import { jsonError } from "../../../common.js";
import sendEmail from "../../../email.js";

export async function onRequestPost(context: RequestContext) {
  const { appeal } = context.data;
  const emailResponse = await sendEmail(
    appeal.user.email,
    context.env.MAILGUN_API_KEY,
    "Appeal Accepted",
    "appeal_accepted",
    {
      note: context.data.body.feedback || "No note provided.",
    },
  );

  if (!emailResponse.ok) {
    console.log(await emailResponse.json());
    return jsonError("Failed to accept appeal", 500);
  }

  const { current_user: currentUser } = context.data;

  await context.env.D1.prepare("UPDATE appeals SET open = 0 WHERE id = ?;")
    .bind(context.params.id)
    .run();

  delete appeal.user.email;

  await context.env.DATA.put(`appeal_${appeal.id}`, JSON.stringify(appeal), {
    expirationTtl: 94608000,
  });

  await fetch(
    `https://discord.com/api/v10/guilds/242263977986359297/bans/${appeal.id}`,
    {
      headers: {
        authorization: `Bot ${context.env.BOT_TOKEN}`,
        "x-audit-log-reason": `Appeal accepted by ${currentUser.username} (${currentUser.id})`,
      },
      method: "DELETE",
    },
  );

  await fetch(context.env.APPEALS_WEBHOOK, {
    body: JSON.stringify({
      embeds: [
        {
          title: "Appeal Accepted",
          color: 0x00ff00,
          description: `Appeal from user ${appeal.user.username} (${appeal.user.id}) was accepted.`,
          fields: [
            {
              name: "Moderator",
              value: `${currentUser.username} (${currentUser.id})`,
            },
          ],
        },
      ],
    }),
    headers: {
      "content-type": "application/json",
    },
    method: "POST",
  });

  return new Response(null, {
    status: 204,
  });
}