Fix oauth ub session

This commit is contained in:
OzzieIsaacs 2020-12-08 11:24:07 +01:00
parent f677dcb1f4
commit 986d4c99bd
3 changed files with 12707 additions and 860 deletions

View File

@ -89,7 +89,7 @@ class Singleton:
except AttributeError: except AttributeError:
self._instance = self._decorated() self._instance = self._decorated()
return self._instance return self._instance
except ImportError as e: except (ImportError, NameError) as e:
log.debug(e) log.debug(e)
return None return None

View File

@ -100,25 +100,26 @@ def logout_oauth_user():
if ub.oauth_support: if ub.oauth_support:
oauthblueprints = [] oauthblueprints = []
if not g.ubsession.query(ub.OAuthProvider).count(): oauth_session = ub.Scoped_Session()
if not oauth_session.query(ub.OAuthProvider).count():
oauthProvider = ub.OAuthProvider() oauthProvider = ub.OAuthProvider()
oauthProvider.provider_name = "github" oauthProvider.provider_name = "github"
oauthProvider.active = False oauthProvider.active = False
g.ubsession.add(oauthProvider) oauth_session.add(oauthProvider)
try: try:
g.ubsession.commit() oauth_session.commit()
except OperationalError: except OperationalError:
g.ubsession.rollback() oauth_session.rollback()
oauthProvider = ub.OAuthProvider() oauthProvider = ub.OAuthProvider()
oauthProvider.provider_name = "google" oauthProvider.provider_name = "google"
oauthProvider.active = False oauthProvider.active = False
g.ubsession.add(oauthProvider) oauth_session.add(oauthProvider)
try: try:
g.ubsession.commit() oauth_session.commit()
except OperationalError: except OperationalError:
g.ubsession.rollback() oauth_session.rollback()
oauth_ids = g.ubsession.query(ub.OAuthProvider).all() oauth_ids = oauth_session.query(ub.OAuthProvider).all()
ele1 = dict(provider_name='github', ele1 = dict(provider_name='github',
id=oauth_ids[0].id, id=oauth_ids[0].id,
active=oauth_ids[0].active, active=oauth_ids[0].active,
@ -148,7 +149,7 @@ if ub.oauth_support:
scope=element['scope'] scope=element['scope']
) )
element['blueprint'] = blueprint element['blueprint'] = blueprint
element['blueprint'].backend = OAuthBackend(ub.OAuth, g.ubsession, str(element['id']), element['blueprint'].backend = OAuthBackend(ub.OAuth, oauth_session, str(element['id']),
user=current_user, user_required=True) user=current_user, user_required=True)
app.register_blueprint(blueprint, url_prefix="/login") app.register_blueprint(blueprint, url_prefix="/login")
if element['active']: if element['active']:
@ -192,7 +193,7 @@ if ub.oauth_support:
session[provider_id + "_oauth_token"] = token session[provider_id + "_oauth_token"] = token
# Find this OAuth token in the database, or create it # Find this OAuth token in the database, or create it
query = g.ubsession.query(ub.OAuth).filter_by( query = oauth_session.query(ub.OAuth).filter_by(
provider=provider_id, provider=provider_id,
provider_user_id=provider_user_id, provider_user_id=provider_user_id,
) )
@ -207,11 +208,11 @@ if ub.oauth_support:
token=token, token=token,
) )
try: try:
g.ubsession.add(oauth_entry) oauth_session.add(oauth_entry)
g.ubsession.commit() oauth_session.commit()
except Exception as e: except Exception as e:
log.exception(e) log.exception(e)
g.ubsession.rollback() oauth_session.rollback()
# Disable Flask-Dance's default behavior for saving the OAuth token # Disable Flask-Dance's default behavior for saving the OAuth token
# Value differrs depending on flask-dance version # Value differrs depending on flask-dance version

File diff suppressed because it is too large Load Diff