67 lines
2.3 KiB
TypeScript

import type { RequestHandler } from '@sveltejs/kit';
import { setBeatLeaderSessionFromSetCookieHeaders } from '$lib/server/beatleaderAuth';
/**
* POST /auth/beatleader/steam-ticket
* Body: { ticket: string } or form-data ticket=...
*
* Mirrors BeatLeader mod auth flow by forwarding the Steam session ticket
* to BeatLeader /signin with provider=steamTicket, capturing BL website cookies.
*/
export const POST: RequestHandler = async ({ request, cookies, fetch }) => {
try {
const contentType = request.headers.get('content-type') || '';
let ticket = '';
if (contentType.includes('application/json')) {
const body = await request.json();
ticket = String((body as any)?.ticket ?? '').trim();
} else {
const form = await request.formData();
ticket = String(form.get('ticket') ?? '').trim();
}
if (!ticket) {
return new Response(JSON.stringify({ error: 'Missing ticket' }), {
status: 400,
headers: { 'content-type': 'application/json' }
});
}
const form = new FormData();
form.set('ticket', ticket);
form.set('provider', 'steamTicket');
form.set('returnUrl', '/');
const res = await fetch('https://api.beatleader.com/signin', {
method: 'POST',
body: form,
redirect: 'manual'
});
// Capture BL session cookies regardless of status
try {
const setCookieHeaders = (res.headers as any).getSetCookie?.() ?? res.headers.get('set-cookie')?.split(',') ?? [];
setBeatLeaderSessionFromSetCookieHeaders(cookies, Array.isArray(setCookieHeaders) ? setCookieHeaders : [setCookieHeaders]);
} catch {}
const ok = res.status >= 200 && res.status < 400;
if (!ok) {
const text = await res.text().catch(() => '');
return new Response(JSON.stringify({ error: `BeatLeader signin failed (${res.status})`, details: text }), {
status: 400,
headers: { 'content-type': 'application/json' }
});
}
return new Response(JSON.stringify({ ok: true }), { headers: { 'content-type': 'application/json' } });
} catch (err) {
const message = err instanceof Error ? err.message : 'Unknown error';
return new Response(JSON.stringify({ error: message }), {
status: 500,
headers: { 'content-type': 'application/json' }
});
}
};