From ccfa2149c39c242a6a018a059c3b483f3090b831 Mon Sep 17 00:00:00 2001 From: Miauwkeru Date: Wed, 11 Oct 2023 09:54:00 +0200 Subject: [PATCH] Add behaviour to always use datetime.UTC if there is no zoneinfo available (#86) Add behaviour to always use datetime.UTC if there is no zoneinfo available --------- Co-authored-by: Yun Zheng Hu --- flow/record/fieldtypes/__init__.py | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) diff --git a/flow/record/fieldtypes/__init__.py b/flow/record/fieldtypes/__init__.py index f636df7..fe31d2d 100644 --- a/flow/record/fieldtypes/__init__.py +++ b/flow/record/fieldtypes/__init__.py @@ -15,9 +15,14 @@ from urllib.parse import urlparse try: - from zoneinfo import ZoneInfo, ZoneInfoNotFoundError + try: + from zoneinfo import ZoneInfo, ZoneInfoNotFoundError + except ImportError: + from backports.zoneinfo import ZoneInfo, ZoneInfoNotFoundError + HAS_ZONE_INFO = True except ImportError: - from backports.zoneinfo import ZoneInfo, ZoneInfoNotFoundError + HAS_ZONE_INFO = False + from flow.record.base import FieldType @@ -50,9 +55,16 @@ def flow_record_tz(*, default_tz: str = "UTC") -> Optional[ZoneInfo | UTC]: Returns: None if ``FLOW_RECORD_TZ=NONE`` otherwise ``ZoneInfo(FLOW_RECORD_TZ)`` or ``UTC`` if ZoneInfo is not found. """ + tz = os.environ.get("FLOW_RECORD_TZ", default_tz) if tz.upper() == "NONE": return None + + if not HAS_ZONE_INFO: + if tz != "UTC": + warnings.warn("Cannot use FLOW_RECORD_TZ due to missing zoneinfo module, defaulting to 'UTC'.") + return UTC + try: return ZoneInfo(tz) except ZoneInfoNotFoundError as exc: