From 6a59a02703c328153e12db3ee6154e3d1392990f Mon Sep 17 00:00:00 2001 From: anishfyle Date: Thu, 19 Dec 2024 13:35:16 +0530 Subject: [PATCH] feat: handle expired credentials/tokens --- apps/travelperk/urls.py | 4 +++- apps/travelperk/views.py | 37 +++++++++++++++++++++++++++++++++++++ 2 files changed, 40 insertions(+), 1 deletion(-) diff --git a/apps/travelperk/urls.py b/apps/travelperk/urls.py index f44afd3..9442f4a 100644 --- a/apps/travelperk/urls.py +++ b/apps/travelperk/urls.py @@ -7,7 +7,8 @@ DisconnectTravelperkView, TravelperkPaymentProfileMappingView, SyncPaymentProfiles, - AdvancedSettingView + AdvancedSettingView, + ValidateHealthyToken ) app_name = 'travelperk' @@ -20,4 +21,5 @@ path('advanced_settings/', AdvancedSettingView.as_view(), name='advance-settings-view'), path('profile_mappings/', TravelperkPaymentProfileMappingView.as_view(), name='profile-mappings'), path('sync_payment_profile/', SyncPaymentProfiles.as_view(), name='sync-payment-profiles'), + path('workspaces//travelperk/token_health/', ValidateHealthyToken.as_view(), name='token-health'), ] diff --git a/apps/travelperk/views.py b/apps/travelperk/views.py index d8fe90f..2ecc624 100644 --- a/apps/travelperk/views.py +++ b/apps/travelperk/views.py @@ -269,3 +269,40 @@ class SyncPaymentProfiles(generics.ListAPIView): def get_queryset(self): return SyncPaymentProfileSerializer().sync_payment_profiles(self.kwargs['org_id']) + + +class ValidateHealthyToken(generics.ListAPIView): + """ + API to check if TravelPerk credentials are healthy + """ + def get(self, request, *args, **kwargs): + try: + travelperk = TravelPerk.objects.get(org_id__in=[kwargs['org_id']]) + travelperk_credentials = TravelperkCredential.objects.get(org_id=kwargs['org_id']) + + travelperk_connection = TravelperkConnector(travelperk_credentials, kwargs['org_id']) + + # Try to fetch profiles to verify credentials + profiles_generator = travelperk_connection.connection.invoice_profiles.get_all_generator() + next(profiles_generator, None) # Try to get first profile + + return Response( + data={'message': 'Ready'}, + status=status.HTTP_200_OK + ) + + except (TravelPerk.DoesNotExist, TravelperkCredential.DoesNotExist): + return Response( + data={'message': 'TravelPerk connection not found'}, + status=status.HTTP_404_NOT_FOUND + ) + except Exception: + # If we can't fetch profiles, credentials are likely expired + if travelperk: + travelperk.is_travelperk_connected = False + travelperk.save() + + return Response( + data={'message': 'Invalid credentials'}, + status=status.HTTP_400_BAD_REQUEST + ) \ No newline at end of file