import type { DashboardKisRevokeResponse } from "@/features/dashboard/types/dashboard.types"; import type { KisCredentialInput } from "@/lib/kis/config"; import { hasKisConfig, normalizeTradingEnv } from "@/lib/kis/config"; import { revokeKisAccessToken } from "@/lib/kis/token"; import { NextRequest, NextResponse } from "next/server"; /** * @file app/api/kis/revoke/route.ts * @description 사용자 입력 KIS API 키 기반 접근토큰 폐기 라우트 */ /** * KIS API 접근토큰 폐기 * @param request appKey/appSecret/tradingEnv JSON 본문 * @returns 폐기 성공/실패 정보 * @see features/dashboard/components/dashboard-main.tsx handleRevokeKis - 접근 폐기 버튼 클릭 이벤트 */ export async function POST(request: NextRequest) { const body = (await request.json()) as Partial; const credentials: KisCredentialInput = { appKey: body.appKey?.trim(), appSecret: body.appSecret?.trim(), tradingEnv: normalizeTradingEnv(body.tradingEnv), }; if (!hasKisConfig(credentials)) { return NextResponse.json( { ok: false, tradingEnv: normalizeTradingEnv(credentials.tradingEnv), message: "앱 키와 앱 시크릿을 모두 입력해 주세요.", } satisfies DashboardKisRevokeResponse, { status: 400 }, ); } try { const message = await revokeKisAccessToken(credentials); return NextResponse.json({ ok: true, tradingEnv: normalizeTradingEnv(credentials.tradingEnv), message, } satisfies DashboardKisRevokeResponse); } catch (error) { const message = error instanceof Error ? error.message : "API 키 접근 폐기 중 오류가 발생했습니다."; return NextResponse.json( { ok: false, tradingEnv: normalizeTradingEnv(credentials.tradingEnv), message, } satisfies DashboardKisRevokeResponse, { status: 401 }, ); } } interface DashboardKisRevokeRequest { appKey: string; appSecret: string; tradingEnv: "real" | "mock"; }