diff options
Diffstat (limited to 'backend')
-rw-r--r-- | backend/models/form_response.py | 15 | ||||
-rw-r--r-- | backend/routes/forms/submit.py | 2 |
2 files changed, 13 insertions, 4 deletions
diff --git a/backend/models/form_response.py b/backend/models/form_response.py index b6570e5..8a4da28 100644 --- a/backend/models/form_response.py +++ b/backend/models/form_response.py @@ -15,11 +15,18 @@ class FormResponse(BaseModel): antispam: t.Optional[AntiSpam] response: dict[str, t.Any] form_id: str - timestamp: str = datetime.datetime.now(tz=datetime.timezone.utc).isoformat() + timestamp: str - @validator("timestamp") - def set_timestamp(cls, _: str) -> str: - return datetime.datetime.now(tz=datetime.timezone.utc).isoformat() + @validator("timestamp", pre=True) + def set_timestamp(cls, iso_string: str) -> str: + if iso_string is None: + return datetime.datetime.now(tz=datetime.timezone.utc).isoformat() + + elif not isinstance(iso_string, str): + raise ValueError("Submission timestamp must be a string.") + + # Convert to datetime and back to ensure string is valid + return datetime.datetime.fromisoformat(iso_string).isoformat() class Config: allow_population_by_field_name = True diff --git a/backend/routes/forms/submit.py b/backend/routes/forms/submit.py index 3ecbda0..48ae4f6 100644 --- a/backend/routes/forms/submit.py +++ b/backend/routes/forms/submit.py @@ -34,6 +34,8 @@ class SubmitForm(Route): async def post(self, request: Request) -> JSONResponse: data = await request.json() + data["timestamp"] = None + if form := await request.state.db.forms.find_one( {"_id": request.path_params["form_id"], "features": "OPEN"} ): |