Improve event editing endpoint
This commit is contained in:
parent
06bcb2507e
commit
4f08791f98
@ -31,11 +31,12 @@ export async function onRequestDelete(context: RequestContext) {
|
|||||||
export async function onRequestPatch(context: RequestContext) {
|
export async function onRequestPatch(context: RequestContext) {
|
||||||
const eventId = context.params.id as string;
|
const eventId = context.params.id as string;
|
||||||
const { body } = context.data;
|
const { body } = context.data;
|
||||||
const eventData = await context.env.D1.prepare(
|
const eventData: Record<string, number | string> | null =
|
||||||
"SELECT answer, created_by, details FROM events WHERE id = ?;",
|
await context.env.D1.prepare(
|
||||||
)
|
"SELECT answer, created_by, day, details, month, year FROM events WHERE id = ?;",
|
||||||
.bind(eventId)
|
)
|
||||||
.first();
|
.bind(eventId)
|
||||||
|
.first();
|
||||||
|
|
||||||
if (!eventData) return jsonError("No event exists with that ID", 404);
|
if (!eventData) return jsonError("No event exists with that ID", 404);
|
||||||
|
|
||||||
@ -51,11 +52,27 @@ export async function onRequestPatch(context: RequestContext) {
|
|||||||
eventData.details &&= body.details;
|
eventData.details &&= body.details;
|
||||||
|
|
||||||
await context.env.D1.prepare(
|
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();
|
.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, {
|
return new Response(null, {
|
||||||
status: 204,
|
status: 204,
|
||||||
});
|
});
|
||||||
|
Loading…
x
Reference in New Issue
Block a user