@decocms/runtime 1.0.0-alpha.27 → 1.0.0-alpha.28
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/src/index.ts +12 -1
package/package.json
CHANGED
package/src/index.ts
CHANGED
|
@@ -310,7 +310,18 @@ export const withRuntime = <TEnv, TSchema extends z.ZodTypeAny = never>(
|
|
|
310
310
|
if (url.pathname === "/mcp") {
|
|
311
311
|
// If OAuth is configured, require authentication
|
|
312
312
|
if (oauthHandlers && !oauthHandlers.hasAuth(req)) {
|
|
313
|
-
|
|
313
|
+
// Clone request to check method without consuming the original body
|
|
314
|
+
const clonedReq = req.clone();
|
|
315
|
+
try {
|
|
316
|
+
const body = (await clonedReq.json()) as { method?: string };
|
|
317
|
+
// Allow tools/list to pass without auth
|
|
318
|
+
if (body?.method !== "tools/list") {
|
|
319
|
+
return oauthHandlers.createUnauthorizedResponse(req);
|
|
320
|
+
}
|
|
321
|
+
} catch {
|
|
322
|
+
// If body parsing fails, require auth
|
|
323
|
+
return oauthHandlers.createUnauthorizedResponse(req);
|
|
324
|
+
}
|
|
314
325
|
}
|
|
315
326
|
|
|
316
327
|
return server.fetch(req, env, ctx);
|