about summary refs log tree commit diff
path: root/.venv/lib/python3.12/site-packages/requests_oauthlib/compliance_fixes/facebook.py
diff options
context:
space:
mode:
Diffstat (limited to '.venv/lib/python3.12/site-packages/requests_oauthlib/compliance_fixes/facebook.py')
-rw-r--r--.venv/lib/python3.12/site-packages/requests_oauthlib/compliance_fixes/facebook.py27
1 files changed, 27 insertions, 0 deletions
diff --git a/.venv/lib/python3.12/site-packages/requests_oauthlib/compliance_fixes/facebook.py b/.venv/lib/python3.12/site-packages/requests_oauthlib/compliance_fixes/facebook.py
new file mode 100644
index 00000000..f44558a8
--- /dev/null
+++ b/.venv/lib/python3.12/site-packages/requests_oauthlib/compliance_fixes/facebook.py
@@ -0,0 +1,27 @@
+from json import dumps
+from urllib.parse import parse_qsl
+
+
+def facebook_compliance_fix(session):
+    def _compliance_fix(r):
+        # if Facebook claims to be sending us json, let's trust them.
+        if "application/json" in r.headers.get("content-type", {}):
+            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.
+        if "text/plain" in r.headers.get("content-type", {}) and r.status_code == 200:
+            token = dict(parse_qsl(r.text, keep_blank_values=True))
+        else:
+            return r
+
+        expires = token.get("expires")
+        if expires is not None:
+            token["expires_in"] = expires
+        token["token_type"] = "Bearer"
+        r._content = dumps(token).encode()
+        return r
+
+    session.register_compliance_hook("access_token_response", _compliance_fix)
+    return session