mirror of
https://github.com/Tautulli/Tautulli.git
synced 2025-01-06 11:09:57 -08:00
0d1d2a3e6b
* Bump requests-oauthlib from 1.3.1 to 2.0.0 Bumps [requests-oauthlib](https://github.com/requests/requests-oauthlib) from 1.3.1 to 2.0.0. - [Release notes](https://github.com/requests/requests-oauthlib/releases) - [Changelog](https://github.com/requests/requests-oauthlib/blob/master/HISTORY.rst) - [Commits](https://github.com/requests/requests-oauthlib/compare/v1.3.1...v2.0.0) --- updated-dependencies: - dependency-name: requests-oauthlib dependency-type: direct:production update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] <support@github.com> * Update requests-oauthlib==2.0.0 --------- Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: JonnyWong16 <9099342+JonnyWong16@users.noreply.github.com> [skip ci]
37 lines
1.5 KiB
Python
37 lines
1.5 KiB
Python
from oauthlib.oauth2 import WebApplicationClient, InsecureTransportError
|
|
from oauthlib.oauth2 import is_secure_transport
|
|
from requests.auth import AuthBase
|
|
|
|
|
|
class OAuth2(AuthBase):
|
|
"""Adds proof of authorization (OAuth2 token) to the request."""
|
|
|
|
def __init__(self, client_id=None, client=None, token=None):
|
|
"""Construct a new OAuth 2 authorization object.
|
|
|
|
:param client_id: Client id obtained during registration
|
|
:param client: :class:`oauthlib.oauth2.Client` to be used. Default is
|
|
WebApplicationClient which is useful for any
|
|
hosted application but not mobile or desktop.
|
|
:param token: Token dictionary, must include access_token
|
|
and token_type.
|
|
"""
|
|
self._client = client or WebApplicationClient(client_id, token=token)
|
|
if token:
|
|
for k, v in token.items():
|
|
setattr(self._client, k, v)
|
|
|
|
def __call__(self, r):
|
|
"""Append an OAuth 2 token to the request.
|
|
|
|
Note that currently HTTPS is required for all requests. There may be
|
|
a token type that allows for plain HTTP in the future and then this
|
|
should be updated to allow plain HTTP on a white list basis.
|
|
"""
|
|
if not is_secure_transport(r.url):
|
|
raise InsecureTransportError()
|
|
r.url, r.headers, r.body = self._client.add_token(
|
|
r.url, http_method=r.method, body=r.body, headers=r.headers
|
|
)
|
|
return r
|