import type { DashboardKisRevokeResponse } from "@/features/trade/types/trade.types"; import { normalizeTradingEnv } from "@/lib/kis/config"; import { parseKisCredentialRequest, validateKisCredentialInput, } from "@/lib/kis/request"; import { revokeKisAccessToken } from "@/lib/kis/token"; import { hasKisApiSession } from "@/app/api/kis/_session"; import { NextRequest, NextResponse } from "next/server"; /** * @file app/api/kis/revoke/route.ts * @description 사용자 입력 KIS API 키로 액세스 토큰을 폐기합니다. */ /** * @description KIS 액세스 토큰 폐기 * @see features/settings/components/KisAuthForm.tsx */ export async function POST(request: NextRequest) { const credentials = await parseKisCredentialRequest(request); const tradingEnv = normalizeTradingEnv(credentials.tradingEnv); const hasSession = await hasKisApiSession(); if (!hasSession) { return NextResponse.json( { ok: false, tradingEnv, message: "로그인이 필요합니다.", } satisfies DashboardKisRevokeResponse, { status: 401 }, ); } const invalidMessage = validateKisCredentialInput(credentials); if (invalidMessage) { return NextResponse.json( { ok: false, tradingEnv, message: invalidMessage, } satisfies DashboardKisRevokeResponse, { status: 400 }, ); } try { const message = await revokeKisAccessToken(credentials); return NextResponse.json({ ok: true, tradingEnv, message, } satisfies DashboardKisRevokeResponse); } catch (error) { const message = error instanceof Error ? error.message : "API 토큰 폐기 중 오류가 발생했습니다."; return NextResponse.json( { ok: false, tradingEnv, message, } satisfies DashboardKisRevokeResponse, { status: 401 }, ); } }