From c31b4d6b4f680e3f8ce0169d286e21692bc940f3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jonah=20Br=C3=BCchert?= Date: Fri, 1 Mar 2024 02:53:22 +0100 Subject: [PATCH] Fix timezone shenanigans Passing %Z to strptime does not result in a datetime with a timezone set. This doesn't make sense at all but the random email function does the right thing. --- src/fetch.py | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/src/fetch.py b/src/fetch.py index 0d007e13..d3c1398a 100755 --- a/src/fetch.py +++ b/src/fetch.py @@ -5,7 +5,8 @@ from metadata import * from pathlib import Path -from datetime import datetime +from datetime import datetime, timezone +import email.utils import requests import transitland @@ -39,11 +40,12 @@ def fetch_source(self, name: str, source: Source) -> Optional[Path]: dest_path = Path(f"downloads/{name}.gtfs.zip") if dest_path.exists(): mtime = dest_path.stat().st_mtime - last_modified = datetime.fromtimestamp(mtime) + last_modified = datetime.fromtimestamp(mtime, + tz=timezone.utc) # Check if the last download was longer than the interval ago if source.options.fetch_interval_days and last_modified \ - and (datetime.now() - last_modified).days \ + and (datetime.now(timezone.utc) - last_modified).days \ < source.options.fetch_interval_days: return None @@ -54,8 +56,8 @@ def fetch_source(self, name: str, source: Source) -> Optional[Path]: # If server version is older, return last_modified_server = None if "last-modified" in server_headers: - last_modified_server = datetime.strptime( - server_headers["last-modified"], "%a, %d %b %Y %X %Z") + last_modified_server = email.utils.parsedate_to_datetime( + server_headers["last-modified"]) if last_modified and last_modified_server <= last_modified: return None @@ -92,8 +94,8 @@ def fetch_source(self, name: str, source: Source) -> Optional[Path]: # but the actual target does. server_headers = response.headers if "last-modified" in server_headers: - last_modified_server = datetime.strptime( - server_headers["last-modified"], "%a, %d %b %Y %X %Z") + last_modified_server = email.utils.parsedate_to_datetime( + server_headers["last-modified"]) with open(dest_path, "wb") as dest: dest.write(response.content)