From a675967751be1f29b2c3ecee68c8b8bc6fb2aca1 Mon Sep 17 00:00:00 2001 From: Kegan Maher Date: Wed, 17 Jul 2024 20:50:17 +0000 Subject: [PATCH] refactor(oauth): centralize analytics, sentry, error redirect --- benefits/oauth/views.py | 31 ++++++++++++++++++------------- 1 file changed, 18 insertions(+), 13 deletions(-) diff --git a/benefits/oauth/views.py b/benefits/oauth/views.py index d758736fd1..b149d0490c 100644 --- a/benefits/oauth/views.py +++ b/benefits/oauth/views.py @@ -69,19 +69,22 @@ def login(request): logger.debug(f"OAuth authorize_redirect with redirect_uri: {redirect_uri}") analytics.started_sign_in(request) + exception = None + result = None try: result = oauth_client.authorize_redirect(request, redirect_uri) except Exception as ex: - analytics.client_error(request, message=str(ex), operation="authorize_redirect") - sentry_sdk.capture_exception(ex) - result = redirect(redirects.ROUTE_SYSTEM_ERROR) + exception = ex - if result.status_code >= 400: - analytics.client_error(request, message=result.status_code, operation="authorize_redirect") - sentry_sdk.capture_exception( - Exception(f"authorize_redirect error response [{result.status_code}]: {result.content.decode()}") - ) + if result and result.status_code >= 400: + exception = Exception(f"authorize_redirect error response [{result.status_code}]: {result.content.decode()}") + elif result is None: + exception = Exception("authorize_redirect returned None") + + if exception: + analytics.client_error(request, message=str(exception), operation="authorize_redirect") + sentry_sdk.capture_exception(exception) result = redirect(redirects.ROUTE_SYSTEM_ERROR) return result @@ -103,18 +106,20 @@ def authorize(request): logger.debug("Attempting to authorize OAuth access token") token = None + exception = None try: token = oauth_client.authorize_access_token(request) except Exception as ex: - analytics.client_error(request, message=str(ex), operation="authorize_access_token") - sentry_sdk.capture_exception(ex) - return redirect(redirects.ROUTE_SYSTEM_ERROR) + exception = ex if token is None: logger.warning("Could not authorize OAuth access token") - analytics.client_error(request, message="token was None", operation="authorize_access_token") - sentry_sdk.capture_exception(Exception("oauth_client.authorize_access_token returned None")) + exception = Exception("oauth_client.authorize_access_token returned None") + + if exception: + analytics.client_error(request, message=str(exception), operation="authorize_access_token") + sentry_sdk.capture_exception(exception) return redirect(redirects.ROUTE_SYSTEM_ERROR) logger.debug("OAuth access token authorized")