/usr/lib/python2.7/dist-packages/social/backends/stripe.py is in python-social-auth 1:0.2.21+dfsg-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 | """
Stripe OAuth2 backend, docs at:
http://psa.matiasaguirre.net/docs/backends/stripe.html
"""
from social.backends.oauth import BaseOAuth2
class StripeOAuth2(BaseOAuth2):
"""Stripe OAuth2 authentication backend"""
name = 'stripe'
ID_KEY = 'stripe_user_id'
AUTHORIZATION_URL = 'https://connect.stripe.com/oauth/authorize'
ACCESS_TOKEN_URL = 'https://connect.stripe.com/oauth/token'
ACCESS_TOKEN_METHOD = 'POST'
REDIRECT_STATE = False
EXTRA_DATA = [
('stripe_publishable_key', 'stripe_publishable_key'),
('access_token', 'access_token'),
('livemode', 'livemode'),
('token_type', 'token_type'),
('refresh_token', 'refresh_token'),
('stripe_user_id', 'stripe_user_id'),
]
def get_user_details(self, response):
"""Return user details from Stripe account"""
return {'username': response.get('stripe_user_id'),
'email': ''}
def auth_params(self, state=None):
client_id, client_secret = self.get_key_and_secret()
params = {'response_type': 'code',
'client_id': client_id}
if state:
params['state'] = state
return params
def auth_complete_params(self, state=None):
client_id, client_secret = self.get_key_and_secret()
return {
'grant_type': 'authorization_code',
'client_id': client_id,
'scope': self.SCOPE_SEPARATOR.join(self.get_scope()),
'code': self.data['code']
}
def auth_headers(self):
client_id, client_secret = self.get_key_and_secret()
return {'Accept': 'application/json',
'Authorization': 'Bearer {0}'.format(client_secret)}
def refresh_token_params(self, refresh_token, *args, **kwargs):
return {'refresh_token': refresh_token,
'grant_type': 'refresh_token'}
|