From ad2373981ada1803ad731e55050c951d81ecbcf0 Mon Sep 17 00:00:00 2001 From: Youngjin Jo Date: Mon, 5 Aug 2024 22:56:38 +0900 Subject: [PATCH] feat: add edge case when refresh_token is None Signed-off-by: Youngjin Jo --- .../console_api_v2/service/auth_service.py | 21 ++++++++++--------- 1 file changed, 11 insertions(+), 10 deletions(-) diff --git a/src/cloudforet/console_api_v2/service/auth_service.py b/src/cloudforet/console_api_v2/service/auth_service.py index 9b3f2af..f32f605 100644 --- a/src/cloudforet/console_api_v2/service/auth_service.py +++ b/src/cloudforet/console_api_v2/service/auth_service.py @@ -64,7 +64,13 @@ def saml(self, params: dict) -> RedirectResponse: request, console_api_v2_endpoint, dict(form_data) ) domain_name = self._get_domain_name(domain_id) - refresh_token = self._issue_token(credentials, domain_id) + + refresh_token = "unauthorized" + try: + refresh_token = self._issue_token(credentials, domain_id) + except Exception as e: + _LOGGER.error(f"[saml] failed to issue token: {e}") + return self._redirect_response(domain_name, refresh_token) def saml_sp_metadata(self, domain_id: str) -> Response: @@ -163,19 +169,14 @@ def _get_domain_name(domain_id: str) -> str: return response.get("name") @staticmethod - def _redirect_response( - domain_name: str, refresh_token: str = None - ) -> RedirectResponse: + def _redirect_response(domain_name: str, refresh_token: str) -> RedirectResponse: console_domain: str = config.get_global("CONSOLE_DOMAIN").format( domain_name=domain_name ) - if refresh_token: - return RedirectResponse( - f"{console_domain}/saml?refresh_token={refresh_token}", status_code=302 - ) - else: - return RedirectResponse(f"{console_domain}/error-page/401", status_code=302) + return RedirectResponse( + f"{console_domain}/saml?refresh_token={refresh_token}", status_code=302 + ) @staticmethod def _get_acs_url(domain_name: str, domain_id: str) -> str: