From 417cea175a2598cd9e053fcd641561c842d76a92 Mon Sep 17 00:00:00 2001 From: Renan Butkeraites Date: Fri, 29 Nov 2024 19:06:25 -0300 Subject: [PATCH] Remove redundant JSON schema type reinforcement method in KlaviyoStream to streamline post-processing. This change simplifies the code and enhances maintainability by relying on existing type handling mechanisms. --- tap_klaviyo/client.py | 39 +-------------------------------------- 1 file changed, 1 insertion(+), 38 deletions(-) diff --git a/tap_klaviyo/client.py b/tap_klaviyo/client.py index 3085ae8..378e3bd 100644 --- a/tap_klaviyo/client.py +++ b/tap_klaviyo/client.py @@ -93,50 +93,13 @@ def get_url_params( params["filter"] = f"greater-than({self.replication_key},{start_date})" return params - def _reinforce_jsonschema_type(self, obj, sub_schema): - if "null" in sub_schema["type"] and obj is None: - return None - if "integer" in sub_schema["type"]: - try: - return int(obj) - except: - pass - if "number" in sub_schema["type"]: - try: - return float(obj) - except: - pass - if "boolean" in sub_schema["type"]: - try: - return bool(obj) - except: - pass - if "string" in sub_schema["type"]: - if self.is_unix_timestamp(obj): - return obj - try: - return str(obj) - except: - pass - if type(obj) == list: - if len(obj) > 0: - return [self._reinforce_jsonschema_type(item, sub_schema["items"]) for item in obj] - else: - return [] - if type(obj) == dict: - reinforced_obj = {} - for key in obj.keys(): - reinforced_obj[key] = self._reinforce_jsonschema_type(obj[key], sub_schema["properties"][key]) - return reinforced_obj - else: - raise Exception(f"Unsupported type: {type(obj)}") + def post_process(self, row, context): row = super().post_process(row, context) for key, value in row.get("attributes", {}).items(): row[key] = value row.pop("attributes", None) - row = self._reinforce_jsonschema_type(row, self.schema) return row def is_unix_timestamp(self, date):