Files
saladeaula.digital/id.saladeaula.digital/client/app/routes/authorize.ts
2025-09-17 16:51:35 -03:00

56 lines
1.4 KiB
TypeScript

import type { Route } from './+types'
import * as httpStatus from '@/lib/http-status'
import { parse } from 'cookie'
export async function loader({ request, context }: Route.LoaderArgs) {
const cookies = parse(request.headers.get('Cookie') || '')
const url = new URL(request.url)
const redirect = new URL('/', url.origin)
const issuerUrl = new URL('/authorize', context.cloudflare.env.ISSUER_URL)
issuerUrl.search = url.search
redirect.search = url.search
if (!cookies.session_id) {
return new Response(null, {
status: httpStatus.FOUND,
headers: {
Location: redirect.toString()
}
})
}
try {
const r = await fetch(issuerUrl.toString(), {
method: 'GET',
headers: new Headers([
['Content-Type', 'application/json'],
['Cookie', request.headers.get('Cookie') as string]
]),
redirect: 'manual'
})
if (r.status === httpStatus.FOUND) {
return new Response(await r.text(), {
status: r.status,
headers: r.headers
})
}
console.log('Issuer response', {
json: await r.json(),
headers: r.headers,
status: r.status
})
return new Response(null, {
status: httpStatus.FOUND,
headers: {
Location: redirect.toString()
}
})
} catch {
return new Response(null, { status: httpStatus.INTERNAL_SERVER })
}
}