2018-09-17 08:27:00 +08:00
|
|
|
from json import dumps
|
2022-01-24 12:07:52 +08:00
|
|
|
|
2018-09-17 08:27:00 +08:00
|
|
|
try:
|
|
|
|
from urlparse import parse_qsl
|
|
|
|
except ImportError:
|
|
|
|
from urllib.parse import parse_qsl
|
|
|
|
|
|
|
|
from oauthlib.common import to_unicode
|
|
|
|
|
|
|
|
|
|
|
|
def facebook_compliance_fix(session):
|
|
|
|
def _compliance_fix(r):
|
|
|
|
# if Facebook claims to be sending us json, let's trust them.
|
2022-01-24 12:07:52 +08:00
|
|
|
if "application/json" in r.headers.get("content-type", {}):
|
2018-09-17 08:27:00 +08:00
|
|
|
return r
|
|
|
|
|
|
|
|
# Facebook returns a content-type of text/plain when sending their
|
|
|
|
# x-www-form-urlencoded responses, along with a 200. If not, let's
|
|
|
|
# assume we're getting JSON and bail on the fix.
|
2022-01-24 12:07:52 +08:00
|
|
|
if "text/plain" in r.headers.get("content-type", {}) and r.status_code == 200:
|
2018-09-17 08:27:00 +08:00
|
|
|
token = dict(parse_qsl(r.text, keep_blank_values=True))
|
|
|
|
else:
|
|
|
|
return r
|
|
|
|
|
2022-01-24 12:07:52 +08:00
|
|
|
expires = token.get("expires")
|
2018-09-17 08:27:00 +08:00
|
|
|
if expires is not None:
|
2022-01-24 12:07:52 +08:00
|
|
|
token["expires_in"] = expires
|
|
|
|
token["token_type"] = "Bearer"
|
|
|
|
r._content = to_unicode(dumps(token)).encode("UTF-8")
|
2018-09-17 08:27:00 +08:00
|
|
|
return r
|
|
|
|
|
2022-01-24 12:07:52 +08:00
|
|
|
session.register_compliance_hook("access_token_response", _compliance_fix)
|
2018-09-17 08:27:00 +08:00
|
|
|
return session
|