export async function onRequestDelete(context: RequestContext) { const { id } = context.data.body; if ( typeof id !== "string" || id.search(/\D/) || id.length > 19 || id.length < 17 ) return new Response('{"error":"Invalid ID"}', { headers: { "content-type": "application/json", }, status: 400, }); await context.env.DATA.delete(`etmember_${id}`); await context.env.D1.prepare("DELETE FROM et_members WHERE id = ?;") .bind(id) .run(); return new Response(null, { status: 204, }); } export async function onRequestPost(context: RequestContext) { const { id, name } = context.data.body; if ( typeof id !== "string" || id.search(/\D/) || id.length > 19 || id.length < 17 ) return new Response('{"error":"Invalid user ID"}', { headers: { "content-type": "application/json", }, status: 400, }); if (typeof name !== "string" || !name.length || name.length > 32) return new Response('{"error":"Invalid name"}', { headers: { "content-type": "application/json", }, status: 400, }); if (await context.env.DATA.get(`etmember_${id}`)) return new Response('{"error":"User is already a member"}', { headers: { "content-type": "application/json", }, status: 400, }); const createdAt = Date.now(); const addingUser = context.data.current_user.id; await context.env.DATA.put( `etmember_${id}`, JSON.stringify({ created_at: createdAt, created_by: addingUser, name, }), ); await context.env.D1.prepare( "INSERT INTO et_members (created_at, created_by, id, name) VALUES (?, ?, ?, ?);", ) .bind(createdAt, addingUser, id, name) .run(); }