New API + API Token Updates

This commit is contained in:
2026-01-16 13:20:11 -07:00
parent 756ab2a38f
commit 4412229990
26 changed files with 1661 additions and 1012 deletions

View File

@@ -1,12 +1,27 @@
import { defineMiddleware } from 'astro/middleware';
import { validateSession } from './lib/auth';
import { defineMiddleware } from "astro/middleware";
import { validateSession } from "./lib/auth";
import { validateApiToken } from "./lib/api-auth";
export const onRequest = defineMiddleware(async (context, next) => {
const sessionId = context.cookies.get('session_id')?.value;
const authHeader = context.request.headers.get("Authorization");
if (authHeader?.startsWith("Bearer ")) {
const token = authHeader.substring(7);
const result = await validateApiToken(token);
if (result) {
context.locals.user = result.user;
context.locals.session = null;
context.locals.scopes = result.scopes;
return next();
}
}
const sessionId = context.cookies.get("session_id")?.value;
if (!sessionId) {
context.locals.user = null;
context.locals.session = null;
context.locals.scopes = null;
return next();
}
@@ -15,10 +30,12 @@ export const onRequest = defineMiddleware(async (context, next) => {
if (result) {
context.locals.user = result.user;
context.locals.session = result.session;
context.locals.scopes = null;
} else {
context.locals.user = null;
context.locals.session = null;
context.cookies.delete('session_id');
context.locals.scopes = null;
context.cookies.delete("session_id");
}
return next();