Fix oauth ub session
This commit is contained in:
parent
f677dcb1f4
commit
986d4c99bd
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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
Loading…
Reference in New Issue
Block a user