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();
}