2024-10-07 12:52:22 +02:00
|
|
|
import { auth } from "@/api";
|
|
|
|
|
import { createRoute, z } from "@hono/zod-openapi";
|
|
|
|
|
import { exportJWK } from "jose";
|
|
|
|
|
import type { PluginType } from "../index.ts";
|
|
|
|
|
|
2024-11-02 00:43:33 +01:00
|
|
|
export default (plugin: PluginType): void => {
|
2024-10-07 12:52:22 +02:00
|
|
|
plugin.registerRoute("/.well-known/jwks", (app) =>
|
|
|
|
|
app.openapi(
|
|
|
|
|
createRoute({
|
|
|
|
|
method: "get",
|
|
|
|
|
path: "/.well-known/jwks",
|
|
|
|
|
summary: "JWK Set",
|
|
|
|
|
responses: {
|
|
|
|
|
200: {
|
|
|
|
|
description: "JWK Set",
|
|
|
|
|
content: {
|
|
|
|
|
"application/json": {
|
|
|
|
|
schema: z.object({
|
|
|
|
|
keys: z.array(
|
|
|
|
|
z.object({
|
|
|
|
|
kty: z.string(),
|
|
|
|
|
use: z.string(),
|
|
|
|
|
alg: z.string(),
|
|
|
|
|
kid: z.string(),
|
|
|
|
|
crv: z.string().optional(),
|
|
|
|
|
x: z.string().optional(),
|
|
|
|
|
y: z.string().optional(),
|
|
|
|
|
}),
|
|
|
|
|
),
|
|
|
|
|
}),
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
middleware: [
|
|
|
|
|
auth({
|
|
|
|
|
required: false,
|
|
|
|
|
}),
|
2024-10-11 17:16:03 +02:00
|
|
|
plugin.middleware,
|
2024-12-30 18:20:22 +01:00
|
|
|
] as const,
|
2024-10-07 12:52:22 +02:00
|
|
|
}),
|
|
|
|
|
async (context) => {
|
|
|
|
|
const jwk = await exportJWK(
|
|
|
|
|
context.get("pluginConfig").keys?.public,
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
// Remove the private key 💀
|
|
|
|
|
jwk.d = undefined;
|
|
|
|
|
|
|
|
|
|
return context.json(
|
|
|
|
|
{
|
|
|
|
|
keys: [
|
|
|
|
|
{
|
|
|
|
|
...jwk,
|
|
|
|
|
use: "sig",
|
|
|
|
|
alg: "EdDSA",
|
|
|
|
|
kid: "1",
|
|
|
|
|
},
|
|
|
|
|
],
|
|
|
|
|
},
|
|
|
|
|
200,
|
|
|
|
|
);
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
);
|
|
|
|
|
};
|