summaryrefslogtreecommitdiffstats
path: root/src/libcmis-c/oauth2-data.cxx
blob: 9b7c69f4a0c45f5498e30eb4fc3cef1bf3d84fbd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
/* libcmis
 * Version: MPL 1.1 / GPLv2+ / LGPLv2+
 *
 * The contents of this file are subject to the Mozilla Public License Version
 * 1.1 (the "License"); you may not use this file except in compliance with
 * the License or as specified alternatively below. You may obtain a copy of
 * the License at http://www.mozilla.org/MPL/
 *
 * Software distributed under the License is distributed on an "AS IS" basis,
 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
 * for the specific language governing rights and limitations under the
 * License.
 *
 * Major Contributor(s):
 * Copyright (C) 2011 SUSE <cbosdonnat@suse.com>
 *
 *
 * All Rights Reserved.
 *
 * For minor contributions see the git repository.
 *
 * Alternatively, the contents of this file may be used under the terms of
 * either the GNU General Public License Version 2 or later (the "GPLv2+"), or
 * the GNU Lesser General Public License Version 2 or later (the "LGPLv2+"),
 * in which case the provisions of the GPLv2+ or the LGPLv2+ are applicable
 * instead of those above.
 */

#include <libcmis-c/oauth2-data.h>

#include "internals.hxx"

using namespace std;


libcmis_OAuth2DataPtr libcmis_oauth2data_create(
        char* authUrl, char* tokenUrl, char* scope, char* redirectUri,
        char* clientId, char* clientSecret )
{
    libcmis_OAuth2DataPtr data = new( nothrow ) libcmis_oauth2data( );

    if ( NULL != data )
        data->handle.reset( new libcmis::OAuth2Data(
                   authUrl, tokenUrl, scope, redirectUri,
                   clientId, clientSecret ) );
    return data;
}


void libcmis_oauth2data_free( libcmis_OAuth2DataPtr oauth2 )
{
    delete oauth2;
}


bool libcmis_oauth2data_isComplete( libcmis_OAuth2DataPtr oauth2 )
{
    bool result = false;
    if ( oauth2 != NULL && oauth2->handle != NULL )
        result = oauth2->handle->isComplete();
    return result;
}


const char* libcmis_oauth2data_getAuthUrl( libcmis_OAuth2DataPtr oauth2 )
{
    if ( oauth2 != NULL && oauth2->handle != NULL )
        return oauth2->handle->getAuthUrl().c_str();
    return NULL;
}


const char* libcmis_oauth2data_getTokenUrl( libcmis_OAuth2DataPtr oauth2 )
{
    if ( oauth2 != NULL && oauth2->handle != NULL )
        return oauth2->handle->getTokenUrl().c_str();
    return NULL;
}


const char* libcmis_oauth2data_getClientId( libcmis_OAuth2DataPtr oauth2 )
{
    if ( oauth2 != NULL && oauth2->handle != NULL )
        return oauth2->handle->getClientId().c_str();
    return NULL;
}


const char* libcmis_oauth2data_getClientSecret( libcmis_OAuth2DataPtr oauth2 )
{
    if ( oauth2 != NULL && oauth2->handle != NULL )
        return oauth2->handle->getClientSecret().c_str();
    return NULL;
}


const char* libcmis_oauth2data_getScope( libcmis_OAuth2DataPtr oauth2 )
{
    if ( oauth2 != NULL && oauth2->handle != NULL )
        return oauth2->handle->getScope().c_str();
    return NULL;
}


const char* libcmis_oauth2data_getRedirectUri( libcmis_OAuth2DataPtr oauth2 )
{
    if ( oauth2 != NULL && oauth2->handle != NULL )
        return oauth2->handle->getRedirectUri().c_str();
    return NULL;
}