Improve event editing endpoint

This commit is contained in:
Regalijan 2024-09-10 16:34:56 -04:00
parent 06bcb2507e
commit 4f08791f98
Signed by: regalijan
GPG Key ID: 5D4196DA269EF520

View File

@ -31,8 +31,9 @@ export async function onRequestDelete(context: RequestContext) {
export async function onRequestPatch(context: RequestContext) {
const eventId = context.params.id as string;
const { body } = context.data;
const eventData = await context.env.D1.prepare(
"SELECT answer, created_by, details FROM events WHERE id = ?;",
const eventData: Record<string, number | string> | null =
await context.env.D1.prepare(
"SELECT answer, created_by, day, details, month, year FROM events WHERE id = ?;",
)
.bind(eventId)
.first();
@ -51,11 +52,27 @@ export async function onRequestPatch(context: RequestContext) {
eventData.details &&= body.details;
await context.env.D1.prepare(
"UPDATE events SET answer = ?, details = ? WHERE id = ?;",
"UPDATE events SET answer = ?, approved = 0, day = ?, details = ?, pending = 1 WHERE id = ?;",
)
.bind(eventData.answer, eventData.details, eventId)
.bind(eventData.answer, eventData.day, eventData.details, eventId)
.run();
await fetch(context.env.EVENTS_WEBHOOK, {
body: JSON.stringify({
embeds: [
{
title: "Event Modified",
color: 3756250,
description: `${context.data.current_user.username} updated their ${(eventData.type as string).toUpperCase()} for ${eventData.year}-${eventData.month.toString().padStart(2, "0")}-${eventData.day.toString().padStart(2, "0")}`,
},
],
}),
headers: {
"content-type": "application/json",
},
method: "POST",
});
return new Response(null, {
status: 204,
});