/* eslint-disable @typescript-eslint/no-explicit-any,no-console */ import { NextRequest, NextResponse } from 'next/server'; import { getAuthInfoFromCookie } from '@/lib/auth'; import { getConfig } from '@/lib/config'; import { getStorage } from '@/lib/db'; export const runtime = 'edge'; export async function POST(request: NextRequest) { const storageType = process.env.NEXT_PUBLIC_STORAGE_TYPE || 'localstorage'; if (storageType === 'localstorage') { return NextResponse.json( { error: '不支持本地存储进行管理员配置', }, { status: 400 } ); } try { const body = await request.json(); const authInfo = getAuthInfoFromCookie(request); if (!authInfo || !authInfo.username) { return NextResponse.json({ error: 'Unauthorized' }, { status: 401 }); } const username = authInfo.username; const { SiteName, Announcement, SearchDownstreamMaxPage, SiteInterfaceCacheTime, ImageProxy, DoubanProxy, } = body as { SiteName: string; Announcement: string; SearchDownstreamMaxPage: number; SiteInterfaceCacheTime: number; ImageProxy: string; DoubanProxy: string; }; // 参数校验 if ( typeof SiteName !== 'string' || typeof Announcement !== 'string' || typeof SearchDownstreamMaxPage !== 'number' || typeof SiteInterfaceCacheTime !== 'number' || typeof ImageProxy !== 'string' || typeof DoubanProxy !== 'string' ) { return NextResponse.json({ error: '参数格式错误' }, { status: 400 }); } const adminConfig = await getConfig(); const storage = getStorage(); // 权限校验 if (username !== process.env.USERNAME) { // 管理员 const user = adminConfig.UserConfig.Users.find( (u) => u.username === username ); if (!user || user.role !== 'admin') { return NextResponse.json({ error: '权限不足' }, { status: 401 }); } } // 更新缓存中的站点设置 adminConfig.SiteConfig = { SiteName, Announcement, SearchDownstreamMaxPage, SiteInterfaceCacheTime, ImageProxy, DoubanProxy, }; // 写入数据库 if (storage && typeof (storage as any).setAdminConfig === 'function') { await (storage as any).setAdminConfig(adminConfig); } return NextResponse.json( { ok: true }, { headers: { 'Cache-Control': 'no-store', // 不缓存结果 }, } ); } catch (error) { console.error('更新站点配置失败:', error); return NextResponse.json( { error: '更新站点配置失败', details: (error as Error).message, }, { status: 500 } ); } }