Files
multiverse/jumpa-chat/app/api/guest/knock/route.ts
T

38 lines
1.3 KiB
TypeScript

// [TSM.ID].[11031972] -- All Rights Reserved. Proprietary & Confidential.
import { NextResponse } from 'next/server';
import { Pool } from 'pg';
const pool = new Pool({
connectionString: process.env.DATABASE_URL || 'postgresql://jumpa_admin:JumpaS3cur3%21%40%23@127.0.0.1:5432/jumpadb',
});
export async function POST(req: Request) {
try {
const { room, pin, name } = await req.json();
if (!room || !pin || !name) {
return NextResponse.json({ error: 'Data tidak lengkap' }, { status: 400 });
}
// Cari tiket PIN yang belum dipakai dan belum expired (kita anggap belum expired kalau ada)
const result = await pool.query(
'SELECT id FROM guest_invites WHERE room = $1 AND pin = $2 AND is_used = false',
[room, pin]
);
if (result.rows.length === 0) {
return NextResponse.json({ error: 'PIN tidak valid atau sudah digunakan.' }, { status: 401 });
}
const pinId = result.rows[0].id;
// PIN Valid! Kita kembalikan success.
// WebSocket di client akan mengirim sinyal 'guest_knock' setelah ini
return NextResponse.json({ success: true, pinId }, { status: 200 });
} catch (error) {
console.error('[API GUEST KNOCK ERROR]', error);
return NextResponse.json({ error: 'Internal Server Error' }, { status: 500 });
}
}