aboutsummaryrefslogtreecommitdiffstats
path: root/backend
diff options
context:
space:
mode:
Diffstat (limited to 'backend')
-rw-r--r--backend/models/form_response.py15
-rw-r--r--backend/routes/forms/submit.py2
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"}
):