From de98d748a9548e420be3cef3fde58eb4ce777940 Mon Sep 17 00:00:00 2001 From: Trenton H <797416+stumpylog@users.noreply.github.com> Date: Tue, 22 Nov 2022 10:11:27 -0800 Subject: [PATCH] If override_date is provided, coerce it into a datetime --- src/documents/tasks.py | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/src/documents/tasks.py b/src/documents/tasks.py index 667c3d9df..f5bad665a 100644 --- a/src/documents/tasks.py +++ b/src/documents/tasks.py @@ -3,6 +3,7 @@ import logging import os import shutil import uuid +from datetime import datetime from pathlib import Path from typing import Type @@ -98,6 +99,14 @@ def consume_file( path = Path(path).resolve() + # Celery converts this to a string, but everything expects a datetime + # Long term solution is to not use JSON for the serializer but pickle instead + if override_created is not None and isinstance(override_created, str): + try: + override_created = datetime.fromisoformat(override_created) + except Exception: + pass + # check for separators in current document if settings.CONSUMER_ENABLE_BARCODES: