diff --git a/src/api/auth.ts b/src/api/auth.ts index a7b4ac7..1a33ab6 100644 --- a/src/api/auth.ts +++ b/src/api/auth.ts @@ -48,8 +48,9 @@ function getHeader(req: IncomingMessage, name: string): string | undefined { */ export function getTokenFromRequest(req: IncomingMessage, headerName: string): string | undefined { const authHeader = getHeader(req, 'authorization'); - if (authHeader?.trim().toLowerCase().startsWith('bearer ')) { - return authHeader.slice(7).trim() || undefined; + const trimmedAuthHeader = authHeader?.trim(); + if (trimmedAuthHeader?.toLowerCase().startsWith('bearer ')) { + return trimmedAuthHeader.slice(7).trim() || undefined; } const value = getHeader(req, headerName); return value?.trim() || undefined; @@ -152,8 +153,9 @@ export function createAuthMiddleware(config?: Partial) { // Get API key: support Authorization: Bearer (MockMCP-style) and configured header const authHeader = ctx.get('authorization'); - const apiKey = authHeader?.trim().toLowerCase().startsWith('bearer ') - ? authHeader.slice(7).trim() + const trimmedAuthHeader = authHeader?.trim(); + const apiKey = trimmedAuthHeader?.toLowerCase().startsWith('bearer ') + ? trimmedAuthHeader.slice(7).trim() : (ctx.get(authConfig.headerName) || '').trim(); if (!apiKey) {