From cc9f971274afcf3755689b31dcd83a8d5e55cf86 Mon Sep 17 00:00:00 2001 From: Karl Fischer Date: Mon, 20 Jan 2025 17:04:23 +0100 Subject: [PATCH] APPSRE-11428 mitigate DT bug --- reconcile/utils/dynatrace/client.py | 31 +++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) diff --git a/reconcile/utils/dynatrace/client.py b/reconcile/utils/dynatrace/client.py index 62d7da384f..ea751f9e90 100644 --- a/reconcile/utils/dynatrace/client.py +++ b/reconcile/utils/dynatrace/client.py @@ -1,6 +1,8 @@ from __future__ import annotations from collections.abc import Iterable +from datetime import datetime +from unittest.mock import patch from dynatrace import Dynatrace from dynatrace.environment_v2.tokens_api import ApiTokenUpdate @@ -33,11 +35,32 @@ class DynatraceAPIToken(BaseModel): scopes: list[str] +# TODO: Remove once APPSRE-11428 is resolved ####### +ISO_8601 = "%Y-%m-%dT%H:%M:%S.%fZ" +FIXED_ISO_8601 = "%Y-%m-%dT%H:%M:%SZ" + + +def custom_iso8601_to_datetime(timestamp: str | None) -> datetime | None: + if isinstance(timestamp, str): + try: + return datetime.strptime(timestamp, ISO_8601) + except ValueError: + return datetime.strptime(timestamp, FIXED_ISO_8601) + return timestamp + + +################################################ + + class DynatraceClient: def __init__(self, environment_url: str, api: Dynatrace) -> None: self._environment_url = environment_url self._api = api + @patch( + "dynatrace.environment_v2.tokens_api.iso8601_to_datetime", + custom_iso8601_to_datetime, + ) def create_api_token( self, name: str, scopes: Iterable[str] ) -> DynatraceAPITokenCreated: @@ -49,6 +72,10 @@ def create_api_token( ) from e return DynatraceAPITokenCreated(token=token.token, id=token.id) + @patch( + "dynatrace.environment_v2.tokens_api.iso8601_to_datetime", + custom_iso8601_to_datetime, + ) def get_token_ids_map_for_name_prefix(self, prefix: str) -> dict[str, str]: try: dt_tokens = self._api.tokens.list() @@ -60,6 +87,10 @@ def get_token_ids_map_for_name_prefix(self, prefix: str) -> dict[str, str]: token.id: token.name for token in dt_tokens if token.name.startswith(prefix) } + @patch( + "dynatrace.environment_v2.tokens_api.iso8601_to_datetime", + custom_iso8601_to_datetime, + ) def get_token_by_id(self, token_id: str) -> DynatraceAPIToken: try: token = self._api.tokens.get(token_id=token_id)