chatbot-nc 2.2.40 → 2.2.42
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/cjs/utils/exception.d.ts +3 -3
- package/dist/cjs/utils/exception.js +10 -10
- package/dist/cjs/utils/exception.js.map +1 -1
- package/dist/cjs/utils/mcp-oauth.js +26 -22
- package/dist/cjs/utils/mcp-oauth.js.map +1 -1
- package/dist/cjs/utils/oauth.js +3 -3
- package/dist/cjs/utils/oauth.js.map +1 -1
- package/dist/esm/utils/exception.d.ts +3 -3
- package/dist/esm/utils/exception.js +6 -6
- package/dist/esm/utils/exception.js.map +1 -1
- package/dist/esm/utils/mcp-oauth.js +27 -23
- package/dist/esm/utils/mcp-oauth.js.map +1 -1
- package/dist/esm/utils/oauth.js +4 -4
- package/dist/esm/utils/oauth.js.map +1 -1
- package/package.json +1 -1
|
@@ -11,13 +11,13 @@ export declare class HttpException extends Error {
|
|
|
11
11
|
code: string;
|
|
12
12
|
constructor(message: string, options?: ExceptionOptions);
|
|
13
13
|
}
|
|
14
|
-
export declare class
|
|
14
|
+
export declare class BadRequestException extends HttpException {
|
|
15
15
|
constructor(message: string, options?: RequestOptions);
|
|
16
16
|
}
|
|
17
|
-
export declare class
|
|
17
|
+
export declare class OuthException extends HttpException {
|
|
18
18
|
constructor(message: string, options?: RequestOptions);
|
|
19
19
|
}
|
|
20
|
-
export declare class
|
|
20
|
+
export declare class MCPOuthException extends HttpException {
|
|
21
21
|
constructor(message: string, options?: RequestOptions);
|
|
22
22
|
}
|
|
23
23
|
export {};
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.MCPOuthException = exports.OuthException = exports.BadRequestException = exports.HttpException = void 0;
|
|
4
4
|
class HttpException extends Error {
|
|
5
5
|
constructor(message, options = {}) {
|
|
6
6
|
var _a, _b, _c, _d;
|
|
@@ -13,40 +13,40 @@ class HttpException extends Error {
|
|
|
13
13
|
}
|
|
14
14
|
}
|
|
15
15
|
exports.HttpException = HttpException;
|
|
16
|
-
class
|
|
16
|
+
class BadRequestException extends HttpException {
|
|
17
17
|
constructor(message, options = {}) {
|
|
18
18
|
var _a, _b, _c;
|
|
19
19
|
super(message, {
|
|
20
|
-
name: "
|
|
20
|
+
name: "#BadRequest",
|
|
21
21
|
statusCode: (_a = options.statusCode) !== null && _a !== void 0 ? _a : 400,
|
|
22
22
|
error: (_b = options.error) !== null && _b !== void 0 ? _b : "Bad_Request",
|
|
23
23
|
code: (_c = options.code) !== null && _c !== void 0 ? _c : "BAD_REQUEST",
|
|
24
24
|
});
|
|
25
25
|
}
|
|
26
26
|
}
|
|
27
|
-
exports.
|
|
28
|
-
class
|
|
27
|
+
exports.BadRequestException = BadRequestException;
|
|
28
|
+
class OuthException extends HttpException {
|
|
29
29
|
constructor(message, options = {}) {
|
|
30
30
|
var _a, _b, _c;
|
|
31
31
|
super(message, {
|
|
32
|
-
name: "
|
|
32
|
+
name: "#OuthException",
|
|
33
33
|
statusCode: (_a = options.statusCode) !== null && _a !== void 0 ? _a : 400,
|
|
34
34
|
error: (_b = options.error) !== null && _b !== void 0 ? _b : "OuthError",
|
|
35
35
|
code: (_c = options.code) !== null && _c !== void 0 ? _c : "OUTH_ERROR",
|
|
36
36
|
});
|
|
37
37
|
}
|
|
38
38
|
}
|
|
39
|
-
exports.
|
|
40
|
-
class
|
|
39
|
+
exports.OuthException = OuthException;
|
|
40
|
+
class MCPOuthException extends HttpException {
|
|
41
41
|
constructor(message, options = {}) {
|
|
42
42
|
var _a, _b, _c;
|
|
43
43
|
super(message, {
|
|
44
|
-
name: "
|
|
44
|
+
name: "#MCPOuthException",
|
|
45
45
|
statusCode: (_a = options.statusCode) !== null && _a !== void 0 ? _a : 400,
|
|
46
46
|
error: (_b = options.error) !== null && _b !== void 0 ? _b : "MCPOuthError",
|
|
47
47
|
code: (_c = options.code) !== null && _c !== void 0 ? _c : "MCP_OUTH_ERROR",
|
|
48
48
|
});
|
|
49
49
|
}
|
|
50
50
|
}
|
|
51
|
-
exports.
|
|
51
|
+
exports.MCPOuthException = MCPOuthException;
|
|
52
52
|
//# sourceMappingURL=exception.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"exception.js","sourceRoot":"","sources":["../../../utils/exception.ts"],"names":[],"mappings":";;;AASA,MAAa,aAAc,SAAQ,KAAK;IAKtC,YACE,OAAe,EACf,UAA4B,EAAE;;QAE9B,KAAK,CAAC,OAAO,CAAC,CAAC;QAEf,IAAI,CAAC,IAAI,GAAG,MAAA,OAAO,CAAC,IAAI,mCAAI,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC;QAC5C,IAAI,CAAC,UAAU,GAAG,MAAA,OAAO,CAAC,UAAU,mCAAI,GAAG,CAAC;QAC5C,IAAI,CAAC,KAAK,GAAG,MAAA,OAAO,CAAC,KAAK,mCAAI,uBAAuB,CAAC;QACtD,IAAI,CAAC,IAAI,GAAG,MAAA,OAAO,CAAC,IAAI,mCAAI,uBAAuB,CAAC;QAEpD,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,GAAG,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;IACpD,CAAC;CACF;AAlBD,sCAkBC;AAED,MAAa,
|
|
1
|
+
{"version":3,"file":"exception.js","sourceRoot":"","sources":["../../../utils/exception.ts"],"names":[],"mappings":";;;AASA,MAAa,aAAc,SAAQ,KAAK;IAKtC,YACE,OAAe,EACf,UAA4B,EAAE;;QAE9B,KAAK,CAAC,OAAO,CAAC,CAAC;QAEf,IAAI,CAAC,IAAI,GAAG,MAAA,OAAO,CAAC,IAAI,mCAAI,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC;QAC5C,IAAI,CAAC,UAAU,GAAG,MAAA,OAAO,CAAC,UAAU,mCAAI,GAAG,CAAC;QAC5C,IAAI,CAAC,KAAK,GAAG,MAAA,OAAO,CAAC,KAAK,mCAAI,uBAAuB,CAAC;QACtD,IAAI,CAAC,IAAI,GAAG,MAAA,OAAO,CAAC,IAAI,mCAAI,uBAAuB,CAAC;QAEpD,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,GAAG,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;IACpD,CAAC;CACF;AAlBD,sCAkBC;AAED,MAAa,mBAAoB,SAAQ,aAAa;IACpD,YACE,OAAe,EACf,UAA0B,EAAE;;QAE5B,KAAK,CAAC,OAAO,EAAE;YACb,IAAI,EAAE,aAAa;YACnB,UAAU,EAAE,MAAA,OAAO,CAAC,UAAU,mCAAI,GAAG;YACrC,KAAK,EAAE,MAAA,OAAO,CAAC,KAAK,mCAAI,aAAa;YACrC,IAAI,EAAE,MAAA,OAAO,CAAC,IAAI,mCAAI,aAAa;SACpC,CAAC,CAAC;IACL,CAAC;CACF;AAZD,kDAYC;AAED,MAAa,aAAc,SAAQ,aAAa;IAC9C,YACE,OAAe,EACf,UAA0B,EAAE;;QAE5B,KAAK,CAAC,OAAO,EAAE;YACb,IAAI,EAAE,gBAAgB;YACtB,UAAU,EAAE,MAAA,OAAO,CAAC,UAAU,mCAAI,GAAG;YACrC,KAAK,EAAE,MAAA,OAAO,CAAC,KAAK,mCAAI,WAAW;YACnC,IAAI,EAAE,MAAA,OAAO,CAAC,IAAI,mCAAI,YAAY;SACnC,CAAC,CAAC;IACL,CAAC;CACF;AAZD,sCAYC;AAED,MAAa,gBAAiB,SAAQ,aAAa;IACjD,YACE,OAAe,EACf,UAA0B,EAAE;;QAE5B,KAAK,CAAC,OAAO,EAAE;YACb,IAAI,EAAE,mBAAmB;YACzB,UAAU,EAAE,MAAA,OAAO,CAAC,UAAU,mCAAI,GAAG;YACrC,KAAK,EAAE,MAAA,OAAO,CAAC,KAAK,mCAAI,cAAc;YACtC,IAAI,EAAE,MAAA,OAAO,CAAC,IAAI,mCAAI,gBAAgB;SACvC,CAAC,CAAC;IACL,CAAC;CACF;AAZD,4CAYC"}
|
|
@@ -14,11 +14,11 @@ const exception_1 = require("./exception");
|
|
|
14
14
|
*/
|
|
15
15
|
const discoverOAuthResourceMetadata = async (mcpServerUrl) => {
|
|
16
16
|
const url = new URL(mcpServerUrl);
|
|
17
|
-
const protectedResourceUrl = new URL(`/.well-known/oauth-protected-resource${url.pathname}`, url.origin);
|
|
17
|
+
const protectedResourceUrl = new URL(`/.well-known/oauth-protected-resource${url.pathname.replace(/^\/$/, "")}`, url.origin);
|
|
18
18
|
// Step 1: RFC 9470 - Get Protected Resource Metadata
|
|
19
19
|
const protectedResourceResponse = await fetch(protectedResourceUrl.toString());
|
|
20
20
|
if (!protectedResourceResponse.ok) {
|
|
21
|
-
throw new exception_1.
|
|
21
|
+
throw new exception_1.MCPOuthException(`Failed to fetch protected resource metadata`, { error: "Fetch_Error", code: "FETCH_ERROR" });
|
|
22
22
|
}
|
|
23
23
|
const protectedResource = (await protectedResourceResponse.json());
|
|
24
24
|
return protectedResource;
|
|
@@ -27,30 +27,37 @@ const discoverOAuthResourceMetadata = async (mcpServerUrl) => {
|
|
|
27
27
|
* Discovers OAuth configuration for an MCP server using RFC 9470 + RFC 8414.
|
|
28
28
|
*/
|
|
29
29
|
const discoverOAuthMetadata = async (mcpServerUrl) => {
|
|
30
|
-
|
|
31
|
-
|
|
30
|
+
let protectedResource;
|
|
31
|
+
try {
|
|
32
|
+
protectedResource = (await discoverOAuthResourceMetadata(mcpServerUrl));
|
|
33
|
+
}
|
|
34
|
+
catch (error) {
|
|
35
|
+
return await oAuthMetadata(mcpServerUrl);
|
|
36
|
+
}
|
|
32
37
|
const authServers = protectedResource.authorization_servers;
|
|
33
38
|
if (!Array.isArray(authServers) || authServers.length === 0) {
|
|
34
|
-
throw new exception_1.
|
|
39
|
+
throw new exception_1.MCPOuthException("No authorization servers found in protected resource metadata", { error: "Resource_not_found", code: "RESOURCE_NOT_FOUND" });
|
|
35
40
|
}
|
|
36
41
|
// Use the first authorization server"
|
|
37
42
|
const authServerUrl = authServers[0];
|
|
43
|
+
return await oAuthMetadata(authServerUrl);
|
|
44
|
+
};
|
|
45
|
+
/**
|
|
46
|
+
* Discovers OAuth configuration for an MCP server using RFC 9470 + RFC 8414.
|
|
47
|
+
*/
|
|
48
|
+
const oAuthMetadata = async (authServerUrl) => {
|
|
49
|
+
var _a;
|
|
38
50
|
// Step 2: RFC 8414 - Get Authorization Server Metadata
|
|
39
51
|
let url = new URL(authServerUrl);
|
|
40
|
-
const metadataUrl = new URL(`/.well-known/oauth-authorization-server${url.pathname}`, url.origin);
|
|
52
|
+
const metadataUrl = new URL(`/.well-known/oauth-authorization-server${url.pathname.replace(/^\/$/, "")}`, url.origin);
|
|
41
53
|
let metadataResponse = await fetch(metadataUrl.toString());
|
|
42
54
|
if (!metadataResponse.ok) {
|
|
43
|
-
|
|
44
|
-
const secondMetaDataUrl = new URL(`/.well-known/oauth-authorization-server${url.pathname}`, url.origin);
|
|
45
|
-
metadataResponse = await fetch(secondMetaDataUrl.toString());
|
|
46
|
-
if (!metadataResponse.ok) {
|
|
47
|
-
throw new exception_1.MCPOuthError(`Failed to fetch authorization server metadata`, { error: "Resource_data_not_found", code: "RESOURCE_DATA_NOT_FOUND" });
|
|
48
|
-
}
|
|
55
|
+
throw new exception_1.MCPOuthException(`Failed to fetch authorization server metadata`, { error: "Resource_data_not_found", code: "RESOURCE_DATA_NOT_FOUND" });
|
|
49
56
|
}
|
|
50
57
|
const metadata = (await metadataResponse.json());
|
|
51
58
|
// Validate required fields
|
|
52
59
|
if (!metadata.authorization_endpoint || !metadata.token_endpoint) {
|
|
53
|
-
throw new exception_1.
|
|
60
|
+
throw new exception_1.MCPOuthException("Missing required OAuth endpoints in metadata");
|
|
54
61
|
}
|
|
55
62
|
// Warn if PKCE support isn't advertised
|
|
56
63
|
if (!((_a = metadata.code_challenge_methods_supported) === null || _a === void 0 ? void 0 : _a.includes("S256"))) {
|
|
@@ -69,7 +76,7 @@ const discoverOAuthMetadata = async (mcpServerUrl) => {
|
|
|
69
76
|
const registerClient = async (metadata, redirectUris, client_Name = "AuroCX") => {
|
|
70
77
|
var _a, _b, _c, _d, _e;
|
|
71
78
|
if (!metadata.registration_endpoint)
|
|
72
|
-
throw new exception_1.
|
|
79
|
+
throw new exception_1.MCPOuthException("Server does not support dynamic client registration", { error: "Dcr_not_support", code: "DCE_NOT_SUPPORT" });
|
|
73
80
|
const registrationRequest = {
|
|
74
81
|
client_name: client_Name,
|
|
75
82
|
redirect_uris: redirectUris,
|
|
@@ -81,15 +88,12 @@ const registerClient = async (metadata, redirectUris, client_Name = "AuroCX") =>
|
|
|
81
88
|
registrationRequest.scope = metadata.scopes_supported.join("");
|
|
82
89
|
const response = await fetch(metadata.registration_endpoint, {
|
|
83
90
|
method: "POST",
|
|
84
|
-
headers: {
|
|
85
|
-
"Content-Type": "application/json",
|
|
86
|
-
Accept: "application/json",
|
|
87
|
-
},
|
|
91
|
+
headers: { "Content-Type": "application/json", Accept: "application/json" },
|
|
88
92
|
body: JSON.stringify(registrationRequest),
|
|
89
93
|
});
|
|
90
94
|
if (!response.ok) {
|
|
91
95
|
const errorBody = await response.text();
|
|
92
|
-
throw new exception_1.
|
|
96
|
+
throw new exception_1.MCPOuthException(`Client registration failed`, { error: "Registration_Failed", code: "REGISTRATION_FAILD" });
|
|
93
97
|
}
|
|
94
98
|
const credentials = (await response.json());
|
|
95
99
|
// Store credentials securely
|
|
@@ -137,14 +141,14 @@ const buildAuthorizationUrl = async (metadata, clientId, redirectUri, state, cod
|
|
|
137
141
|
const handleCallBack = async (callbackUrl, storedState, codeVerifier) => {
|
|
138
142
|
const params = parseCallback(callbackUrl);
|
|
139
143
|
if (params.error) {
|
|
140
|
-
throw new exception_1.
|
|
144
|
+
throw new exception_1.MCPOuthException(`OAuth error: ${params.error} - ` +
|
|
141
145
|
`${params.error_description || "Unknown error"}`);
|
|
142
146
|
}
|
|
143
147
|
if (params.state !== storedState) {
|
|
144
|
-
throw new exception_1.
|
|
148
|
+
throw new exception_1.MCPOuthException("Invalid state parameter - possible CSRF attack");
|
|
145
149
|
}
|
|
146
150
|
if (!params.code) {
|
|
147
|
-
throw new exception_1.
|
|
151
|
+
throw new exception_1.MCPOuthException("Missing authorization code");
|
|
148
152
|
}
|
|
149
153
|
return params.code;
|
|
150
154
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mcp-oauth.js","sourceRoot":"","sources":["../../../utils/mcp-oauth.ts"],"names":[],"mappings":";;;;;;AAAA,kDAA0B;AAC1B,uDAA4B;AAE5B,
|
|
1
|
+
{"version":3,"file":"mcp-oauth.js","sourceRoot":"","sources":["../../../utils/mcp-oauth.ts"],"names":[],"mappings":"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"}
|
package/dist/cjs/utils/oauth.js
CHANGED
|
@@ -70,7 +70,7 @@ const resolveProviderUrl = (provider) => {
|
|
|
70
70
|
// lookup provider name
|
|
71
71
|
const url = OPENID_CONFIGURATION_URLS[provider.toLowerCase()];
|
|
72
72
|
if (!url)
|
|
73
|
-
throw new exception_1.
|
|
73
|
+
throw new exception_1.OuthException(`Unsupported OAuth Provider: ${provider}`, { code: "RESOURCE_META_REQUIRED", error: "Resoucr_meta_required" });
|
|
74
74
|
return url;
|
|
75
75
|
}
|
|
76
76
|
};
|
|
@@ -87,7 +87,7 @@ const discoverOAuthOpenIdMetadata = async (providerUrl) => {
|
|
|
87
87
|
// Step 1: RFC 9470 - Get OpenId Configuration
|
|
88
88
|
const openIdResponse = await fetch(discoveryUrl.toString());
|
|
89
89
|
if (!openIdResponse.ok) {
|
|
90
|
-
throw new exception_1.
|
|
90
|
+
throw new exception_1.OuthException(`Failed to fetch OpenID configuration:`, { code: "RESOURCE_META_REQUIRED", error: "Resoucr_meta_required" });
|
|
91
91
|
}
|
|
92
92
|
const metadata = (await openIdResponse.json());
|
|
93
93
|
return metadata;
|
|
@@ -99,7 +99,7 @@ const discoverOAuthOpenIdMetadata = async (providerUrl) => {
|
|
|
99
99
|
*/
|
|
100
100
|
const oauthToken = async (authValue) => {
|
|
101
101
|
if (!authValue)
|
|
102
|
-
throw new exception_1.
|
|
102
|
+
throw new exception_1.BadRequestException("OAuth Config Not Found");
|
|
103
103
|
const provisionList = JSON.parse(authValue);
|
|
104
104
|
if (!Array.isArray(provisionList))
|
|
105
105
|
return "";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"oauth.js","sourceRoot":"","sources":["../../../utils/oauth.ts"],"names":[],"mappings":";;;;;;AAAA,kDAA0B;AAC1B,mCAAiD;AACjD,uDAA4B;AAE5B,
|
|
1
|
+
{"version":3,"file":"oauth.js","sourceRoot":"","sources":["../../../utils/oauth.ts"],"names":[],"mappings":"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"}
|
|
@@ -11,13 +11,13 @@ export declare class HttpException extends Error {
|
|
|
11
11
|
code: string;
|
|
12
12
|
constructor(message: string, options?: ExceptionOptions);
|
|
13
13
|
}
|
|
14
|
-
export declare class
|
|
14
|
+
export declare class BadRequestException extends HttpException {
|
|
15
15
|
constructor(message: string, options?: RequestOptions);
|
|
16
16
|
}
|
|
17
|
-
export declare class
|
|
17
|
+
export declare class OuthException extends HttpException {
|
|
18
18
|
constructor(message: string, options?: RequestOptions);
|
|
19
19
|
}
|
|
20
|
-
export declare class
|
|
20
|
+
export declare class MCPOuthException extends HttpException {
|
|
21
21
|
constructor(message: string, options?: RequestOptions);
|
|
22
22
|
}
|
|
23
23
|
export {};
|
|
@@ -9,33 +9,33 @@ export class HttpException extends Error {
|
|
|
9
9
|
Object.setPrototypeOf(this, new.target.prototype);
|
|
10
10
|
}
|
|
11
11
|
}
|
|
12
|
-
export class
|
|
12
|
+
export class BadRequestException extends HttpException {
|
|
13
13
|
constructor(message, options = {}) {
|
|
14
14
|
var _a, _b, _c;
|
|
15
15
|
super(message, {
|
|
16
|
-
name: "
|
|
16
|
+
name: "#BadRequest",
|
|
17
17
|
statusCode: (_a = options.statusCode) !== null && _a !== void 0 ? _a : 400,
|
|
18
18
|
error: (_b = options.error) !== null && _b !== void 0 ? _b : "Bad_Request",
|
|
19
19
|
code: (_c = options.code) !== null && _c !== void 0 ? _c : "BAD_REQUEST",
|
|
20
20
|
});
|
|
21
21
|
}
|
|
22
22
|
}
|
|
23
|
-
export class
|
|
23
|
+
export class OuthException extends HttpException {
|
|
24
24
|
constructor(message, options = {}) {
|
|
25
25
|
var _a, _b, _c;
|
|
26
26
|
super(message, {
|
|
27
|
-
name: "
|
|
27
|
+
name: "#OuthException",
|
|
28
28
|
statusCode: (_a = options.statusCode) !== null && _a !== void 0 ? _a : 400,
|
|
29
29
|
error: (_b = options.error) !== null && _b !== void 0 ? _b : "OuthError",
|
|
30
30
|
code: (_c = options.code) !== null && _c !== void 0 ? _c : "OUTH_ERROR",
|
|
31
31
|
});
|
|
32
32
|
}
|
|
33
33
|
}
|
|
34
|
-
export class
|
|
34
|
+
export class MCPOuthException extends HttpException {
|
|
35
35
|
constructor(message, options = {}) {
|
|
36
36
|
var _a, _b, _c;
|
|
37
37
|
super(message, {
|
|
38
|
-
name: "
|
|
38
|
+
name: "#MCPOuthException",
|
|
39
39
|
statusCode: (_a = options.statusCode) !== null && _a !== void 0 ? _a : 400,
|
|
40
40
|
error: (_b = options.error) !== null && _b !== void 0 ? _b : "MCPOuthError",
|
|
41
41
|
code: (_c = options.code) !== null && _c !== void 0 ? _c : "MCP_OUTH_ERROR",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"exception.js","sourceRoot":"","sources":["../../../utils/exception.ts"],"names":[],"mappings":"AASA,MAAM,OAAO,aAAc,SAAQ,KAAK;IAKtC,YACE,OAAe,EACf,UAA4B,EAAE;;QAE9B,KAAK,CAAC,OAAO,CAAC,CAAC;QAEf,IAAI,CAAC,IAAI,GAAG,MAAA,OAAO,CAAC,IAAI,mCAAI,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC;QAC5C,IAAI,CAAC,UAAU,GAAG,MAAA,OAAO,CAAC,UAAU,mCAAI,GAAG,CAAC;QAC5C,IAAI,CAAC,KAAK,GAAG,MAAA,OAAO,CAAC,KAAK,mCAAI,uBAAuB,CAAC;QACtD,IAAI,CAAC,IAAI,GAAG,MAAA,OAAO,CAAC,IAAI,mCAAI,uBAAuB,CAAC;QAEpD,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,GAAG,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;IACpD,CAAC;CACF;AAED,MAAM,OAAO,
|
|
1
|
+
{"version":3,"file":"exception.js","sourceRoot":"","sources":["../../../utils/exception.ts"],"names":[],"mappings":"AASA,MAAM,OAAO,aAAc,SAAQ,KAAK;IAKtC,YACE,OAAe,EACf,UAA4B,EAAE;;QAE9B,KAAK,CAAC,OAAO,CAAC,CAAC;QAEf,IAAI,CAAC,IAAI,GAAG,MAAA,OAAO,CAAC,IAAI,mCAAI,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC;QAC5C,IAAI,CAAC,UAAU,GAAG,MAAA,OAAO,CAAC,UAAU,mCAAI,GAAG,CAAC;QAC5C,IAAI,CAAC,KAAK,GAAG,MAAA,OAAO,CAAC,KAAK,mCAAI,uBAAuB,CAAC;QACtD,IAAI,CAAC,IAAI,GAAG,MAAA,OAAO,CAAC,IAAI,mCAAI,uBAAuB,CAAC;QAEpD,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,GAAG,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;IACpD,CAAC;CACF;AAED,MAAM,OAAO,mBAAoB,SAAQ,aAAa;IACpD,YACE,OAAe,EACf,UAA0B,EAAE;;QAE5B,KAAK,CAAC,OAAO,EAAE;YACb,IAAI,EAAE,aAAa;YACnB,UAAU,EAAE,MAAA,OAAO,CAAC,UAAU,mCAAI,GAAG;YACrC,KAAK,EAAE,MAAA,OAAO,CAAC,KAAK,mCAAI,aAAa;YACrC,IAAI,EAAE,MAAA,OAAO,CAAC,IAAI,mCAAI,aAAa;SACpC,CAAC,CAAC;IACL,CAAC;CACF;AAED,MAAM,OAAO,aAAc,SAAQ,aAAa;IAC9C,YACE,OAAe,EACf,UAA0B,EAAE;;QAE5B,KAAK,CAAC,OAAO,EAAE;YACb,IAAI,EAAE,gBAAgB;YACtB,UAAU,EAAE,MAAA,OAAO,CAAC,UAAU,mCAAI,GAAG;YACrC,KAAK,EAAE,MAAA,OAAO,CAAC,KAAK,mCAAI,WAAW;YACnC,IAAI,EAAE,MAAA,OAAO,CAAC,IAAI,mCAAI,YAAY;SACnC,CAAC,CAAC;IACL,CAAC;CACF;AAED,MAAM,OAAO,gBAAiB,SAAQ,aAAa;IACjD,YACE,OAAe,EACf,UAA0B,EAAE;;QAE5B,KAAK,CAAC,OAAO,EAAE;YACb,IAAI,EAAE,mBAAmB;YACzB,UAAU,EAAE,MAAA,OAAO,CAAC,UAAU,mCAAI,GAAG;YACrC,KAAK,EAAE,MAAA,OAAO,CAAC,KAAK,mCAAI,cAAc;YACtC,IAAI,EAAE,MAAA,OAAO,CAAC,IAAI,mCAAI,gBAAgB;SACvC,CAAC,CAAC;IACL,CAAC;CACF"}
|
|
@@ -9,7 +9,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
9
9
|
};
|
|
10
10
|
import axios from "axios";
|
|
11
11
|
import log from "../logger";
|
|
12
|
-
import {
|
|
12
|
+
import { MCPOuthException } from "./exception";
|
|
13
13
|
/**
|
|
14
14
|
*
|
|
15
15
|
* @param mcpServerUrl
|
|
@@ -17,11 +17,11 @@ import { MCPOuthError } from "./exception";
|
|
|
17
17
|
*/
|
|
18
18
|
const discoverOAuthResourceMetadata = (mcpServerUrl) => __awaiter(void 0, void 0, void 0, function* () {
|
|
19
19
|
const url = new URL(mcpServerUrl);
|
|
20
|
-
const protectedResourceUrl = new URL(`/.well-known/oauth-protected-resource${url.pathname}`, url.origin);
|
|
20
|
+
const protectedResourceUrl = new URL(`/.well-known/oauth-protected-resource${url.pathname.replace(/^\/$/, "")}`, url.origin);
|
|
21
21
|
// Step 1: RFC 9470 - Get Protected Resource Metadata
|
|
22
22
|
const protectedResourceResponse = yield fetch(protectedResourceUrl.toString());
|
|
23
23
|
if (!protectedResourceResponse.ok) {
|
|
24
|
-
throw new
|
|
24
|
+
throw new MCPOuthException(`Failed to fetch protected resource metadata`, { error: "Fetch_Error", code: "FETCH_ERROR" });
|
|
25
25
|
}
|
|
26
26
|
const protectedResource = (yield protectedResourceResponse.json());
|
|
27
27
|
return protectedResource;
|
|
@@ -30,30 +30,37 @@ const discoverOAuthResourceMetadata = (mcpServerUrl) => __awaiter(void 0, void 0
|
|
|
30
30
|
* Discovers OAuth configuration for an MCP server using RFC 9470 + RFC 8414.
|
|
31
31
|
*/
|
|
32
32
|
const discoverOAuthMetadata = (mcpServerUrl) => __awaiter(void 0, void 0, void 0, function* () {
|
|
33
|
-
|
|
34
|
-
|
|
33
|
+
let protectedResource;
|
|
34
|
+
try {
|
|
35
|
+
protectedResource = (yield discoverOAuthResourceMetadata(mcpServerUrl));
|
|
36
|
+
}
|
|
37
|
+
catch (error) {
|
|
38
|
+
return yield oAuthMetadata(mcpServerUrl);
|
|
39
|
+
}
|
|
35
40
|
const authServers = protectedResource.authorization_servers;
|
|
36
41
|
if (!Array.isArray(authServers) || authServers.length === 0) {
|
|
37
|
-
throw new
|
|
42
|
+
throw new MCPOuthException("No authorization servers found in protected resource metadata", { error: "Resource_not_found", code: "RESOURCE_NOT_FOUND" });
|
|
38
43
|
}
|
|
39
44
|
// Use the first authorization server"
|
|
40
45
|
const authServerUrl = authServers[0];
|
|
46
|
+
return yield oAuthMetadata(authServerUrl);
|
|
47
|
+
});
|
|
48
|
+
/**
|
|
49
|
+
* Discovers OAuth configuration for an MCP server using RFC 9470 + RFC 8414.
|
|
50
|
+
*/
|
|
51
|
+
const oAuthMetadata = (authServerUrl) => __awaiter(void 0, void 0, void 0, function* () {
|
|
52
|
+
var _a;
|
|
41
53
|
// Step 2: RFC 8414 - Get Authorization Server Metadata
|
|
42
54
|
let url = new URL(authServerUrl);
|
|
43
|
-
const metadataUrl = new URL(`/.well-known/oauth-authorization-server${url.pathname}`, url.origin);
|
|
55
|
+
const metadataUrl = new URL(`/.well-known/oauth-authorization-server${url.pathname.replace(/^\/$/, "")}`, url.origin);
|
|
44
56
|
let metadataResponse = yield fetch(metadataUrl.toString());
|
|
45
57
|
if (!metadataResponse.ok) {
|
|
46
|
-
|
|
47
|
-
const secondMetaDataUrl = new URL(`/.well-known/oauth-authorization-server${url.pathname}`, url.origin);
|
|
48
|
-
metadataResponse = yield fetch(secondMetaDataUrl.toString());
|
|
49
|
-
if (!metadataResponse.ok) {
|
|
50
|
-
throw new MCPOuthError(`Failed to fetch authorization server metadata`, { error: "Resource_data_not_found", code: "RESOURCE_DATA_NOT_FOUND" });
|
|
51
|
-
}
|
|
58
|
+
throw new MCPOuthException(`Failed to fetch authorization server metadata`, { error: "Resource_data_not_found", code: "RESOURCE_DATA_NOT_FOUND" });
|
|
52
59
|
}
|
|
53
60
|
const metadata = (yield metadataResponse.json());
|
|
54
61
|
// Validate required fields
|
|
55
62
|
if (!metadata.authorization_endpoint || !metadata.token_endpoint) {
|
|
56
|
-
throw new
|
|
63
|
+
throw new MCPOuthException("Missing required OAuth endpoints in metadata");
|
|
57
64
|
}
|
|
58
65
|
// Warn if PKCE support isn't advertised
|
|
59
66
|
if (!((_a = metadata.code_challenge_methods_supported) === null || _a === void 0 ? void 0 : _a.includes("S256"))) {
|
|
@@ -72,7 +79,7 @@ const discoverOAuthMetadata = (mcpServerUrl) => __awaiter(void 0, void 0, void 0
|
|
|
72
79
|
const registerClient = (metadata_1, redirectUris_1, ...args_1) => __awaiter(void 0, [metadata_1, redirectUris_1, ...args_1], void 0, function* (metadata, redirectUris, client_Name = "AuroCX") {
|
|
73
80
|
var _a, _b, _c, _d, _e;
|
|
74
81
|
if (!metadata.registration_endpoint)
|
|
75
|
-
throw new
|
|
82
|
+
throw new MCPOuthException("Server does not support dynamic client registration", { error: "Dcr_not_support", code: "DCE_NOT_SUPPORT" });
|
|
76
83
|
const registrationRequest = {
|
|
77
84
|
client_name: client_Name,
|
|
78
85
|
redirect_uris: redirectUris,
|
|
@@ -84,15 +91,12 @@ const registerClient = (metadata_1, redirectUris_1, ...args_1) => __awaiter(void
|
|
|
84
91
|
registrationRequest.scope = metadata.scopes_supported.join("");
|
|
85
92
|
const response = yield fetch(metadata.registration_endpoint, {
|
|
86
93
|
method: "POST",
|
|
87
|
-
headers: {
|
|
88
|
-
"Content-Type": "application/json",
|
|
89
|
-
Accept: "application/json",
|
|
90
|
-
},
|
|
94
|
+
headers: { "Content-Type": "application/json", Accept: "application/json" },
|
|
91
95
|
body: JSON.stringify(registrationRequest),
|
|
92
96
|
});
|
|
93
97
|
if (!response.ok) {
|
|
94
98
|
const errorBody = yield response.text();
|
|
95
|
-
throw new
|
|
99
|
+
throw new MCPOuthException(`Client registration failed`, { error: "Registration_Failed", code: "REGISTRATION_FAILD" });
|
|
96
100
|
}
|
|
97
101
|
const credentials = (yield response.json());
|
|
98
102
|
// Store credentials securely
|
|
@@ -140,14 +144,14 @@ const buildAuthorizationUrl = (metadata, clientId, redirectUri, state, codeChall
|
|
|
140
144
|
const handleCallBack = (callbackUrl, storedState, codeVerifier) => __awaiter(void 0, void 0, void 0, function* () {
|
|
141
145
|
const params = parseCallback(callbackUrl);
|
|
142
146
|
if (params.error) {
|
|
143
|
-
throw new
|
|
147
|
+
throw new MCPOuthException(`OAuth error: ${params.error} - ` +
|
|
144
148
|
`${params.error_description || "Unknown error"}`);
|
|
145
149
|
}
|
|
146
150
|
if (params.state !== storedState) {
|
|
147
|
-
throw new
|
|
151
|
+
throw new MCPOuthException("Invalid state parameter - possible CSRF attack");
|
|
148
152
|
}
|
|
149
153
|
if (!params.code) {
|
|
150
|
-
throw new
|
|
154
|
+
throw new MCPOuthException("Missing authorization code");
|
|
151
155
|
}
|
|
152
156
|
return params.code;
|
|
153
157
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mcp-oauth.js","sourceRoot":"","sources":["../../../utils/mcp-oauth.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,GAAG,MAAM,WAAW,CAAC;AAE5B,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"mcp-oauth.js","sourceRoot":"","sources":["../../../utils/mcp-oauth.ts"],"names":[],"mappings":"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"}
|
package/dist/esm/utils/oauth.js
CHANGED
|
@@ -10,7 +10,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
10
10
|
import axios from "axios";
|
|
11
11
|
import { createHash, randomBytes } from "crypto";
|
|
12
12
|
import log from "../logger";
|
|
13
|
-
import {
|
|
13
|
+
import { BadRequestException, OuthException } from "./exception";
|
|
14
14
|
const OPENID_CONFIGURATION_URLS = {
|
|
15
15
|
// Google
|
|
16
16
|
google: "https://accounts.google.com",
|
|
@@ -73,7 +73,7 @@ const resolveProviderUrl = (provider) => {
|
|
|
73
73
|
// lookup provider name
|
|
74
74
|
const url = OPENID_CONFIGURATION_URLS[provider.toLowerCase()];
|
|
75
75
|
if (!url)
|
|
76
|
-
throw new
|
|
76
|
+
throw new OuthException(`Unsupported OAuth Provider: ${provider}`, { code: "RESOURCE_META_REQUIRED", error: "Resoucr_meta_required" });
|
|
77
77
|
return url;
|
|
78
78
|
}
|
|
79
79
|
};
|
|
@@ -90,7 +90,7 @@ const discoverOAuthOpenIdMetadata = (providerUrl) => __awaiter(void 0, void 0, v
|
|
|
90
90
|
// Step 1: RFC 9470 - Get OpenId Configuration
|
|
91
91
|
const openIdResponse = yield fetch(discoveryUrl.toString());
|
|
92
92
|
if (!openIdResponse.ok) {
|
|
93
|
-
throw new
|
|
93
|
+
throw new OuthException(`Failed to fetch OpenID configuration:`, { code: "RESOURCE_META_REQUIRED", error: "Resoucr_meta_required" });
|
|
94
94
|
}
|
|
95
95
|
const metadata = (yield openIdResponse.json());
|
|
96
96
|
return metadata;
|
|
@@ -102,7 +102,7 @@ const discoverOAuthOpenIdMetadata = (providerUrl) => __awaiter(void 0, void 0, v
|
|
|
102
102
|
*/
|
|
103
103
|
const oauthToken = (authValue) => __awaiter(void 0, void 0, void 0, function* () {
|
|
104
104
|
if (!authValue)
|
|
105
|
-
throw new
|
|
105
|
+
throw new BadRequestException("OAuth Config Not Found");
|
|
106
106
|
const provisionList = JSON.parse(authValue);
|
|
107
107
|
if (!Array.isArray(provisionList))
|
|
108
108
|
return "";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"oauth.js","sourceRoot":"","sources":["../../../utils/oauth.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,QAAQ,CAAC;AACjD,OAAO,GAAG,MAAM,WAAW,CAAC;AAE5B,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"oauth.js","sourceRoot":"","sources":["../../../utils/oauth.ts"],"names":[],"mappings":"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"}
|