@opendatalabs/personal-server-ts-server 0.0.1-canary.93bdda2 → 0.0.1-canary.97dbbed
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/dist/app.d.ts.map +1 -1
- package/dist/app.js +1 -33
- package/dist/app.js.map +1 -1
- package/dist/tunnel/manager.js +1 -1
- package/dist/tunnel/manager.js.map +1 -1
- package/dist/tunnel/verify.d.ts +1 -1
- package/dist/tunnel/verify.d.ts.map +1 -1
- package/dist/tunnel/verify.js +8 -2
- package/dist/tunnel/verify.js.map +1 -1
- package/package.json +2 -4
- package/dist/oauth/provider.d.ts +0 -55
- package/dist/oauth/provider.d.ts.map +0 -1
- package/dist/oauth/provider.js +0 -160
- package/dist/oauth/provider.js.map +0 -1
- package/dist/oauth/routes.d.ts +0 -10
- package/dist/oauth/routes.d.ts.map +0 -1
- package/dist/oauth/routes.js +0 -206
- package/dist/oauth/routes.js.map +0 -1
- package/dist/routes/mcp.d.ts +0 -10
- package/dist/routes/mcp.d.ts.map +0 -1
- package/dist/routes/mcp.js +0 -60
- package/dist/routes/mcp.js.map +0 -1
package/dist/app.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"app.d.ts","sourceRoot":"","sources":["../src/app.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAG5B,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,qDAAqD,CAAC;AACxF,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,yDAAyD,CAAC;AACvG,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,+CAA+C,CAAC;AACnF,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,0DAA0D,CAAC;AAChG,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,6DAA6D,CAAC;AACnG,OAAO,EAAe,KAAK,UAAU,EAAE,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"app.d.ts","sourceRoot":"","sources":["../src/app.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAG5B,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,qDAAqD,CAAC;AACxF,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,yDAAyD,CAAC;AACvG,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,+CAA+C,CAAC;AACnF,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,0DAA0D,CAAC;AAChG,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,6DAA6D,CAAC;AACnG,OAAO,EAAe,KAAK,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAOlE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,4CAA4C,CAAC;AAC9E,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,+CAA+C,CAAC;AAClF,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAEnC,MAAM,WAAW,YAAY;IAC3B,OAAO,EAAE,KAAK,MAAM,EAAE,CAAC;IACvB,SAAS,EAAE,KAAK,MAAM,EAAE,CAAC;IACzB,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;CACzB;AAED,MAAM,WAAW,OAAO;IACtB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,IAAI,CAAC;IAChB,YAAY,EAAE,YAAY,CAAC;IAC3B,gBAAgB,EAAE,uBAAuB,CAAC;IAC1C,YAAY,EAAE,MAAM,GAAG,CAAC,MAAM,MAAM,CAAC,CAAC;IACtC,WAAW,CAAC,EAAE,KAAK,MAAM,EAAE,CAAC;IAC5B,QAAQ,CAAC,EAAE,YAAY,CAAC;IACxB,OAAO,EAAE,aAAa,CAAC;IACvB,eAAe,EAAE,eAAe,CAAC;IACjC,eAAe,EAAE,eAAe,CAAC;IACjC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,WAAW,CAAC,EAAE,WAAW,GAAG,IAAI,CAAC;IACjC,YAAY,CAAC,EAAE,YAAY,CAAC;IAC5B,eAAe,CAAC,EAAE,UAAU,CAAC,iBAAiB,CAAC,CAAC;CACjD;AAED,wBAAgB,SAAS,CAAC,IAAI,EAAE,OAAO,GAAG,IAAI,CAmI7C"}
|
package/dist/app.js
CHANGED
|
@@ -8,22 +8,12 @@ import { accessLogsRoutes } from "./routes/access-logs.js";
|
|
|
8
8
|
import { syncRoutes } from "./routes/sync.js";
|
|
9
9
|
import { uiConfigRoutes } from "./routes/ui-config.js";
|
|
10
10
|
import { uiRoute } from "./routes/ui.js";
|
|
11
|
-
import { mcpRoute } from "./routes/mcp.js";
|
|
12
|
-
import { OAuthProvider } from "./oauth/provider.js";
|
|
13
|
-
import { oauthRoutes } from "./oauth/routes.js";
|
|
14
11
|
export function createApp(deps) {
|
|
15
12
|
const app = new Hono();
|
|
16
13
|
// CORS — allow all origins for browser-based clients
|
|
17
14
|
app.use("*", cors({
|
|
18
15
|
origin: "*",
|
|
19
|
-
allowHeaders: [
|
|
20
|
-
"Content-Type",
|
|
21
|
-
"Authorization",
|
|
22
|
-
"mcp-session-id",
|
|
23
|
-
"Last-Event-ID",
|
|
24
|
-
"mcp-protocol-version",
|
|
25
|
-
],
|
|
26
|
-
exposeHeaders: ["mcp-session-id", "mcp-protocol-version"],
|
|
16
|
+
allowHeaders: ["Content-Type", "Authorization"],
|
|
27
17
|
allowMethods: ["GET", "POST", "PUT", "DELETE", "OPTIONS"],
|
|
28
18
|
maxAge: 86400,
|
|
29
19
|
}));
|
|
@@ -74,28 +64,6 @@ export function createApp(deps) {
|
|
|
74
64
|
devToken: deps.devToken,
|
|
75
65
|
syncManager: deps.syncManager ?? null,
|
|
76
66
|
}));
|
|
77
|
-
// Mount MCP endpoint (Model Context Protocol for AI tools)
|
|
78
|
-
if (deps.serverOwner) {
|
|
79
|
-
const oauthProvider = new OAuthProvider(deps.serverOwner);
|
|
80
|
-
// Mount OAuth discovery + auth endpoints at the root
|
|
81
|
-
app.route("/", oauthRoutes({
|
|
82
|
-
oauthProvider,
|
|
83
|
-
serverOwner: deps.serverOwner,
|
|
84
|
-
accountPortalOrigin: process.env.ACCOUNT_URL,
|
|
85
|
-
serverOrigin: deps.serverOrigin,
|
|
86
|
-
}));
|
|
87
|
-
app.route("/mcp", mcpRoute({
|
|
88
|
-
mcpContext: {
|
|
89
|
-
indexManager: deps.indexManager,
|
|
90
|
-
hierarchyOptions: deps.hierarchyOptions,
|
|
91
|
-
gatewayClient: deps.gateway,
|
|
92
|
-
serverOwner: deps.serverOwner,
|
|
93
|
-
logger: deps.logger,
|
|
94
|
-
},
|
|
95
|
-
oauthProvider,
|
|
96
|
-
serverOrigin: deps.serverOrigin,
|
|
97
|
-
}));
|
|
98
|
-
}
|
|
99
67
|
// Mount dev UI routes when dev token is available
|
|
100
68
|
if (deps.devToken) {
|
|
101
69
|
app.route("/ui", uiRoute({ devToken: deps.devToken }));
|
package/dist/app.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"app.js","sourceRoot":"","sources":["../src/app.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAC5B,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,aAAa,EAAE,MAAM,8CAA8C,CAAC;AAM7E,OAAO,EAAE,WAAW,EAAmB,MAAM,oBAAoB,CAAC;AAClE,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAC3D,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"app.js","sourceRoot":"","sources":["../src/app.ts"],"names":[],"mappings":"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"}
|
package/dist/tunnel/manager.js
CHANGED
|
@@ -58,7 +58,7 @@ export class TunnelManager {
|
|
|
58
58
|
}
|
|
59
59
|
}
|
|
60
60
|
const subdomain = config.walletAddress.toLowerCase();
|
|
61
|
-
this.publicUrl = buildTunnelUrl(subdomain);
|
|
61
|
+
this.publicUrl = buildTunnelUrl(subdomain, config.serverAddr);
|
|
62
62
|
const configPath = await this.writeFreshConfig(subdomain);
|
|
63
63
|
await this.spawnProcess(configPath);
|
|
64
64
|
this.scheduleRefresh();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"manager.js","sourceRoot":"","sources":["../../src/tunnel/manager.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,EAAE,KAAK,EAAqB,MAAM,oBAAoB,CAAC;AAC9D,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC9E,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAEjC,OAAO,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAC;AACnE,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AA2B7C,2DAA2D;AAC3D,MAAM,mBAAmB,GAAG,iBAAiB,GAAG,GAAG,GAAG,IAAI,CAAC;AAE3D,mDAAmD;AACnD,MAAM,gBAAgB,GAAG,MAAM,CAAC;AAEhC,MAAM,OAAO,aAAa;IAChB,WAAW,CAAS;IACpB,OAAO,GAAwB,IAAI,CAAC;IACpC,MAAM,GAAiB,SAAS,CAAC;IACjC,SAAS,GAAkB,IAAI,CAAC;IAChC,cAAc,GAAgB,IAAI,CAAC;IACnC,SAAS,GAAkB,IAAI,CAAC;IAChC,MAAM,GAAwB,IAAI,CAAC;IACnC,UAAU,GAAkB,IAAI,CAAC;IACjC,YAAY,GAAyC,IAAI,CAAC;IAC1D,UAAU,GAAG,KAAK,CAAC;IAE3B,YAAY,WAAmB;QAC7B,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;IACjC,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,KAAK,CAAC,MAAoB,EAAE,UAAkB;QAClD,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;QAC5C,CAAC;QAED,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,MAAM,GAAG,UAAU,CAAC;QACzB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QAEtB,yCAAyC;QACzC,IAAI,CAAC;YACH,MAAM,MAAM,CAAC,UAAU,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC;QAC3C,CAAC;QAAC,MAAM,CAAC;YACP,IAAI,CAAC;gBACH,MAAM,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC;YACjC,CAAC;YAAC,MAAM,CAAC;gBACP,MAAM,IAAI,KAAK,CACb,4CAA4C,UAAU,EAAE,CACzD,CAAC;YACJ,CAAC;QACH,CAAC;QAED,MAAM,SAAS,GAAG,MAAM,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC;QACrD,IAAI,CAAC,SAAS,GAAG,cAAc,CAAC,SAAS,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"manager.js","sourceRoot":"","sources":["../../src/tunnel/manager.ts"],"names":[],"mappings":"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"}
|
package/dist/tunnel/verify.d.ts
CHANGED
|
@@ -19,7 +19,7 @@ export interface VerifyTunnelResult {
|
|
|
19
19
|
/**
|
|
20
20
|
* Build the canonical tunnel URL for a wallet address.
|
|
21
21
|
*/
|
|
22
|
-
export declare function buildTunnelUrl(walletAddress: string): string;
|
|
22
|
+
export declare function buildTunnelUrl(walletAddress: string, serverAddr?: string): string;
|
|
23
23
|
/**
|
|
24
24
|
* Verify that a tunnel URL is reachable by hitting its /health endpoint.
|
|
25
25
|
* Retries on failure with configurable attempts, delay, and timeout.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"verify.d.ts","sourceRoot":"","sources":["../../src/tunnel/verify.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,MAAM,WAAW,mBAAmB;IAClC,8CAA8C;IAC9C,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,kDAAkD;IAClD,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,gDAAgD;IAChD,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,gDAAgD;IAChD,OAAO,CAAC,EAAE,OAAO,KAAK,CAAC;CACxB;AAED,MAAM,WAAW,kBAAkB;IACjC,SAAS,EAAE,OAAO,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;
|
|
1
|
+
{"version":3,"file":"verify.d.ts","sourceRoot":"","sources":["../../src/tunnel/verify.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,MAAM,WAAW,mBAAmB;IAClC,8CAA8C;IAC9C,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,kDAAkD;IAClD,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,gDAAgD;IAChD,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,gDAAgD;IAChD,OAAO,CAAC,EAAE,OAAO,KAAK,CAAC;CACxB;AAED,MAAM,WAAW,kBAAkB;IACjC,SAAS,EAAE,OAAO,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AASD;;GAEG;AACH,wBAAgB,cAAc,CAC5B,aAAa,EAAE,MAAM,EACrB,UAAU,CAAC,EAAE,MAAM,GAClB,MAAM,CAIR;AAED;;;GAGG;AACH,wBAAsB,eAAe,CACnC,SAAS,EAAE,MAAM,EACjB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,OAAO,CAAC,kBAAkB,CAAC,CA4B7B"}
|
package/dist/tunnel/verify.js
CHANGED
|
@@ -1,11 +1,17 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Tunnel URL helpers: build the canonical tunnel URL and verify reachability.
|
|
3
3
|
*/
|
|
4
|
+
const ALLOWED_SERVER_ADDRS = {
|
|
5
|
+
"frpc.server.vana.org": "server.vana.org",
|
|
6
|
+
"frpc.server-dev.vana.org": "server-dev.vana.org",
|
|
7
|
+
};
|
|
8
|
+
const DEFAULT_DOMAIN = "server.vana.org";
|
|
4
9
|
/**
|
|
5
10
|
* Build the canonical tunnel URL for a wallet address.
|
|
6
11
|
*/
|
|
7
|
-
export function buildTunnelUrl(walletAddress) {
|
|
8
|
-
|
|
12
|
+
export function buildTunnelUrl(walletAddress, serverAddr) {
|
|
13
|
+
const domain = (serverAddr && ALLOWED_SERVER_ADDRS[serverAddr]) || DEFAULT_DOMAIN;
|
|
14
|
+
return `https://${walletAddress.toLowerCase()}.${domain}`;
|
|
9
15
|
}
|
|
10
16
|
/**
|
|
11
17
|
* Verify that a tunnel URL is reachable by hitting its /health endpoint.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"verify.js","sourceRoot":"","sources":["../../src/tunnel/verify.ts"],"names":[],"mappings":"AAAA;;GAEG;AAmBH;;GAEG;AACH,MAAM,UAAU,cAAc,
|
|
1
|
+
{"version":3,"file":"verify.js","sourceRoot":"","sources":["../../src/tunnel/verify.ts"],"names":[],"mappings":"AAAA;;GAEG;AAmBH,MAAM,oBAAoB,GAA2B;IACnD,sBAAsB,EAAE,iBAAiB;IACzC,0BAA0B,EAAE,qBAAqB;CAClD,CAAC;AAEF,MAAM,cAAc,GAAG,iBAAiB,CAAC;AAEzC;;GAEG;AACH,MAAM,UAAU,cAAc,CAC5B,aAAqB,EACrB,UAAmB;IAEnB,MAAM,MAAM,GACV,CAAC,UAAU,IAAI,oBAAoB,CAAC,UAAU,CAAC,CAAC,IAAI,cAAc,CAAC;IACrE,OAAO,WAAW,aAAa,CAAC,WAAW,EAAE,IAAI,MAAM,EAAE,CAAC;AAC5D,CAAC;AAED;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,eAAe,CACnC,SAAiB,EACjB,OAA6B;IAE7B,MAAM,WAAW,GAAG,OAAO,EAAE,WAAW,IAAI,CAAC,CAAC;IAC9C,MAAM,YAAY,GAAG,OAAO,EAAE,YAAY,IAAI,IAAI,CAAC;IACnD,MAAM,SAAS,GAAG,OAAO,EAAE,SAAS,IAAI,IAAI,CAAC;IAC7C,MAAM,OAAO,GAAG,OAAO,EAAE,OAAO,IAAI,KAAK,CAAC;IAE1C,MAAM,SAAS,GAAG,GAAG,SAAS,SAAS,CAAC;IACxC,IAAI,SAA6B,CAAC;IAElC,KAAK,IAAI,OAAO,GAAG,CAAC,EAAE,OAAO,IAAI,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC;QACxD,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,MAAM,OAAO,CAAC,SAAS,EAAE;gBACxC,MAAM,EAAE,WAAW,CAAC,OAAO,CAAC,SAAS,CAAC;aACvC,CAAC,CAAC;YACH,IAAI,QAAQ,CAAC,EAAE,EAAE,CAAC;gBAChB,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC;YAChD,CAAC;YACD,SAAS,GAAG,QAAQ,QAAQ,CAAC,MAAM,EAAE,CAAC;QACxC,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,SAAS,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC;QACnE,CAAC;QAED,IAAI,OAAO,GAAG,WAAW,EAAE,CAAC;YAC1B,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC,CAAC;QACpE,CAAC;IACH,CAAC;IAED,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;AACvE,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@opendatalabs/personal-server-ts-server",
|
|
3
|
-
"version": "0.0.1-canary.
|
|
3
|
+
"version": "0.0.1-canary.97dbbed",
|
|
4
4
|
"description": "Hono HTTP server for the Vana Personal Server — routes, middleware, composition root",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"repository": {
|
|
@@ -38,9 +38,7 @@
|
|
|
38
38
|
"dev": "node --watch dist/index.js"
|
|
39
39
|
},
|
|
40
40
|
"dependencies": {
|
|
41
|
-
"@opendatalabs/personal-server-ts-core": "0.0.1-canary.
|
|
42
|
-
"@opendatalabs/personal-server-ts-mcp": "*",
|
|
43
|
-
"@modelcontextprotocol/sdk": "^1.27.0",
|
|
41
|
+
"@opendatalabs/personal-server-ts-core": "0.0.1-canary.97dbbed",
|
|
44
42
|
"hono": "^4.7.0",
|
|
45
43
|
"@hono/node-server": "^1.14.0"
|
|
46
44
|
}
|
package/dist/oauth/provider.d.ts
DELETED
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
import type { AuthInfo } from "@modelcontextprotocol/sdk/server/auth/types.js";
|
|
2
|
-
export interface OAuthClientMetadata {
|
|
3
|
-
redirect_uris: string[];
|
|
4
|
-
client_name?: string;
|
|
5
|
-
token_endpoint_auth_method?: string;
|
|
6
|
-
}
|
|
7
|
-
export interface OAuthClient {
|
|
8
|
-
client_id: string;
|
|
9
|
-
client_secret: string;
|
|
10
|
-
redirect_uris: string[];
|
|
11
|
-
client_name?: string;
|
|
12
|
-
client_id_issued_at: number;
|
|
13
|
-
}
|
|
14
|
-
export declare class OAuthProvider {
|
|
15
|
-
private readonly serverOwner;
|
|
16
|
-
private clients;
|
|
17
|
-
private pendingAuths;
|
|
18
|
-
private tokens;
|
|
19
|
-
private refreshTokens;
|
|
20
|
-
constructor(serverOwner: `0x${string}`);
|
|
21
|
-
registerClient(metadata: OAuthClientMetadata): OAuthClient;
|
|
22
|
-
getClient(clientId: string): OAuthClient | undefined;
|
|
23
|
-
createPendingAuth(opts: {
|
|
24
|
-
clientId: string;
|
|
25
|
-
redirectUri: string;
|
|
26
|
-
codeChallenge: string;
|
|
27
|
-
codeChallengeMethod: "S256";
|
|
28
|
-
state: string | null;
|
|
29
|
-
scopes: string[];
|
|
30
|
-
}): string;
|
|
31
|
-
completeAuth(authCode: string, walletAddress: `0x${string}`): {
|
|
32
|
-
redirectUri: string;
|
|
33
|
-
state: string | null;
|
|
34
|
-
};
|
|
35
|
-
exchangeCode(authCode: string, codeVerifier: string, clientId: string): {
|
|
36
|
-
access_token: string;
|
|
37
|
-
token_type: string;
|
|
38
|
-
expires_in: number;
|
|
39
|
-
refresh_token: string;
|
|
40
|
-
};
|
|
41
|
-
verifyToken(token: string): AuthInfo | null;
|
|
42
|
-
refreshAccessToken(refreshToken: string, clientId: string): {
|
|
43
|
-
access_token: string;
|
|
44
|
-
token_type: string;
|
|
45
|
-
expires_in: number;
|
|
46
|
-
refresh_token: string;
|
|
47
|
-
};
|
|
48
|
-
/**
|
|
49
|
-
* Check if a wallet has access (is the owner or has a grant).
|
|
50
|
-
* For now, only the server owner gets full access.
|
|
51
|
-
*/
|
|
52
|
-
isAuthorizedWallet(walletAddress: `0x${string}`): boolean;
|
|
53
|
-
private verifyCodeChallenge;
|
|
54
|
-
}
|
|
55
|
-
//# sourceMappingURL=provider.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"provider.d.ts","sourceRoot":"","sources":["../../src/oauth/provider.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gDAAgD,CAAC;AAE/E,MAAM,WAAW,mBAAmB;IAClC,aAAa,EAAE,MAAM,EAAE,CAAC;IACxB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,0BAA0B,CAAC,EAAE,MAAM,CAAC;CACrC;AAED,MAAM,WAAW,WAAW;IAC1B,SAAS,EAAE,MAAM,CAAC;IAClB,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,MAAM,EAAE,CAAC;IACxB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,mBAAmB,EAAE,MAAM,CAAC;CAC7B;AA2BD,qBAAa,aAAa;IASZ,OAAO,CAAC,QAAQ,CAAC,WAAW;IARxC,OAAO,CAAC,OAAO,CAAkC;IACjD,OAAO,CAAC,YAAY,CAAkC;IACtD,OAAO,CAAC,MAAM,CAAkC;IAChD,OAAO,CAAC,aAAa,CAGjB;gBAEyB,WAAW,EAAE,KAAK,MAAM,EAAE;IAEvD,cAAc,CAAC,QAAQ,EAAE,mBAAmB,GAAG,WAAW;IAiB1D,SAAS,CAAC,QAAQ,EAAE,MAAM,GAAG,WAAW,GAAG,SAAS;IAIpD,iBAAiB,CAAC,IAAI,EAAE;QACtB,QAAQ,EAAE,MAAM,CAAC;QACjB,WAAW,EAAE,MAAM,CAAC;QACpB,aAAa,EAAE,MAAM,CAAC;QACtB,mBAAmB,EAAE,MAAM,CAAC;QAC5B,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;QACrB,MAAM,EAAE,MAAM,EAAE,CAAC;KAClB,GAAG,MAAM;IAqBV,YAAY,CACV,QAAQ,EAAE,MAAM,EAChB,aAAa,EAAE,KAAK,MAAM,EAAE,GAC3B;QAAE,WAAW,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAA;KAAE;IAOhD,YAAY,CACV,QAAQ,EAAE,MAAM,EAChB,YAAY,EAAE,MAAM,EACpB,QAAQ,EAAE,MAAM,GACf;QACD,YAAY,EAAE,MAAM,CAAC;QACrB,UAAU,EAAE,MAAM,CAAC;QACnB,UAAU,EAAE,MAAM,CAAC;QACnB,aAAa,EAAE,MAAM,CAAC;KACvB;IA2CD,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,QAAQ,GAAG,IAAI;IAgB3C,kBAAkB,CAChB,YAAY,EAAE,MAAM,EACpB,QAAQ,EAAE,MAAM,GACf;QACD,YAAY,EAAE,MAAM,CAAC;QACrB,UAAU,EAAE,MAAM,CAAC;QACnB,UAAU,EAAE,MAAM,CAAC;QACnB,aAAa,EAAE,MAAM,CAAC;KACvB;IAiCD;;;OAGG;IACH,kBAAkB,CAAC,aAAa,EAAE,KAAK,MAAM,EAAE,GAAG,OAAO;IAIzD,OAAO,CAAC,mBAAmB;CAa5B"}
|
package/dist/oauth/provider.js
DELETED
|
@@ -1,160 +0,0 @@
|
|
|
1
|
-
import { randomBytes, createHash } from "node:crypto";
|
|
2
|
-
function generateId() {
|
|
3
|
-
return randomBytes(32).toString("hex");
|
|
4
|
-
}
|
|
5
|
-
const TOKEN_TTL_MS = 60 * 60 * 1000; // 1 hour
|
|
6
|
-
const AUTH_CODE_TTL_MS = 5 * 60 * 1000; // 5 minutes
|
|
7
|
-
export class OAuthProvider {
|
|
8
|
-
serverOwner;
|
|
9
|
-
clients = new Map();
|
|
10
|
-
pendingAuths = new Map();
|
|
11
|
-
tokens = new Map();
|
|
12
|
-
refreshTokens = new Map();
|
|
13
|
-
constructor(serverOwner) {
|
|
14
|
-
this.serverOwner = serverOwner;
|
|
15
|
-
}
|
|
16
|
-
registerClient(metadata) {
|
|
17
|
-
if (!metadata.redirect_uris || metadata.redirect_uris.length === 0) {
|
|
18
|
-
throw new Error("redirect_uris is required");
|
|
19
|
-
}
|
|
20
|
-
const client = {
|
|
21
|
-
client_id: generateId(),
|
|
22
|
-
client_secret: generateId(),
|
|
23
|
-
redirect_uris: metadata.redirect_uris,
|
|
24
|
-
client_name: metadata.client_name,
|
|
25
|
-
client_id_issued_at: Math.floor(Date.now() / 1000),
|
|
26
|
-
};
|
|
27
|
-
this.clients.set(client.client_id, client);
|
|
28
|
-
return client;
|
|
29
|
-
}
|
|
30
|
-
getClient(clientId) {
|
|
31
|
-
return this.clients.get(clientId);
|
|
32
|
-
}
|
|
33
|
-
createPendingAuth(opts) {
|
|
34
|
-
const client = this.clients.get(opts.clientId);
|
|
35
|
-
if (!client)
|
|
36
|
-
throw new Error("Unknown client");
|
|
37
|
-
if (!client.redirect_uris.includes(opts.redirectUri)) {
|
|
38
|
-
throw new Error("Invalid redirect_uri");
|
|
39
|
-
}
|
|
40
|
-
const authCode = generateId();
|
|
41
|
-
this.pendingAuths.set(authCode, {
|
|
42
|
-
clientId: opts.clientId,
|
|
43
|
-
redirectUri: opts.redirectUri,
|
|
44
|
-
codeChallenge: opts.codeChallenge,
|
|
45
|
-
codeChallengeMethod: opts.codeChallengeMethod,
|
|
46
|
-
state: opts.state,
|
|
47
|
-
scopes: opts.scopes,
|
|
48
|
-
createdAt: Date.now(),
|
|
49
|
-
});
|
|
50
|
-
return authCode;
|
|
51
|
-
}
|
|
52
|
-
completeAuth(authCode, walletAddress) {
|
|
53
|
-
const pending = this.pendingAuths.get(authCode);
|
|
54
|
-
if (!pending)
|
|
55
|
-
throw new Error("Unknown auth code");
|
|
56
|
-
pending.walletAddress = walletAddress;
|
|
57
|
-
return { redirectUri: pending.redirectUri, state: pending.state };
|
|
58
|
-
}
|
|
59
|
-
exchangeCode(authCode, codeVerifier, clientId) {
|
|
60
|
-
const pending = this.pendingAuths.get(authCode);
|
|
61
|
-
if (!pending)
|
|
62
|
-
throw new Error("Invalid authorization code");
|
|
63
|
-
if (pending.clientId !== clientId)
|
|
64
|
-
throw new Error("Client mismatch");
|
|
65
|
-
if (!pending.walletAddress)
|
|
66
|
-
throw new Error("Authorization not completed");
|
|
67
|
-
if (Date.now() - pending.createdAt > AUTH_CODE_TTL_MS) {
|
|
68
|
-
this.pendingAuths.delete(authCode);
|
|
69
|
-
throw new Error("Authorization code expired");
|
|
70
|
-
}
|
|
71
|
-
// Verify PKCE challenge
|
|
72
|
-
if (!this.verifyCodeChallenge(codeVerifier, pending.codeChallenge)) {
|
|
73
|
-
throw new Error("Invalid code_verifier");
|
|
74
|
-
}
|
|
75
|
-
// Single-use: remove the auth code
|
|
76
|
-
this.pendingAuths.delete(authCode);
|
|
77
|
-
const accessToken = generateId();
|
|
78
|
-
const refreshToken = generateId();
|
|
79
|
-
const expiresIn = Math.floor(TOKEN_TTL_MS / 1000);
|
|
80
|
-
this.tokens.set(accessToken, {
|
|
81
|
-
clientId,
|
|
82
|
-
walletAddress: pending.walletAddress,
|
|
83
|
-
scopes: pending.scopes,
|
|
84
|
-
expiresAt: Date.now() + TOKEN_TTL_MS,
|
|
85
|
-
});
|
|
86
|
-
this.refreshTokens.set(refreshToken, {
|
|
87
|
-
clientId,
|
|
88
|
-
walletAddress: pending.walletAddress,
|
|
89
|
-
scopes: pending.scopes,
|
|
90
|
-
});
|
|
91
|
-
return {
|
|
92
|
-
access_token: accessToken,
|
|
93
|
-
token_type: "bearer",
|
|
94
|
-
expires_in: expiresIn,
|
|
95
|
-
refresh_token: refreshToken,
|
|
96
|
-
};
|
|
97
|
-
}
|
|
98
|
-
verifyToken(token) {
|
|
99
|
-
const record = this.tokens.get(token);
|
|
100
|
-
if (!record)
|
|
101
|
-
return null;
|
|
102
|
-
if (Date.now() > record.expiresAt) {
|
|
103
|
-
this.tokens.delete(token);
|
|
104
|
-
return null;
|
|
105
|
-
}
|
|
106
|
-
return {
|
|
107
|
-
token,
|
|
108
|
-
clientId: record.clientId,
|
|
109
|
-
scopes: record.scopes,
|
|
110
|
-
expiresAt: Math.floor(record.expiresAt / 1000),
|
|
111
|
-
};
|
|
112
|
-
}
|
|
113
|
-
refreshAccessToken(refreshToken, clientId) {
|
|
114
|
-
const record = this.refreshTokens.get(refreshToken);
|
|
115
|
-
if (!record)
|
|
116
|
-
throw new Error("Invalid refresh token");
|
|
117
|
-
if (record.clientId !== clientId)
|
|
118
|
-
throw new Error("Client mismatch");
|
|
119
|
-
// Rotate: remove old refresh token
|
|
120
|
-
this.refreshTokens.delete(refreshToken);
|
|
121
|
-
const newAccessToken = generateId();
|
|
122
|
-
const newRefreshToken = generateId();
|
|
123
|
-
const expiresIn = Math.floor(TOKEN_TTL_MS / 1000);
|
|
124
|
-
this.tokens.set(newAccessToken, {
|
|
125
|
-
clientId,
|
|
126
|
-
walletAddress: record.walletAddress,
|
|
127
|
-
scopes: record.scopes,
|
|
128
|
-
expiresAt: Date.now() + TOKEN_TTL_MS,
|
|
129
|
-
});
|
|
130
|
-
this.refreshTokens.set(newRefreshToken, {
|
|
131
|
-
clientId,
|
|
132
|
-
walletAddress: record.walletAddress,
|
|
133
|
-
scopes: record.scopes,
|
|
134
|
-
});
|
|
135
|
-
return {
|
|
136
|
-
access_token: newAccessToken,
|
|
137
|
-
token_type: "bearer",
|
|
138
|
-
expires_in: expiresIn,
|
|
139
|
-
refresh_token: newRefreshToken,
|
|
140
|
-
};
|
|
141
|
-
}
|
|
142
|
-
/**
|
|
143
|
-
* Check if a wallet has access (is the owner or has a grant).
|
|
144
|
-
* For now, only the server owner gets full access.
|
|
145
|
-
*/
|
|
146
|
-
isAuthorizedWallet(walletAddress) {
|
|
147
|
-
return walletAddress.toLowerCase() === this.serverOwner.toLowerCase();
|
|
148
|
-
}
|
|
149
|
-
verifyCodeChallenge(codeVerifier, codeChallenge) {
|
|
150
|
-
// S256: BASE64URL(SHA256(code_verifier)) === code_challenge
|
|
151
|
-
const hash = createHash("sha256").update(codeVerifier).digest();
|
|
152
|
-
const computed = hash
|
|
153
|
-
.toString("base64")
|
|
154
|
-
.replace(/\+/g, "-")
|
|
155
|
-
.replace(/\//g, "_")
|
|
156
|
-
.replace(/=+$/, "");
|
|
157
|
-
return computed === codeChallenge;
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
//# sourceMappingURL=provider.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"provider.js","sourceRoot":"","sources":["../../src/oauth/provider.ts"],"names":[],"mappings":"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"}
|
package/dist/oauth/routes.d.ts
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { Hono } from "hono";
|
|
2
|
-
import type { OAuthProvider } from "./provider.js";
|
|
3
|
-
export interface OAuthRouteDeps {
|
|
4
|
-
oauthProvider: OAuthProvider;
|
|
5
|
-
serverOwner: `0x${string}`;
|
|
6
|
-
accountPortalOrigin?: string;
|
|
7
|
-
serverOrigin?: string | (() => string);
|
|
8
|
-
}
|
|
9
|
-
export declare function oauthRoutes(deps: OAuthRouteDeps): Hono;
|
|
10
|
-
//# sourceMappingURL=routes.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"routes.d.ts","sourceRoot":"","sources":["../../src/oauth/routes.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAE5B,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAInD,MAAM,WAAW,cAAc;IAC7B,aAAa,EAAE,aAAa,CAAC;IAC7B,WAAW,EAAE,KAAK,MAAM,EAAE,CAAC;IAC3B,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,YAAY,CAAC,EAAE,MAAM,GAAG,CAAC,MAAM,MAAM,CAAC,CAAC;CACxC;AAED,wBAAgB,WAAW,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI,CA2QtD"}
|
package/dist/oauth/routes.js
DELETED
|
@@ -1,206 +0,0 @@
|
|
|
1
|
-
import { Hono } from "hono";
|
|
2
|
-
import { recoverServerOwner } from "@opendatalabs/personal-server-ts-core/keys";
|
|
3
|
-
const DEFAULT_ACCOUNT_PORTAL_ORIGIN = "https://account.vana.org";
|
|
4
|
-
export function oauthRoutes(deps) {
|
|
5
|
-
const app = new Hono();
|
|
6
|
-
const { oauthProvider } = deps;
|
|
7
|
-
const accountPortalOrigin = deps.accountPortalOrigin ?? DEFAULT_ACCOUNT_PORTAL_ORIGIN;
|
|
8
|
-
/** Resolve the public-facing origin (tunnel URL when available, else request origin). */
|
|
9
|
-
function getPublicOrigin(c) {
|
|
10
|
-
if (deps.serverOrigin) {
|
|
11
|
-
const origin = typeof deps.serverOrigin === "function"
|
|
12
|
-
? deps.serverOrigin()
|
|
13
|
-
: deps.serverOrigin;
|
|
14
|
-
if (origin)
|
|
15
|
-
return origin;
|
|
16
|
-
}
|
|
17
|
-
return new URL(c.req.url).origin;
|
|
18
|
-
}
|
|
19
|
-
// --- Discovery endpoints ---
|
|
20
|
-
app.get("/.well-known/oauth-authorization-server", (c) => {
|
|
21
|
-
const issuer = getPublicOrigin(c);
|
|
22
|
-
return c.json({
|
|
23
|
-
issuer,
|
|
24
|
-
authorization_endpoint: `${issuer}/authorize`,
|
|
25
|
-
token_endpoint: `${issuer}/token`,
|
|
26
|
-
registration_endpoint: `${issuer}/register`,
|
|
27
|
-
response_types_supported: ["code"],
|
|
28
|
-
grant_types_supported: ["authorization_code", "refresh_token"],
|
|
29
|
-
token_endpoint_auth_methods_supported: ["client_secret_post"],
|
|
30
|
-
code_challenge_methods_supported: ["S256"],
|
|
31
|
-
});
|
|
32
|
-
});
|
|
33
|
-
app.get("/.well-known/oauth-protected-resource", (c) => {
|
|
34
|
-
const origin = getPublicOrigin(c);
|
|
35
|
-
return c.json({
|
|
36
|
-
resource: origin,
|
|
37
|
-
authorization_servers: [origin],
|
|
38
|
-
});
|
|
39
|
-
});
|
|
40
|
-
// --- Dynamic Client Registration (RFC 7591) ---
|
|
41
|
-
app.post("/register", async (c) => {
|
|
42
|
-
try {
|
|
43
|
-
const body = await c.req.json();
|
|
44
|
-
const client = oauthProvider.registerClient({
|
|
45
|
-
redirect_uris: body.redirect_uris,
|
|
46
|
-
client_name: body.client_name,
|
|
47
|
-
token_endpoint_auth_method: body.token_endpoint_auth_method,
|
|
48
|
-
});
|
|
49
|
-
return c.json({
|
|
50
|
-
client_id: client.client_id,
|
|
51
|
-
client_secret: client.client_secret,
|
|
52
|
-
redirect_uris: client.redirect_uris,
|
|
53
|
-
client_name: client.client_name,
|
|
54
|
-
client_id_issued_at: client.client_id_issued_at,
|
|
55
|
-
}, 201);
|
|
56
|
-
}
|
|
57
|
-
catch (err) {
|
|
58
|
-
return c.json({ error: "invalid_client_metadata", error_description: String(err) }, 400);
|
|
59
|
-
}
|
|
60
|
-
});
|
|
61
|
-
// --- Authorization endpoint ---
|
|
62
|
-
app.get("/authorize", (c) => {
|
|
63
|
-
const clientId = c.req.query("client_id");
|
|
64
|
-
const redirectUri = c.req.query("redirect_uri");
|
|
65
|
-
const codeChallenge = c.req.query("code_challenge");
|
|
66
|
-
const codeChallengeMethod = c.req.query("code_challenge_method");
|
|
67
|
-
const state = c.req.query("state") ?? null;
|
|
68
|
-
const scope = c.req.query("scope") ?? "";
|
|
69
|
-
const responseType = c.req.query("response_type");
|
|
70
|
-
if (responseType !== "code") {
|
|
71
|
-
return c.json({ error: "unsupported_response_type" }, 400);
|
|
72
|
-
}
|
|
73
|
-
if (!clientId || !redirectUri || !codeChallenge) {
|
|
74
|
-
return c.json({
|
|
75
|
-
error: "invalid_request",
|
|
76
|
-
error_description: "Missing required parameters",
|
|
77
|
-
}, 400);
|
|
78
|
-
}
|
|
79
|
-
if (codeChallengeMethod !== "S256") {
|
|
80
|
-
return c.json({
|
|
81
|
-
error: "invalid_request",
|
|
82
|
-
error_description: "Only S256 code_challenge_method is supported",
|
|
83
|
-
}, 400);
|
|
84
|
-
}
|
|
85
|
-
const client = oauthProvider.getClient(clientId);
|
|
86
|
-
if (!client) {
|
|
87
|
-
return c.json({ error: "invalid_client" }, 400);
|
|
88
|
-
}
|
|
89
|
-
if (!client.redirect_uris.includes(redirectUri)) {
|
|
90
|
-
return c.json({
|
|
91
|
-
error: "invalid_request",
|
|
92
|
-
error_description: "redirect_uri not registered",
|
|
93
|
-
}, 400);
|
|
94
|
-
}
|
|
95
|
-
const scopes = scope ? scope.split(" ") : [];
|
|
96
|
-
let authCode;
|
|
97
|
-
try {
|
|
98
|
-
authCode = oauthProvider.createPendingAuth({
|
|
99
|
-
clientId,
|
|
100
|
-
redirectUri,
|
|
101
|
-
codeChallenge,
|
|
102
|
-
codeChallengeMethod: "S256",
|
|
103
|
-
state,
|
|
104
|
-
scopes,
|
|
105
|
-
});
|
|
106
|
-
}
|
|
107
|
-
catch (err) {
|
|
108
|
-
return c.json({ error: "server_error", error_description: String(err) }, 500);
|
|
109
|
-
}
|
|
110
|
-
// Redirect to Account Portal for identity verification.
|
|
111
|
-
// The callback URL points back to our /oauth/callback with the auth code as state.
|
|
112
|
-
const callbackUrl = `${getPublicOrigin(c)}/oauth/callback`;
|
|
113
|
-
const portalParams = new URLSearchParams({
|
|
114
|
-
// Use a placeholder sessionId — the Account Portal requires one to render the connect page.
|
|
115
|
-
// We pass the authCode via the redirect_uri so it comes back to us.
|
|
116
|
-
sessionId: `mcp-oauth-${authCode.slice(0, 8)}`,
|
|
117
|
-
redirect_uri: callbackUrl,
|
|
118
|
-
oauth_state: authCode,
|
|
119
|
-
appName: client.client_name ?? "MCP Client",
|
|
120
|
-
});
|
|
121
|
-
return c.redirect(`${accountPortalOrigin}/connect?${portalParams.toString()}`);
|
|
122
|
-
});
|
|
123
|
-
// --- OAuth callback (receives wallet proof from Account Portal) ---
|
|
124
|
-
app.get("/oauth/callback", async (c) => {
|
|
125
|
-
const masterKeySig = c.req.query("masterKeySig");
|
|
126
|
-
const authCode = c.req.query("oauth_state");
|
|
127
|
-
if (!masterKeySig || !authCode) {
|
|
128
|
-
return c.text("Missing masterKeySig or oauth_state parameter", 400);
|
|
129
|
-
}
|
|
130
|
-
// Recover wallet address from the master key signature
|
|
131
|
-
let walletAddress;
|
|
132
|
-
try {
|
|
133
|
-
walletAddress = await recoverServerOwner(masterKeySig);
|
|
134
|
-
}
|
|
135
|
-
catch {
|
|
136
|
-
return c.text("Invalid master key signature", 400);
|
|
137
|
-
}
|
|
138
|
-
// Check authorization: must be the server owner
|
|
139
|
-
if (!oauthProvider.isAuthorizedWallet(walletAddress)) {
|
|
140
|
-
return c.text("Unauthorized: wallet is not the server owner", 403);
|
|
141
|
-
}
|
|
142
|
-
// Complete the pending auth with the verified wallet
|
|
143
|
-
let authResult;
|
|
144
|
-
try {
|
|
145
|
-
authResult = oauthProvider.completeAuth(authCode, walletAddress);
|
|
146
|
-
}
|
|
147
|
-
catch (err) {
|
|
148
|
-
return c.text(`Authorization failed: ${err}`, 400);
|
|
149
|
-
}
|
|
150
|
-
// Redirect back to the OAuth client (e.g., Claude) with the auth code
|
|
151
|
-
const redirectUrl = new URL(authResult.redirectUri);
|
|
152
|
-
redirectUrl.searchParams.set("code", authCode);
|
|
153
|
-
if (authResult.state) {
|
|
154
|
-
redirectUrl.searchParams.set("state", authResult.state);
|
|
155
|
-
}
|
|
156
|
-
return c.redirect(redirectUrl.toString());
|
|
157
|
-
});
|
|
158
|
-
// --- Token endpoint ---
|
|
159
|
-
app.post("/token", async (c) => {
|
|
160
|
-
const contentType = c.req.header("content-type") ?? "";
|
|
161
|
-
let body;
|
|
162
|
-
if (contentType.includes("application/x-www-form-urlencoded")) {
|
|
163
|
-
const formData = await c.req.parseBody();
|
|
164
|
-
body = Object.fromEntries(Object.entries(formData).map(([k, v]) => [k, String(v)]));
|
|
165
|
-
}
|
|
166
|
-
else {
|
|
167
|
-
body = await c.req.json();
|
|
168
|
-
}
|
|
169
|
-
const grantType = body.grant_type;
|
|
170
|
-
const clientId = body.client_id;
|
|
171
|
-
if (!clientId) {
|
|
172
|
-
return c.json({ error: "invalid_client", error_description: "Missing client_id" }, 400);
|
|
173
|
-
}
|
|
174
|
-
try {
|
|
175
|
-
if (grantType === "authorization_code") {
|
|
176
|
-
const code = body.code;
|
|
177
|
-
const codeVerifier = body.code_verifier;
|
|
178
|
-
if (!code || !codeVerifier) {
|
|
179
|
-
return c.json({
|
|
180
|
-
error: "invalid_request",
|
|
181
|
-
error_description: "Missing code or code_verifier",
|
|
182
|
-
}, 400);
|
|
183
|
-
}
|
|
184
|
-
const tokens = oauthProvider.exchangeCode(code, codeVerifier, clientId);
|
|
185
|
-
return c.json(tokens);
|
|
186
|
-
}
|
|
187
|
-
if (grantType === "refresh_token") {
|
|
188
|
-
const refreshToken = body.refresh_token;
|
|
189
|
-
if (!refreshToken) {
|
|
190
|
-
return c.json({
|
|
191
|
-
error: "invalid_request",
|
|
192
|
-
error_description: "Missing refresh_token",
|
|
193
|
-
}, 400);
|
|
194
|
-
}
|
|
195
|
-
const tokens = oauthProvider.refreshAccessToken(refreshToken, clientId);
|
|
196
|
-
return c.json(tokens);
|
|
197
|
-
}
|
|
198
|
-
return c.json({ error: "unsupported_grant_type" }, 400);
|
|
199
|
-
}
|
|
200
|
-
catch (err) {
|
|
201
|
-
return c.json({ error: "invalid_grant", error_description: String(err) }, 400);
|
|
202
|
-
}
|
|
203
|
-
});
|
|
204
|
-
return app;
|
|
205
|
-
}
|
|
206
|
-
//# sourceMappingURL=routes.js.map
|
package/dist/oauth/routes.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"routes.js","sourceRoot":"","sources":["../../src/oauth/routes.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAC5B,OAAO,EAAE,kBAAkB,EAAE,MAAM,4CAA4C,CAAC;AAGhF,MAAM,6BAA6B,GAAG,0BAA0B,CAAC;AASjE,MAAM,UAAU,WAAW,CAAC,IAAoB;IAC9C,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;IACvB,MAAM,EAAE,aAAa,EAAE,GAAG,IAAI,CAAC;IAC/B,MAAM,mBAAmB,GACvB,IAAI,CAAC,mBAAmB,IAAI,6BAA6B,CAAC;IAE5D,yFAAyF;IACzF,SAAS,eAAe,CAAC,CAA2B;QAClD,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,MAAM,MAAM,GACV,OAAO,IAAI,CAAC,YAAY,KAAK,UAAU;gBACrC,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE;gBACrB,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC;YACxB,IAAI,MAAM;gBAAE,OAAO,MAAM,CAAC;QAC5B,CAAC;QACD,OAAO,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC;IACnC,CAAC;IAED,8BAA8B;IAE9B,GAAG,CAAC,GAAG,CAAC,yCAAyC,EAAE,CAAC,CAAC,EAAE,EAAE;QACvD,MAAM,MAAM,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC;QAClC,OAAO,CAAC,CAAC,IAAI,CAAC;YACZ,MAAM;YACN,sBAAsB,EAAE,GAAG,MAAM,YAAY;YAC7C,cAAc,EAAE,GAAG,MAAM,QAAQ;YACjC,qBAAqB,EAAE,GAAG,MAAM,WAAW;YAC3C,wBAAwB,EAAE,CAAC,MAAM,CAAC;YAClC,qBAAqB,EAAE,CAAC,oBAAoB,EAAE,eAAe,CAAC;YAC9D,qCAAqC,EAAE,CAAC,oBAAoB,CAAC;YAC7D,gCAAgC,EAAE,CAAC,MAAM,CAAC;SAC3C,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,GAAG,CAAC,GAAG,CAAC,uCAAuC,EAAE,CAAC,CAAC,EAAE,EAAE;QACrD,MAAM,MAAM,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC;QAClC,OAAO,CAAC,CAAC,IAAI,CAAC;YACZ,QAAQ,EAAE,MAAM;YAChB,qBAAqB,EAAE,CAAC,MAAM,CAAC;SAChC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,iDAAiD;IAEjD,GAAG,CAAC,IAAI,CAAC,WAAW,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;QAChC,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;YAChC,MAAM,MAAM,GAAG,aAAa,CAAC,cAAc,CAAC;gBAC1C,aAAa,EAAE,IAAI,CAAC,aAAa;gBACjC,WAAW,EAAE,IAAI,CAAC,WAAW;gBAC7B,0BAA0B,EAAE,IAAI,CAAC,0BAA0B;aAC5D,CAAC,CAAC;YAEH,OAAO,CAAC,CAAC,IAAI,CACX;gBACE,SAAS,EAAE,MAAM,CAAC,SAAS;gBAC3B,aAAa,EAAE,MAAM,CAAC,aAAa;gBACnC,aAAa,EAAE,MAAM,CAAC,aAAa;gBACnC,WAAW,EAAE,MAAM,CAAC,WAAW;gBAC/B,mBAAmB,EAAE,MAAM,CAAC,mBAAmB;aAChD,EACD,GAAG,CACJ,CAAC;QACJ,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,CAAC,IAAI,CACX,EAAE,KAAK,EAAE,yBAAyB,EAAE,iBAAiB,EAAE,MAAM,CAAC,GAAG,CAAC,EAAE,EACpE,GAAG,CACJ,CAAC;QACJ,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,iCAAiC;IAEjC,GAAG,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC,CAAC,EAAE,EAAE;QAC1B,MAAM,QAAQ,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;QAC1C,MAAM,WAAW,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;QAChD,MAAM,aAAa,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC;QACpD,MAAM,mBAAmB,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,uBAAuB,CAAC,CAAC;QACjE,MAAM,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC;QAC3C,MAAM,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;QACzC,MAAM,YAAY,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;QAElD,IAAI,YAAY,KAAK,MAAM,EAAE,CAAC;YAC5B,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,2BAA2B,EAAE,EAAE,GAAG,CAAC,CAAC;QAC7D,CAAC;QACD,IAAI,CAAC,QAAQ,IAAI,CAAC,WAAW,IAAI,CAAC,aAAa,EAAE,CAAC;YAChD,OAAO,CAAC,CAAC,IAAI,CACX;gBACE,KAAK,EAAE,iBAAiB;gBACxB,iBAAiB,EAAE,6BAA6B;aACjD,EACD,GAAG,CACJ,CAAC;QACJ,CAAC;QACD,IAAI,mBAAmB,KAAK,MAAM,EAAE,CAAC;YACnC,OAAO,CAAC,CAAC,IAAI,CACX;gBACE,KAAK,EAAE,iBAAiB;gBACxB,iBAAiB,EAAE,8CAA8C;aAClE,EACD,GAAG,CACJ,CAAC;QACJ,CAAC;QAED,MAAM,MAAM,GAAG,aAAa,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QACjD,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,gBAAgB,EAAE,EAAE,GAAG,CAAC,CAAC;QAClD,CAAC;QACD,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,CAAC;YAChD,OAAO,CAAC,CAAC,IAAI,CACX;gBACE,KAAK,EAAE,iBAAiB;gBACxB,iBAAiB,EAAE,6BAA6B;aACjD,EACD,GAAG,CACJ,CAAC;QACJ,CAAC;QAED,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAE7C,IAAI,QAAgB,CAAC;QACrB,IAAI,CAAC;YACH,QAAQ,GAAG,aAAa,CAAC,iBAAiB,CAAC;gBACzC,QAAQ;gBACR,WAAW;gBACX,aAAa;gBACb,mBAAmB,EAAE,MAAM;gBAC3B,KAAK;gBACL,MAAM;aACP,CAAC,CAAC;QACL,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,CAAC,IAAI,CACX,EAAE,KAAK,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,CAAC,GAAG,CAAC,EAAE,EACzD,GAAG,CACJ,CAAC;QACJ,CAAC;QAED,wDAAwD;QACxD,mFAAmF;QACnF,MAAM,WAAW,GAAG,GAAG,eAAe,CAAC,CAAC,CAAC,iBAAiB,CAAC;QAE3D,MAAM,YAAY,GAAG,IAAI,eAAe,CAAC;YACvC,4FAA4F;YAC5F,oEAAoE;YACpE,SAAS,EAAE,aAAa,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE;YAC9C,YAAY,EAAE,WAAW;YACzB,WAAW,EAAE,QAAQ;YACrB,OAAO,EAAE,MAAM,CAAC,WAAW,IAAI,YAAY;SAC5C,CAAC,CAAC;QAEH,OAAO,CAAC,CAAC,QAAQ,CACf,GAAG,mBAAmB,YAAY,YAAY,CAAC,QAAQ,EAAE,EAAE,CAC5D,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,qEAAqE;IAErE,GAAG,CAAC,GAAG,CAAC,iBAAiB,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;QACrC,MAAM,YAAY,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,cAAc,CAElC,CAAC;QACd,MAAM,QAAQ,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QAE5C,IAAI,CAAC,YAAY,IAAI,CAAC,QAAQ,EAAE,CAAC;YAC/B,OAAO,CAAC,CAAC,IAAI,CAAC,+CAA+C,EAAE,GAAG,CAAC,CAAC;QACtE,CAAC;QAED,uDAAuD;QACvD,IAAI,aAA4B,CAAC;QACjC,IAAI,CAAC;YACH,aAAa,GAAG,MAAM,kBAAkB,CAAC,YAAY,CAAC,CAAC;QACzD,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,CAAC,CAAC,IAAI,CAAC,8BAA8B,EAAE,GAAG,CAAC,CAAC;QACrD,CAAC;QAED,gDAAgD;QAChD,IAAI,CAAC,aAAa,CAAC,kBAAkB,CAAC,aAAa,CAAC,EAAE,CAAC;YACrD,OAAO,CAAC,CAAC,IAAI,CAAC,8CAA8C,EAAE,GAAG,CAAC,CAAC;QACrE,CAAC;QAED,qDAAqD;QACrD,IAAI,UAAyD,CAAC;QAC9D,IAAI,CAAC;YACH,UAAU,GAAG,aAAa,CAAC,YAAY,CAAC,QAAQ,EAAE,aAAa,CAAC,CAAC;QACnE,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,CAAC,IAAI,CAAC,yBAAyB,GAAG,EAAE,EAAE,GAAG,CAAC,CAAC;QACrD,CAAC;QAED,sEAAsE;QACtE,MAAM,WAAW,GAAG,IAAI,GAAG,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;QACpD,WAAW,CAAC,YAAY,CAAC,GAAG,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;QAC/C,IAAI,UAAU,CAAC,KAAK,EAAE,CAAC;YACrB,WAAW,CAAC,YAAY,CAAC,GAAG,CAAC,OAAO,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC;QAC1D,CAAC;QAED,OAAO,CAAC,CAAC,QAAQ,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC,CAAC;IAC5C,CAAC,CAAC,CAAC;IAEH,yBAAyB;IAEzB,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;QAC7B,MAAM,WAAW,GAAG,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;QACvD,IAAI,IAA4B,CAAC;QAEjC,IAAI,WAAW,CAAC,QAAQ,CAAC,mCAAmC,CAAC,EAAE,CAAC;YAC9D,MAAM,QAAQ,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,EAAE,CAAC;YACzC,IAAI,GAAG,MAAM,CAAC,WAAW,CACvB,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CACzD,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,IAAI,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;QAC5B,CAAC;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC;QAClC,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC;QAEhC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,OAAO,CAAC,CAAC,IAAI,CACX,EAAE,KAAK,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,EACnE,GAAG,CACJ,CAAC;QACJ,CAAC;QAED,IAAI,CAAC;YACH,IAAI,SAAS,KAAK,oBAAoB,EAAE,CAAC;gBACvC,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;gBACvB,MAAM,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC;gBACxC,IAAI,CAAC,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;oBAC3B,OAAO,CAAC,CAAC,IAAI,CACX;wBACE,KAAK,EAAE,iBAAiB;wBACxB,iBAAiB,EAAE,+BAA+B;qBACnD,EACD,GAAG,CACJ,CAAC;gBACJ,CAAC;gBAED,MAAM,MAAM,GAAG,aAAa,CAAC,YAAY,CAAC,IAAI,EAAE,YAAY,EAAE,QAAQ,CAAC,CAAC;gBACxE,OAAO,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACxB,CAAC;YAED,IAAI,SAAS,KAAK,eAAe,EAAE,CAAC;gBAClC,MAAM,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC;gBACxC,IAAI,CAAC,YAAY,EAAE,CAAC;oBAClB,OAAO,CAAC,CAAC,IAAI,CACX;wBACE,KAAK,EAAE,iBAAiB;wBACxB,iBAAiB,EAAE,uBAAuB;qBAC3C,EACD,GAAG,CACJ,CAAC;gBACJ,CAAC;gBAED,MAAM,MAAM,GAAG,aAAa,CAAC,kBAAkB,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;gBACxE,OAAO,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACxB,CAAC;YAED,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,wBAAwB,EAAE,EAAE,GAAG,CAAC,CAAC;QAC1D,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,CAAC,IAAI,CACX,EAAE,KAAK,EAAE,eAAe,EAAE,iBAAiB,EAAE,MAAM,CAAC,GAAG,CAAC,EAAE,EAC1D,GAAG,CACJ,CAAC;QACJ,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,OAAO,GAAG,CAAC;AACb,CAAC"}
|
package/dist/routes/mcp.d.ts
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { Hono } from "hono";
|
|
2
|
-
import type { McpContext } from "@opendatalabs/personal-server-ts-mcp";
|
|
3
|
-
import type { OAuthProvider } from "../oauth/provider.js";
|
|
4
|
-
export interface McpRouteDeps {
|
|
5
|
-
mcpContext: McpContext;
|
|
6
|
-
oauthProvider?: OAuthProvider;
|
|
7
|
-
serverOrigin?: string | (() => string);
|
|
8
|
-
}
|
|
9
|
-
export declare function mcpRoute(deps: McpRouteDeps): Hono;
|
|
10
|
-
//# sourceMappingURL=mcp.d.ts.map
|
package/dist/routes/mcp.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"mcp.d.ts","sourceRoot":"","sources":["../../src/routes/mcp.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAG5B,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,sCAAsC,CAAC;AACvE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAE1D,MAAM,WAAW,YAAY;IAC3B,UAAU,EAAE,UAAU,CAAC;IACvB,aAAa,CAAC,EAAE,aAAa,CAAC;IAC9B,YAAY,CAAC,EAAE,MAAM,GAAG,CAAC,MAAM,MAAM,CAAC,CAAC;CACxC;AAED,wBAAgB,QAAQ,CAAC,IAAI,EAAE,YAAY,GAAG,IAAI,CAkEjD"}
|
package/dist/routes/mcp.js
DELETED
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
import { Hono } from "hono";
|
|
2
|
-
import { WebStandardStreamableHTTPServerTransport } from "@modelcontextprotocol/sdk/server/webStandardStreamableHttp.js";
|
|
3
|
-
import { createMcpServer } from "@opendatalabs/personal-server-ts-mcp";
|
|
4
|
-
export function mcpRoute(deps) {
|
|
5
|
-
const app = new Hono();
|
|
6
|
-
app.all("/", async (c) => {
|
|
7
|
-
// Require bearer token when OAuth is configured
|
|
8
|
-
if (deps.oauthProvider) {
|
|
9
|
-
const authHeader = c.req.header("authorization");
|
|
10
|
-
if (!authHeader || !authHeader.startsWith("Bearer ")) {
|
|
11
|
-
let origin;
|
|
12
|
-
if (deps.serverOrigin) {
|
|
13
|
-
const o = typeof deps.serverOrigin === "function"
|
|
14
|
-
? deps.serverOrigin()
|
|
15
|
-
: deps.serverOrigin;
|
|
16
|
-
origin = o || new URL(c.req.url).origin;
|
|
17
|
-
}
|
|
18
|
-
else {
|
|
19
|
-
origin = new URL(c.req.url).origin;
|
|
20
|
-
}
|
|
21
|
-
return new Response(JSON.stringify({
|
|
22
|
-
error: "Unauthorized",
|
|
23
|
-
error_description: "Bearer token required",
|
|
24
|
-
}), {
|
|
25
|
-
status: 401,
|
|
26
|
-
headers: {
|
|
27
|
-
"WWW-Authenticate": `Bearer resource_metadata="${origin}/.well-known/oauth-protected-resource"`,
|
|
28
|
-
"Content-Type": "application/json",
|
|
29
|
-
},
|
|
30
|
-
});
|
|
31
|
-
}
|
|
32
|
-
const token = authHeader.slice(7);
|
|
33
|
-
const authInfo = deps.oauthProvider.verifyToken(token);
|
|
34
|
-
if (!authInfo) {
|
|
35
|
-
return new Response(JSON.stringify({
|
|
36
|
-
error: "invalid_token",
|
|
37
|
-
error_description: "Token expired or invalid",
|
|
38
|
-
}), {
|
|
39
|
-
status: 401,
|
|
40
|
-
headers: {
|
|
41
|
-
"WWW-Authenticate": 'Bearer error="invalid_token"',
|
|
42
|
-
"Content-Type": "application/json",
|
|
43
|
-
},
|
|
44
|
-
});
|
|
45
|
-
}
|
|
46
|
-
// Pass authInfo to the MCP transport
|
|
47
|
-
const transport = new WebStandardStreamableHTTPServerTransport();
|
|
48
|
-
const server = createMcpServer(deps.mcpContext);
|
|
49
|
-
await server.connect(transport);
|
|
50
|
-
return transport.handleRequest(c.req.raw, { authInfo });
|
|
51
|
-
}
|
|
52
|
-
// No OAuth configured — open access (dev/local mode)
|
|
53
|
-
const transport = new WebStandardStreamableHTTPServerTransport();
|
|
54
|
-
const server = createMcpServer(deps.mcpContext);
|
|
55
|
-
await server.connect(transport);
|
|
56
|
-
return transport.handleRequest(c.req.raw);
|
|
57
|
-
});
|
|
58
|
-
return app;
|
|
59
|
-
}
|
|
60
|
-
//# sourceMappingURL=mcp.js.map
|
package/dist/routes/mcp.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"mcp.js","sourceRoot":"","sources":["../../src/routes/mcp.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAC5B,OAAO,EAAE,wCAAwC,EAAE,MAAM,+DAA+D,CAAC;AACzH,OAAO,EAAE,eAAe,EAAE,MAAM,sCAAsC,CAAC;AAUvE,MAAM,UAAU,QAAQ,CAAC,IAAkB;IACzC,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;IAEvB,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;QACvB,gDAAgD;QAChD,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,MAAM,UAAU,GAAG,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;YACjD,IAAI,CAAC,UAAU,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;gBACrD,IAAI,MAAc,CAAC;gBACnB,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;oBACtB,MAAM,CAAC,GACL,OAAO,IAAI,CAAC,YAAY,KAAK,UAAU;wBACrC,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE;wBACrB,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC;oBACxB,MAAM,GAAG,CAAC,IAAI,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC;gBAC1C,CAAC;qBAAM,CAAC;oBACN,MAAM,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC;gBACrC,CAAC;gBACD,OAAO,IAAI,QAAQ,CACjB,IAAI,CAAC,SAAS,CAAC;oBACb,KAAK,EAAE,cAAc;oBACrB,iBAAiB,EAAE,uBAAuB;iBAC3C,CAAC,EACF;oBACE,MAAM,EAAE,GAAG;oBACX,OAAO,EAAE;wBACP,kBAAkB,EAAE,6BAA6B,MAAM,wCAAwC;wBAC/F,cAAc,EAAE,kBAAkB;qBACnC;iBACF,CACF,CAAC;YACJ,CAAC;YAED,MAAM,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAClC,MAAM,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YACvD,IAAI,CAAC,QAAQ,EAAE,CAAC;gBACd,OAAO,IAAI,QAAQ,CACjB,IAAI,CAAC,SAAS,CAAC;oBACb,KAAK,EAAE,eAAe;oBACtB,iBAAiB,EAAE,0BAA0B;iBAC9C,CAAC,EACF;oBACE,MAAM,EAAE,GAAG;oBACX,OAAO,EAAE;wBACP,kBAAkB,EAAE,8BAA8B;wBAClD,cAAc,EAAE,kBAAkB;qBACnC;iBACF,CACF,CAAC;YACJ,CAAC;YAED,qCAAqC;YACrC,MAAM,SAAS,GAAG,IAAI,wCAAwC,EAAE,CAAC;YACjE,MAAM,MAAM,GAAG,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAChD,MAAM,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;YAChC,OAAO,SAAS,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,QAAQ,EAAE,CAAC,CAAC;QAC1D,CAAC;QAED,qDAAqD;QACrD,MAAM,SAAS,GAAG,IAAI,wCAAwC,EAAE,CAAC;QACjE,MAAM,MAAM,GAAG,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAChD,MAAM,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QAChC,OAAO,SAAS,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IAC5C,CAAC,CAAC,CAAC;IAEH,OAAO,GAAG,CAAC;AACb,CAAC"}
|