umami/pages/api/teams/join.ts

50 lines
1.2 KiB
TypeScript
Raw Normal View History

2023-02-02 02:39:54 +00:00
import { Team } from '@prisma/client';
2023-08-20 05:23:15 +00:00
import { ROLES } from 'lib/constants';
import { useAuth, useValidate } from 'lib/middleware';
2023-02-02 02:39:54 +00:00
import { NextApiRequestQueryBody } from 'lib/types';
import { NextApiResponse } from 'next';
2023-08-20 05:23:15 +00:00
import { methodNotAllowed, notFound, ok } from 'next-basics';
2023-07-30 05:03:34 +00:00
import { createTeamUser, getTeamByAccessCode, getTeamUser } from 'queries';
2023-08-20 05:23:15 +00:00
import * as yup from 'yup';
export interface TeamsJoinRequestBody {
2023-02-02 02:39:54 +00:00
accessCode: string;
}
2023-08-20 05:23:15 +00:00
const schema = {
POST: yup.object().shape({
accessCode: yup.string().max(50).required(),
}),
};
2023-02-02 02:39:54 +00:00
export default async (
req: NextApiRequestQueryBody<any, TeamsJoinRequestBody>,
res: NextApiResponse<Team>,
2023-02-02 02:39:54 +00:00
) => {
await useAuth(req, res);
2023-08-20 05:23:15 +00:00
req.yup = schema;
await useValidate(req, res);
2023-02-02 02:39:54 +00:00
if (req.method === 'POST') {
const { accessCode } = req.body;
2023-07-30 05:03:34 +00:00
const team = await getTeamByAccessCode(accessCode);
2023-02-02 02:39:54 +00:00
if (!team) {
return notFound(res, 'message.team-not-found');
}
const teamUser = await getTeamUser(team.id, req.auth.user.id);
if (teamUser) {
return methodNotAllowed(res, 'message.team-already-member');
}
2023-02-02 02:39:54 +00:00
await createTeamUser(req.auth.user.id, team.id, ROLES.teamMember);
return ok(res, team);
}
return methodNotAllowed(res);
};