Insert inactivity notices into D1

This commit is contained in:
2023-10-19 16:50:07 -04:00
parent 4d6cde7a0b
commit fdc3afdc69

View File

@ -43,20 +43,25 @@ export async function onRequestPost(context: RequestContext) {
status: 400, status: 400,
}); });
if (!departments.every(d => context.data.departments.includes(d))) if (!departments.every((d) => context.data.departments.includes(d)))
return new Response('{"error":"Cannot file a notice in a department you are not part of"}', { return new Response(
'{"error":"Cannot file a notice in a department you are not part of"}',
{
headers: { headers: {
"content-type": "application/json", "content-type": "application/json",
}, },
status: 400, status: 400,
}); }
);
const inactivityId = const inactivityId =
context.data.current_user.id + context.data.current_user.id +
(context.request.headers.get("cf-ray") as string).split("-")[0] + (context.request.headers.get("cf-ray") as string).split("-")[0] +
Date.now().toString(); Date.now().toString();
await context.env.DATA.put(`inactivity_${inactivityId}`, JSON.stringify({ await context.env.DATA.put(
`inactivity_${inactivityId}`,
JSON.stringify({
created_at: Date.now(), created_at: Date.now(),
departments, departments,
end, end,
@ -67,9 +72,17 @@ export async function onRequestPost(context: RequestContext) {
id: context.data.current_user.id, id: context.data.current_user.id,
username: context.data.current_user.username, username: context.data.current_user.username,
}, },
}), { }),
expirationTtl: 63072000 {
}); expirationTtl: 63072000,
}
);
await context.env.D1.prepare(
"INSERT INTO inactivity_notices (created_at, id, user) VALUES (?, ?, ?);"
)
.bind(Date.now(), inactivityId, context.data.current_user.id)
.run();
return new Response(null, { return new Response(null, {
status: 204, status: 204,