import { Role, ROLES } from "@/lib/permissions" import { getRequestContext } from "@cloudflare/next-on-pages" import { EMAIL_CONFIG } from "@/config" export const runtime = "edge" export async function GET() { const env = getRequestContext().env const [defaultRole, emailDomains, adminContact, maxEmails] = await Promise.all([ env.SITE_CONFIG.get("DEFAULT_ROLE"), env.SITE_CONFIG.get("EMAIL_DOMAINS"), env.SITE_CONFIG.get("ADMIN_CONTACT"), env.SITE_CONFIG.get("MAX_EMAILS") ]) return Response.json({ defaultRole: defaultRole || ROLES.CIVILIAN, emailDomains: emailDomains || "moemail.app", adminContact: adminContact || "", maxEmails: maxEmails || EMAIL_CONFIG.MAX_ACTIVE_EMAILS.toString() }) } export async function POST(request: Request) { const { defaultRole, emailDomains, adminContact, maxEmails } = await request.json() as { defaultRole: Exclude, emailDomains: string, adminContact: string, maxEmails: string } if (![ROLES.DUKE, ROLES.KNIGHT, ROLES.CIVILIAN].includes(defaultRole)) { return Response.json({ error: "无效的角色" }, { status: 400 }) } const env = getRequestContext().env await Promise.all([ env.SITE_CONFIG.put("DEFAULT_ROLE", defaultRole), env.SITE_CONFIG.put("EMAIL_DOMAINS", emailDomains), env.SITE_CONFIG.put("ADMIN_CONTACT", adminContact), env.SITE_CONFIG.put("MAX_EMAILS", maxEmails) ]) return Response.json({ success: true }) }