source: lib/oauth.h @ e618d85

Last change on this file since e618d85 was 36533bf, checked in by Wilmer van der Gaast <wilmer@…>, at 2011-12-19T12:54:49Z

When updating the XMPP password field with OAuth data, try harder to preserve
existing data. (Like refresh tokens which we'll need again on next login.)

  • Property mode set to 100644
File size: 4.1 KB
RevLine 
[be28fe7]1/***************************************************************************\
2*                                                                           *
3*  BitlBee - An IRC to IM gateway                                           *
4*  Simple OAuth client (consumer) implementation.                           *
5*                                                                           *
6*  Copyright 2010 Wilmer van der Gaast <wilmer@gaast.net>                   *
7*                                                                           *
8*  This program is free software; you can redistribute it and/or modify     *
9*  it under the terms of the GNU General Public License as published by     *
10*  the Free Software Foundation; either version 2 of the License, or        *
11*  (at your option) any later version.                                      *
12*                                                                           *
13*  This program is distributed in the hope that it will be useful,          *
14*  but WITHOUT ANY WARRANTY; without even the implied warranty of           *
15*  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the            *
16*  GNU General Public License for more details.                             *
17*                                                                           *
18*  You should have received a copy of the GNU General Public License along  *
19*  with this program; if not, write to the Free Software Foundation, Inc.,  *
20*  51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.              *
21*                                                                           *
22\***************************************************************************/
[508c340]23
[acba168]24/* http://oauth.net/core/1.0a/ */
25
26struct oauth_info;
[18dbb20]27
28/* Callback function called twice during the access token request process.
29   Return FALSE if something broke and the process must be aborted. */
30typedef gboolean (*oauth_cb)( struct oauth_info * );
[acba168]31
[c42e8b9]32typedef enum
33{
34        OAUTH_INIT,
35        OAUTH_REQUEST_TOKEN,
36        OAUTH_ACCESS_TOKEN,
37} oauth_stage_t;
38
[acba168]39struct oauth_info
40{
[c42e8b9]41        oauth_stage_t stage;
[3b878a1]42        const struct oauth_service *sp;
[c42e8b9]43       
[acba168]44        oauth_cb func;
45        void *data;
46       
47        struct http_request *http;
48       
[c2ecadc]49        char *auth_url;
[713d611]50        char *request_token;
[acba168]51       
[c2ecadc]52        char *token;
53        char *token_secret;
[93cc86f]54        GSList *params;
[c2ecadc]55};
56
57struct oauth_service
58{
59        char *url_request_token;
60        char *url_access_token;
61        char *url_authorize;
62       
63        char *consumer_key;
64        char *consumer_secret;
[acba168]65};
66
67/* http://oauth.net/core/1.0a/#auth_step1 (section 6.1)
68   Request an initial anonymous token which can be used to construct an
69   authorization URL for the user. This is passed to the callback function
70   in a struct oauth_info. */
[3b878a1]71struct oauth_info *oauth_request_token( const struct oauth_service *sp, oauth_cb func, void *data );
[acba168]72
73/* http://oauth.net/core/1.0a/#auth_step3 (section 6.3)
74   The user gets a PIN or so which we now exchange for the final access
75   token. This is passed to the callback function in the same
76   struct oauth_info. */
[c2ecadc]77gboolean oauth_access_token( const char *pin, struct oauth_info *st );
[acba168]78
79/* http://oauth.net/core/1.0a/#anchor12 (section 7)
80   Generate an OAuth Authorization: HTTP header. access_token should be
81   saved/fetched using the functions above. args can be a string with
82   whatever's going to be in the POST body of the request. GET args will
83   automatically be grabbed from url. */
[c2ecadc]84char *oauth_http_header( struct oauth_info *oi, const char *method, const char *url, char *args );
[18dbb20]85
86/* Shouldn't normally be required unless the process is aborted by the user. */
87void oauth_info_free( struct oauth_info *info );
[f4b0911]88
89/* Convert to and back from strings, for easier saving. */
90char *oauth_to_string( struct oauth_info *oi );
[3b878a1]91struct oauth_info *oauth_from_string( char *in, const struct oauth_service *sp );
[93cc86f]92
93/* For reading misc. data. */
[4a5d885]94void oauth_params_add( GSList **params, const char *key, const char *value );
[aa9f1ac]95void oauth_params_parse( GSList **params, char *in );
[4a5d885]96void oauth_params_free( GSList **params );
97char *oauth_params_string( GSList *params );
[36533bf]98void oauth_params_set( GSList **params, const char *key, const char *value );
[93cc86f]99const char *oauth_params_get( GSList **params, const char *key );
Note: See TracBrowser for help on using the repository browser.