mirror of
https://github.com/kmc7468/arkvault.git
synced 2025-12-14 22:08:45 +00:00
34 lines
1.1 KiB
TypeScript
34 lines
1.1 KiB
TypeScript
import { error, text } from "@sveltejs/kit";
|
|
import env from "$lib/server/loadenv";
|
|
import { tokenUpgradeVerifyRequest } from "$lib/server/schemas";
|
|
import { upgradeToken } from "$lib/server/services/auth";
|
|
import type { RequestHandler } from "./$types";
|
|
|
|
export const POST: RequestHandler = async ({ request, cookies, getClientAddress }) => {
|
|
const token = cookies.get("refreshToken");
|
|
if (!token) error(401, "Refresh token not found");
|
|
|
|
const zodRes = tokenUpgradeVerifyRequest.safeParse(await request.json());
|
|
if (!zodRes.success) error(400, "Invalid request body");
|
|
const { answer, answerSig } = zodRes.data;
|
|
|
|
const { accessToken, refreshToken } = await upgradeToken(
|
|
token,
|
|
getClientAddress(),
|
|
answer,
|
|
answerSig,
|
|
);
|
|
cookies.set("accessToken", accessToken, {
|
|
path: "/",
|
|
maxAge: env.jwt.accessExp / 1000,
|
|
sameSite: "strict",
|
|
});
|
|
cookies.set("refreshToken", refreshToken, {
|
|
path: "/api/auth",
|
|
maxAge: env.jwt.refreshExp / 1000,
|
|
sameSite: "strict",
|
|
});
|
|
|
|
return text("Token upgraded", { headers: { "Content-Type": "text/plain" } });
|
|
};
|