dashboard/helpers/hydra_oauth.py

49 lines
1.4 KiB
Python
Raw Normal View History

2022-01-18 09:48:18 +00:00
from flask import request, session
from requests_oauthlib import OAuth2Session
2022-01-20 08:59:00 +01:00
from oauthlib.oauth2 import BackendApplicationClient
from requests.auth import HTTPBasicAuth
2022-01-18 09:48:18 +00:00
from config import *
from helpers import HydraError
class HydraOauth:
SESSION_KEY = "oauth_state"
@staticmethod
def authorize():
try:
hydra = OAuth2Session(HYDRA_CLIENT_ID)
authorization_url, state = hydra.authorization_url(
HYDRA_AUTHORIZATION_BASE_URL
)
# State is used to prevent CSRF, keep this for later.
session[HydraOauth.SESSION_KEY] = state
return authorization_url
except Exception as err:
raise HydraError(str(err), 500)
@staticmethod
def get_token(state, code):
2022-01-18 09:48:18 +00:00
try:
2022-01-20 08:59:00 +01:00
auth = HTTPBasicAuth(HYDRA_CLIENT_ID, HYDRA_CLIENT_SECRET)
client = BackendApplicationClient(client_id=HYDRA_CLIENT_ID)
hydra = OAuth2Session(client=client, state=state)
# hydra = OAuth2Session(
# client_id=HYDRA_CLIENT_ID,
# state=state,
# )
2022-01-20 07:49:11 +01:00
token = hydra.fetch_token(
2022-01-20 08:59:00 +01:00
token_url=TOKEN_URL,
auth=auth,
code=code,
client_secret=HYDRA_CLIENT_SECRET,
2022-01-18 09:48:18 +00:00
)
session["hydra_token"] = token
return token
except Exception as err:
raise HydraError(str(err), 500)