fix: add /.well-known/indieauth-metadata as public route
Deploy Indiekit Server / deploy (push) Successful in 1m14s

endpoint-auth never registered this well-known path, so requests fell
through to indieauth.authenticate() and got 302 → /session/login.
Adds a patch script that inserts the route into routesWellKnown,
making the endpoint publicly accessible without authentication.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
Sven
2026-04-28 17:42:11 +02:00
parent cc843d34c5
commit 38a235c129
@@ -0,0 +1,39 @@
/**
* Add /.well-known/indieauth-metadata as a public route.
*
* endpoint-auth registers /auth/metadata (authenticated) and
* /.well-known/oauth-authorization-server (patched away by patch-mastodon-well-known),
* but never /.well-known/indieauth-metadata. Without an explicit registration
* the request falls through to indieauth.authenticate() and redirects to login.
*/
import { readFileSync, writeFileSync } from "node:fs";
import { fileURLToPath } from "node:url";
import { join, dirname } from "node:path";
const __dirname = dirname(fileURLToPath(import.meta.url));
const pkg = join(__dirname, "../node_modules/@indiekit/endpoint-auth/index.js");
let src = readFileSync(pkg, "utf-8");
const MARKER = "// patch-indieauth-metadata-well-known: added";
if (src.includes(MARKER)) {
console.log("[patch-indieauth-metadata-well-known] Already applied");
process.exit(0);
}
const OLD = ` router.get("/change-password", (request, response) =>
response.redirect(\`\${this.mountPath}/new-password\`),
);`;
const NEW = ` router.get("/change-password", (request, response) =>
response.redirect(\`\${this.mountPath}/new-password\`),
);
router.get("/indieauth-metadata", metadataController); ${MARKER}`;
if (!src.includes(OLD)) {
console.error("[patch-indieauth-metadata-well-known] Target line not found — check endpoint-auth version");
process.exit(1);
}
src = src.replace(OLD, NEW);
writeFileSync(pkg, src, "utf-8");
console.log("[patch-indieauth-metadata-well-known] Added /.well-known/indieauth-metadata public route");