mirror of
https://github.com/Drop-OSS/drop.git
synced 2025-11-11 04:52:06 +10:00
36 lines
941 B
TypeScript
36 lines
941 B
TypeScript
import clientHandler from "~/server/internal/clients/handler";
|
|
import sessionHandler from "~/server/internal/session";
|
|
|
|
export default defineEventHandler(async (h3) => {
|
|
const user = await sessionHandler.getSession(h3);
|
|
if (!user) throw createError({ statusCode: 403 });
|
|
|
|
const body = await readBody(h3);
|
|
const clientId = await body.id;
|
|
|
|
const client = await clientHandler.fetchClient(clientId);
|
|
if (!client)
|
|
throw createError({
|
|
statusCode: 400,
|
|
message: "Invalid or expired client ID.",
|
|
});
|
|
|
|
if (client.userId != user.userId)
|
|
throw createError({
|
|
statusCode: 403,
|
|
message: "Not allowed to authorize this client.",
|
|
});
|
|
|
|
if (!client.peer)
|
|
throw createError({
|
|
statusCode: 500,
|
|
message: "No client listening for authorization.",
|
|
});
|
|
|
|
const token = await clientHandler.generateAuthToken(clientId);
|
|
|
|
await clientHandler.sendAuthToken(clientId, token);
|
|
|
|
return;
|
|
});
|