summaryrefslogtreecommitdiff
path: root/game/python-extra/requests_oauthlib/compliance_fixes/fitbit.py
diff options
context:
space:
mode:
Diffstat (limited to 'game/python-extra/requests_oauthlib/compliance_fixes/fitbit.py')
-rw-r--r--game/python-extra/requests_oauthlib/compliance_fixes/fitbit.py25
1 files changed, 25 insertions, 0 deletions
diff --git a/game/python-extra/requests_oauthlib/compliance_fixes/fitbit.py b/game/python-extra/requests_oauthlib/compliance_fixes/fitbit.py
new file mode 100644
index 0000000..7e62702
--- /dev/null
+++ b/game/python-extra/requests_oauthlib/compliance_fixes/fitbit.py
@@ -0,0 +1,25 @@
+"""
+The Fitbit API breaks from the OAuth2 RFC standard by returning an "errors"
+object list, rather than a single "error" string. This puts hooks in place so
+that oauthlib can process an error in the results from access token and refresh
+token responses. This is necessary to prevent getting the generic red herring
+MissingTokenError.
+"""
+
+from json import loads, dumps
+
+from oauthlib.common import to_unicode
+
+
+def fitbit_compliance_fix(session):
+ def _missing_error(r):
+ token = loads(r.text)
+ if "errors" in token:
+ # Set the error to the first one we have
+ token["error"] = token["errors"][0]["errorType"]
+ r._content = to_unicode(dumps(token)).encode("UTF-8")
+ return r
+
+ session.register_compliance_hook("access_token_response", _missing_error)
+ session.register_compliance_hook("refresh_token_response", _missing_error)
+ return session