diff options
| author | Pinapelz <yukais@pinapelz.com> | 2025-11-07 22:46:34 -0800 |
|---|---|---|
| committer | Pinapelz <yukais@pinapelz.com> | 2025-11-07 22:46:34 -0800 |
| commit | 91c737c907f174b5252877876126a8b81e6cb831 (patch) | |
| tree | 2529ded98423308a15d96256dc0f1688f12b69c8 /backend/src/routes/auth.ts | |
| parent | 5963d4904cb6e4abe1b379e85a8a29cf03ade6a8 (diff) | |
add support to limit registration to invite codes
Diffstat (limited to 'backend/src/routes/auth.ts')
| -rw-r--r-- | backend/src/routes/auth.ts | 22 |
1 files changed, 21 insertions, 1 deletions
diff --git a/backend/src/routes/auth.ts b/backend/src/routes/auth.ts index f857dea..8bc6274 100644 --- a/backend/src/routes/auth.ts +++ b/backend/src/routes/auth.ts @@ -6,12 +6,24 @@ import crypto from 'crypto'; export const handleRegistration = async (req: express.Request, res: express.Response) => { try { - const { username, password, email } = req.body; + const { username, password, email, code: inviteCode } = req.body; + const requireInvite = process.env.REQUIRE_INVITE === 'true'; if (!username || !password || !email) { return res.status(400).json({ error: 'All fields are required' }); } + if (requireInvite && !inviteCode) { + return res.status(400).json({ error: 'Invite code is required' }); + } + + if (requireInvite && inviteCode) { + const invite = await prisma.inviteCodes.findUnique({ where: { code: inviteCode } }); + if (!invite || invite.remaining <= 0) { + return res.status(400).json({ error: 'Invalid invite code' }); + } + } + const existingUser = await prisma.user.findFirst({ where: { OR: [ @@ -38,6 +50,14 @@ export const handleRegistration = async (req: express.Request, res: express.Resp } }); + // Decrement invite code usage if required + if (requireInvite && inviteCode) { + await prisma.inviteCodes.update({ + where: { code: inviteCode }, + data: { remaining: { decrement: 1 } } + }); + } + // Create session for the new user req.session.userId = user.id; const sessionId = await createSession(user.id); |
