Files
discord-clone/server/api/guilds/[id]/createInvite.post.ts

66 lines
1.5 KiB
TypeScript
Executable File

import { IInviteCode, IServer, SafeUser } from '~/types';
import prisma from '~/server/utils/prisma';
export default defineEventHandler(async (event) => {
if (!event.context.user.authenticated) {
throw createError({
statusCode: 401,
statusMessage: 'You must be logged in to view a channel.',
});
}
if (!event.context.params?.id) {
throw createError({
statusCode: 400,
statusMessage: 'A serverId is required',
});
}
// const body = await readBody(event);
// let expires = false;
// if (body.expiryDate) {
// expires = true;
// body.expiryDate = new Date(body.expiryDate).getUTCDate()
// }
const server = await prisma.server.findFirst({
where: {
id: event.context.params.id
},
include: {
participants: true,
channels: true,
roles: true
}
}) as IServer | null;
if (!server) {
throw createError({
statusCode: 404,
statusMessage: `Server with id "${event.context.params.id}" not found`,
});
}
const userInServerAndPermited: Array<SafeUser> = server.participants.filter((e: SafeUser) => e.id === event.context.user.id && e.roles?.some((el) => el.administer === true || el.owner === false));
if (!userInServerAndPermited) {
throw createError({
statusCode: 401,
statusMessage: 'You must be in the server or an admin/owner of that server to make an invite code',
});
}
const inviteCode = await prisma.inviteCode.create({
data: {
server: {
connect: {
id: server.id
}
},
maxUses: 0
}
}) as IInviteCode;
return inviteCode;
});