-
Notifications
You must be signed in to change notification settings - Fork 0
/
oauth.py
77 lines (63 loc) · 2.24 KB
/
oauth.py
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
import json
from rauth import OAuth1Service, OAuth2Service
from flask import current_app, url_for, request, redirect, session
from services.secrets import FB_ID, FB_SECRET
class OAuthSignIn(object):
providers = None
def __init__(self, provider_name):
self.provider_name = provider_name
def authorize(self):
pass
def callback(self):
pass
def get_callback_url(self):
return url_for('oauth_callback',
provider=self.provider_name,
_external=True,
_scheme="https"
)
@classmethod
def get_provider(self, provider_name):
if self.providers is None:
self.providers = {}
for provider_class in self.__subclasses__():
provider = provider_class()
self.providers[provider.provider_name] = provider
return self.providers[provider_name]
class FacebookSignIn(OAuthSignIn):
def __init__(self):
super(FacebookSignIn, self).__init__('facebook')
self.consumer_id = FB_ID
self.consumer_secret = FB_SECRET
self.service = OAuth2Service(
name='facebook',
client_id=self.consumer_id,
client_secret=self.consumer_secret,
authorize_url='https://graph.facebook.com/oauth/authorize',
access_token_url='https://graph.facebook.com/oauth/access_token',
base_url='https://graph.facebook.com/'
)
def authorize(self):
return redirect(self.service.get_authorize_url(
scope='user_posts',
response_type='code',
redirect_uri=self.get_callback_url())
)
def callback(self):
def decode_json(payload):
return json.loads(payload.decode('utf-8'))
if 'code' not in request.args:
return None, None, None
oauth_session = self.service.get_auth_session(
params={
'code': request.args['code'],
'grant_type': 'authorization_code',
'redirect_uri': self.get_callback_url()
},
decoder=decode_json
)
me = oauth_session.get('me?fields=id').json()
return (
me['id'],
oauth_session.access_token
)