mirror of
https://github.com/kmc7468/arkvault.git
synced 2025-12-16 15:08:46 +00:00
/api/auth/logout, /api/auth/refreshToken Endpoint 구현
This commit is contained in:
@@ -1,6 +1,6 @@
|
||||
import { error, json } from "@sveltejs/kit";
|
||||
import { z } from "zod";
|
||||
import { login } from "$lib/server/auth";
|
||||
import { login } from "$lib/server/services/auth";
|
||||
import type { RequestHandler } from "./$types";
|
||||
|
||||
export const POST: RequestHandler = async ({ request }) => {
|
||||
@@ -14,9 +14,5 @@ export const POST: RequestHandler = async ({ request }) => {
|
||||
if (!zodRes.success) error(400, zodRes.error.message);
|
||||
|
||||
const { email, password, pubKey } = zodRes.data;
|
||||
const loginRes = await login(email.trim(), password.trim(), pubKey?.trim());
|
||||
if (!loginRes) error(401, "Invalid email, password, or public key");
|
||||
|
||||
const { accessToken, refreshToken } = loginRes;
|
||||
return json({ accessToken, refreshToken });
|
||||
return json(await login(email.trim(), password.trim(), pubKey?.trim()));
|
||||
};
|
||||
|
||||
18
src/routes/api/auth/logout/+server.ts
Normal file
18
src/routes/api/auth/logout/+server.ts
Normal file
@@ -0,0 +1,18 @@
|
||||
import { error, text } from "@sveltejs/kit";
|
||||
import { z } from "zod";
|
||||
import { logout } from "$lib/server/services/auth";
|
||||
import type { RequestHandler } from "./$types";
|
||||
|
||||
export const POST: RequestHandler = async ({ request }) => {
|
||||
const zodRes = z
|
||||
.object({
|
||||
refreshToken: z.string().nonempty(),
|
||||
})
|
||||
.safeParse(await request.json());
|
||||
if (!zodRes.success) error(400, zodRes.error.message);
|
||||
|
||||
const { refreshToken } = zodRes.data;
|
||||
await logout(refreshToken.trim());
|
||||
|
||||
return text("Logged out");
|
||||
};
|
||||
16
src/routes/api/auth/refreshToken/+server.ts
Normal file
16
src/routes/api/auth/refreshToken/+server.ts
Normal file
@@ -0,0 +1,16 @@
|
||||
import { error, json } from "@sveltejs/kit";
|
||||
import { z } from "zod";
|
||||
import { refreshToken } from "$lib/server/services/auth";
|
||||
import type { RequestHandler } from "./$types";
|
||||
|
||||
export const POST: RequestHandler = async ({ request }) => {
|
||||
const zodRes = z
|
||||
.object({
|
||||
refreshToken: z.string().nonempty(),
|
||||
})
|
||||
.safeParse(await request.json());
|
||||
if (!zodRes.success) error(400, zodRes.error.message);
|
||||
|
||||
const { refreshToken: token } = zodRes.data;
|
||||
return json(await refreshToken(token.trim()));
|
||||
};
|
||||
Reference in New Issue
Block a user