import { headers } from "next/headers"; import { getServerAuthSession } from "@/server/auth"; import requestIp from "request-ip"; import { db } from "@lifetracker/db"; import { Context, createCallerFactory } from "@lifetracker/trpc"; import { authenticateApiKey } from "@lifetracker/trpc/auth"; import { appRouter } from "@lifetracker/trpc/routers/_app"; export async function createContextFromRequest(req: Request) { // TODO: This is a hack until we offer a proper REST API instead of the trpc based one. // Check if the request has an Authorization token, if it does, assume that API key authentication is requested. const ip = requestIp.getClientIp({ headers: Object.fromEntries(req.headers.entries()), }); const authorizationHeader = req.headers.get("Authorization"); if (authorizationHeader && authorizationHeader.startsWith("Bearer ")) { const token = authorizationHeader.split(" ")[1]; try { console.log("\n\nEeeeeeentering hell\n\n"); console.log(await authenticateApiKey(token)); console.log("\n\n\n\n"); const user = await authenticateApiKey(token); return { user, db, req: { ip, }, }; } catch (e) { // Fallthrough to cookie-based auth } } return createContext(db, ip); } export const createContext = async ( database?: typeof db, ip?: string | null, ): Promise => { const session = await getServerAuthSession(); if (ip === undefined) { const hdrs = headers(); ip = requestIp.getClientIp({ headers: Object.fromEntries(hdrs.entries()), }); } return { user: session?.user ?? null, db: database ?? db, req: { ip, }, }; }; const createCaller = createCallerFactory(appRouter); export const api = createCaller(createContext); export const createTrcpClientFromCtx = createCaller;