@atxp/server 0.3.0 → 0.4.0
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/core/mcp.js.map +1 -1
- package/dist/getResource.js +19 -2
- package/dist/getResource.js.map +1 -1
- package/dist/index.cjs +371 -13444
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts +70 -14
- package/dist/index.js +342 -13441
- package/dist/index.js.map +1 -1
- package/dist/node/getRawBody.js +35 -0
- package/dist/node/getRawBody.js.map +1 -0
- package/dist/node/http.js +4 -7
- package/dist/node/http.js.map +1 -1
- package/dist/node/oauth.js +19 -1
- package/dist/node/oauth.js.map +1 -1
- package/dist/oAuthMetadata.js +1 -10
- package/dist/oAuthMetadata.js.map +1 -1
- package/dist/protectedResourceMetadata.js +6 -15
- package/dist/protectedResourceMetadata.js.map +1 -1
- package/dist/serverConfig.js +37 -0
- package/dist/serverConfig.js.map +1 -0
- package/dist/serverTestHelpers.d.ts +104 -0
- package/dist/serverTestHelpers.js +119 -0
- package/dist/serverTestHelpers.js.map +1 -0
- package/dist/webapi/mcp.js.map +1 -1
- package/dist/webapi/oauth.js +23 -1
- package/dist/webapi/oauth.js.map +1 -1
- package/package.json +8 -8
- package/dist/_virtual/_commonjsHelpers.js +0 -8
- package/dist/_virtual/_commonjsHelpers.js.map +0 -1
- package/dist/_virtual/bom-handling.js +0 -4
- package/dist/_virtual/bom-handling.js.map +0 -1
- package/dist/_virtual/dbcs-codec.js +0 -4
- package/dist/_virtual/dbcs-codec.js.map +0 -1
- package/dist/_virtual/index.js +0 -8
- package/dist/_virtual/index.js.map +0 -1
- package/dist/_virtual/index2.js +0 -4
- package/dist/_virtual/index2.js.map +0 -1
- package/dist/_virtual/index3.js +0 -4
- package/dist/_virtual/index3.js.map +0 -1
- package/dist/_virtual/index4.js +0 -4
- package/dist/_virtual/index4.js.map +0 -1
- package/dist/_virtual/index5.js +0 -4
- package/dist/_virtual/index5.js.map +0 -1
- package/dist/_virtual/inherits.js +0 -4
- package/dist/_virtual/inherits.js.map +0 -1
- package/dist/_virtual/inherits_browser.js +0 -4
- package/dist/_virtual/inherits_browser.js.map +0 -1
- package/dist/_virtual/sbcs-codec.js +0 -4
- package/dist/_virtual/sbcs-codec.js.map +0 -1
- package/dist/_virtual/utf16.js +0 -4
- package/dist/_virtual/utf16.js.map +0 -1
- package/dist/_virtual/utf32.js +0 -4
- package/dist/_virtual/utf32.js.map +0 -1
- package/dist/_virtual/utf7.js +0 -4
- package/dist/_virtual/utf7.js.map +0 -1
- package/dist/atxpServer.js +0 -93
- package/dist/atxpServer.js.map +0 -1
- package/dist/node_modules/bytes/index.js +0 -181
- package/dist/node_modules/bytes/index.js.map +0 -1
- package/dist/node_modules/depd/index.js +0 -551
- package/dist/node_modules/depd/index.js.map +0 -1
- package/dist/node_modules/http-errors/index.js +0 -307
- package/dist/node_modules/http-errors/index.js.map +0 -1
- package/dist/node_modules/iconv-lite/encodings/dbcs-codec.js +0 -599
- package/dist/node_modules/iconv-lite/encodings/dbcs-codec.js.map +0 -1
- package/dist/node_modules/iconv-lite/encodings/dbcs-data.js +0 -207
- package/dist/node_modules/iconv-lite/encodings/dbcs-data.js.map +0 -1
- package/dist/node_modules/iconv-lite/encodings/index.js +0 -45
- package/dist/node_modules/iconv-lite/encodings/index.js.map +0 -1
- package/dist/node_modules/iconv-lite/encodings/internal.js +0 -211
- package/dist/node_modules/iconv-lite/encodings/internal.js.map +0 -1
- package/dist/node_modules/iconv-lite/encodings/sbcs-codec.js +0 -84
- package/dist/node_modules/iconv-lite/encodings/sbcs-codec.js.map +0 -1
- package/dist/node_modules/iconv-lite/encodings/sbcs-data-generated.js +0 -461
- package/dist/node_modules/iconv-lite/encodings/sbcs-data-generated.js.map +0 -1
- package/dist/node_modules/iconv-lite/encodings/sbcs-data.js +0 -188
- package/dist/node_modules/iconv-lite/encodings/sbcs-data.js.map +0 -1
- package/dist/node_modules/iconv-lite/encodings/tables/big5-added.json.js +0 -507
- package/dist/node_modules/iconv-lite/encodings/tables/big5-added.json.js.map +0 -1
- package/dist/node_modules/iconv-lite/encodings/tables/cp936.json.js +0 -2622
- package/dist/node_modules/iconv-lite/encodings/tables/cp936.json.js.map +0 -1
- package/dist/node_modules/iconv-lite/encodings/tables/cp949.json.js +0 -2381
- package/dist/node_modules/iconv-lite/encodings/tables/cp949.json.js.map +0 -1
- package/dist/node_modules/iconv-lite/encodings/tables/cp950.json.js +0 -730
- package/dist/node_modules/iconv-lite/encodings/tables/cp950.json.js.map +0 -1
- package/dist/node_modules/iconv-lite/encodings/tables/eucjp.json.js +0 -823
- package/dist/node_modules/iconv-lite/encodings/tables/eucjp.json.js.map +0 -1
- package/dist/node_modules/iconv-lite/encodings/tables/gb18030-ranges.json.js +0 -425
- package/dist/node_modules/iconv-lite/encodings/tables/gb18030-ranges.json.js.map +0 -1
- package/dist/node_modules/iconv-lite/encodings/tables/gbk-added.json.js +0 -265
- package/dist/node_modules/iconv-lite/encodings/tables/gbk-added.json.js.map +0 -1
- package/dist/node_modules/iconv-lite/encodings/tables/shiftjis.json.js +0 -549
- package/dist/node_modules/iconv-lite/encodings/tables/shiftjis.json.js.map +0 -1
- package/dist/node_modules/iconv-lite/encodings/utf16.js +0 -207
- package/dist/node_modules/iconv-lite/encodings/utf16.js.map +0 -1
- package/dist/node_modules/iconv-lite/encodings/utf32.js +0 -330
- package/dist/node_modules/iconv-lite/encodings/utf32.js.map +0 -1
- package/dist/node_modules/iconv-lite/encodings/utf7.js +0 -298
- package/dist/node_modules/iconv-lite/encodings/utf7.js.map +0 -1
- package/dist/node_modules/iconv-lite/lib/bom-handling.js +0 -62
- package/dist/node_modules/iconv-lite/lib/bom-handling.js.map +0 -1
- package/dist/node_modules/iconv-lite/lib/index.js +0 -193
- package/dist/node_modules/iconv-lite/lib/index.js.map +0 -1
- package/dist/node_modules/iconv-lite/lib/streams.js +0 -121
- package/dist/node_modules/iconv-lite/lib/streams.js.map +0 -1
- package/dist/node_modules/inherits/inherits.js +0 -22
- package/dist/node_modules/inherits/inherits.js.map +0 -1
- package/dist/node_modules/inherits/inherits_browser.js +0 -39
- package/dist/node_modules/inherits/inherits_browser.js.map +0 -1
- package/dist/node_modules/raw-body/index.js +0 -352
- package/dist/node_modules/raw-body/index.js.map +0 -1
- package/dist/node_modules/safer-buffer/safer.js +0 -89
- package/dist/node_modules/safer-buffer/safer.js.map +0 -1
- package/dist/node_modules/setprototypeof/index.js +0 -27
- package/dist/node_modules/setprototypeof/index.js.map +0 -1
- package/dist/node_modules/statuses/codes.json.js +0 -68
- package/dist/node_modules/statuses/codes.json.js.map +0 -1
- package/dist/node_modules/statuses/index.js +0 -158
- package/dist/node_modules/statuses/index.js.map +0 -1
- package/dist/node_modules/toidentifier/index.js +0 -42
- package/dist/node_modules/toidentifier/index.js.map +0 -1
- package/dist/node_modules/unpipe/index.js +0 -79
- package/dist/node_modules/unpipe/index.js.map +0 -1
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
// Helper function to parse size strings like "4mb" to bytes
|
|
2
|
+
function parseSize(size) {
|
|
3
|
+
const match = size.match(/^(\d+(?:\.\d+)?)\s*([kmgt]?b?)$/i);
|
|
4
|
+
if (!match) {
|
|
5
|
+
throw new Error(`Invalid size format: ${size}`);
|
|
6
|
+
}
|
|
7
|
+
const value = parseFloat(match[1]);
|
|
8
|
+
const unit = (match[2] || 'b').toLowerCase();
|
|
9
|
+
const multipliers = {
|
|
10
|
+
'b': 1,
|
|
11
|
+
'kb': 1024,
|
|
12
|
+
'mb': 1024 * 1024,
|
|
13
|
+
'gb': 1024 * 1024 * 1024,
|
|
14
|
+
'tb': 1024 * 1024 * 1024 * 1024,
|
|
15
|
+
};
|
|
16
|
+
return Math.floor(value * (multipliers[unit] || 1));
|
|
17
|
+
}
|
|
18
|
+
async function getRawBody(req, encoding, maxSize) {
|
|
19
|
+
// Use native Node.js approach to read request body
|
|
20
|
+
const chunks = [];
|
|
21
|
+
let totalSize = 0;
|
|
22
|
+
const maxSizeBytes = parseSize(maxSize);
|
|
23
|
+
for await (const chunk of req) {
|
|
24
|
+
totalSize += chunk.length;
|
|
25
|
+
if (totalSize > maxSizeBytes) {
|
|
26
|
+
throw new Error(`Request body too large. Maximum size is ${maxSize}`);
|
|
27
|
+
}
|
|
28
|
+
chunks.push(chunk);
|
|
29
|
+
}
|
|
30
|
+
const body = Buffer.concat(chunks);
|
|
31
|
+
return body.toString(encoding);
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
export { getRawBody };
|
|
35
|
+
//# sourceMappingURL=getRawBody.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getRawBody.js","sources":["../../src/node/getRawBody.ts"],"sourcesContent":[null],"names":[],"mappings":"AAEA;AACA,SAAS,SAAS,CAAC,IAAY,EAAA;IAC7B,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,kCAAkC,CAAC;IAC5D,IAAI,CAAC,KAAK,EAAE;AACV,QAAA,MAAM,IAAI,KAAK,CAAC,wBAAwB,IAAI,CAAA,CAAE,CAAC;IACjD;IAEA,MAAM,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AAClC,IAAA,MAAM,IAAI,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,GAAG,EAAE,WAAW,EAAE;AAE5C,IAAA,MAAM,WAAW,GAA2B;AAC1C,QAAA,GAAG,EAAE,CAAC;AACN,QAAA,IAAI,EAAE,IAAI;QACV,IAAI,EAAE,IAAI,GAAG,IAAI;AACjB,QAAA,IAAI,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI;AACxB,QAAA,IAAI,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI;KAChC;AAED,IAAA,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;AACrD;AAEO,eAAe,UAAU,CAAC,GAAoB,EAAE,QAAgB,EAAE,OAAe,EAAA;;IAEtF,MAAM,MAAM,GAAa,EAAE;IAC3B,IAAI,SAAS,GAAG,CAAC;AACjB,IAAA,MAAM,YAAY,GAAG,SAAS,CAAC,OAAO,CAAC;AAEvC,IAAA,WAAW,MAAM,KAAK,IAAI,GAAG,EAAE;AAC7B,QAAA,SAAS,IAAI,KAAK,CAAC,MAAM;AACzB,QAAA,IAAI,SAAS,GAAG,YAAY,EAAE;AAC5B,YAAA,MAAM,IAAI,KAAK,CAAC,2CAA2C,OAAO,CAAA,CAAE,CAAC;QACvE;AACA,QAAA,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC;IACpB;IAEA,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC;AAClC,IAAA,OAAO,IAAI,CAAC,QAAQ,CAAC,QAA0B,CAAC;AAClD;;;;"}
|
package/dist/node/http.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import
|
|
2
|
-
import contentType from 'content-type';
|
|
1
|
+
import * as contentType from 'content-type';
|
|
3
2
|
import { isJSONRPCRequest } from '@modelcontextprotocol/sdk/types.js';
|
|
4
3
|
import { parseMcpMessages } from '@atxp/common';
|
|
5
4
|
import { parseMcpRequestsCore } from '../core/mcp.js';
|
|
5
|
+
import { getRawBody } from './getRawBody.js';
|
|
6
6
|
|
|
7
7
|
// Useful reference for dealing with low-level http requests:
|
|
8
8
|
// https://github.com/modelcontextprotocol/typescript-sdk/blob/c6ac083b1b37b222b5bfba5563822daa5d03372e/src/server/streamableHttp.ts#L375
|
|
@@ -36,11 +36,8 @@ async function parseBody(req, logger) {
|
|
|
36
36
|
const parsedCt = contentType.parse(ct);
|
|
37
37
|
encoding = parsedCt.parameters.charset ?? "utf-8";
|
|
38
38
|
}
|
|
39
|
-
const body = await getRawBody(req,
|
|
40
|
-
|
|
41
|
-
encoding,
|
|
42
|
-
});
|
|
43
|
-
return JSON.parse(body.toString());
|
|
39
|
+
const body = await getRawBody(req, encoding, MAXIMUM_MESSAGE_SIZE);
|
|
40
|
+
return JSON.parse(body);
|
|
44
41
|
}
|
|
45
42
|
catch (error) {
|
|
46
43
|
logger.error(error.message);
|
package/dist/node/http.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"http.js","sources":["../../src/node/http.ts"],"sourcesContent":[null],"names":[],"mappings":";;;;;;
|
|
1
|
+
{"version":3,"file":"http.js","sources":["../../src/node/http.ts"],"sourcesContent":[null],"names":[],"mappings":";;;;;;AAOA;AACA;AAEA;AACA,MAAM,oBAAoB,GAAG,KAAK;AAElC;;;AAGG;AACI,eAAe,gBAAgB,CAAC,MAAkB,EAAE,UAAe,EAAE,GAAoB,EAAE,UAAoB,EAAA;AACpH,IAAA,UAAU,GAAG,UAAU,IAAI,MAAM,SAAS,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,CAAC;;AAG9D,IAAA,MAAM,aAAa,GAAG,oBAAoB,CAAC,MAAM,EAAE,UAAU,EAAE,GAAG,CAAC,MAAM,IAAI,EAAE,EAAE,UAAU,CAAC;;AAG5F,IAAA,IAAI,aAAa,CAAC,MAAM,KAAK,CAAC,EAAE;AAC9B,QAAA,OAAO,EAAE;IACX;;IAGA,MAAM,QAAQ,GAAG,MAAM,gBAAgB,CAAC,UAAU,EAAE,MAAM,CAAC,MAAM,CAAC;AAElE,IAAA,MAAM,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,GAAG,IAAI,gBAAgB,CAAC,GAAG,CAAC,CAAC;IAC9D,IAAI,QAAQ,CAAC,MAAM,KAAK,QAAQ,CAAC,MAAM,EAAE;AACvC,QAAA,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA,QAAA,EAAW,QAAQ,CAAC,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAA,wCAAA,CAA0C,CAAC;IAC7G;AAEA,IAAA,OAAO,QAAQ;AACjB;AAEO,eAAe,SAAS,CAAC,GAAoB,EAAE,MAAc,EAAA;AAClE,IAAA,IAAI;QACF,MAAM,EAAE,GAAG,GAAG,CAAC,OAAO,CAAC,cAAc,CAAC;QAEtC,IAAI,QAAQ,GAAG,OAAO;QACtB,IAAI,EAAE,EAAE;YACN,MAAM,QAAQ,GAAG,WAAW,CAAC,KAAK,CAAC,EAAE,CAAC;YACtC,QAAQ,GAAG,QAAQ,CAAC,UAAU,CAAC,OAAO,IAAI,OAAO;QACnD;QACA,MAAM,IAAI,GAAG,MAAM,UAAU,CAAC,GAAG,EAAE,QAAQ,EAAE,oBAAoB,CAAC;AAClE,QAAA,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;IACzB;IAAE,OAAO,KAAK,EAAE;AACd,QAAA,MAAM,CAAC,KAAK,CAAE,KAAe,CAAC,OAAO,CAAC;AACtC,QAAA,OAAO,SAAS;IAClB;AACF;;;;"}
|
package/dist/node/oauth.js
CHANGED
|
@@ -18,6 +18,24 @@ function sendOAuthChallenge(res, tokenCheck) {
|
|
|
18
18
|
res.end(responseData.body);
|
|
19
19
|
return true;
|
|
20
20
|
}
|
|
21
|
+
function sendProtectedResourceMetadata(res, metadata) {
|
|
22
|
+
if (!metadata) {
|
|
23
|
+
return false;
|
|
24
|
+
}
|
|
25
|
+
res.setHeader('Content-Type', 'application/json');
|
|
26
|
+
res.writeHead(200);
|
|
27
|
+
res.end(JSON.stringify(metadata));
|
|
28
|
+
return true;
|
|
29
|
+
}
|
|
30
|
+
function sendOAuthMetadata(res, metadata) {
|
|
31
|
+
if (!metadata) {
|
|
32
|
+
return false;
|
|
33
|
+
}
|
|
34
|
+
res.setHeader('Content-Type', 'application/json');
|
|
35
|
+
res.writeHead(200);
|
|
36
|
+
res.end(JSON.stringify(metadata));
|
|
37
|
+
return true;
|
|
38
|
+
}
|
|
21
39
|
|
|
22
|
-
export { sendOAuthChallenge };
|
|
40
|
+
export { sendOAuthChallenge, sendOAuthMetadata, sendProtectedResourceMetadata };
|
|
23
41
|
//# sourceMappingURL=oauth.js.map
|
package/dist/node/oauth.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"oauth.js","sources":["../../src/node/oauth.ts"],"sourcesContent":[null],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"oauth.js","sources":["../../src/node/oauth.ts"],"sourcesContent":[null],"names":[],"mappings":";;AAKA;;;AAGG;AACG,SAAU,kBAAkB,CAAC,GAAmB,EAAE,UAAsB,EAAA;;AAE5E,IAAA,MAAM,YAAY,GAAG,gCAAgC,CAAC,UAAU,CAAC;IAEjE,IAAI,CAAC,YAAY,EAAE;AACjB,QAAA,OAAO,KAAK;IACd;;AAGA,IAAA,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,KAAI;AAC5D,QAAA,GAAG,CAAC,SAAS,CAAC,GAAG,EAAE,KAAK,CAAC;AAC3B,IAAA,CAAC,CAAC;AACF,IAAA,GAAG,CAAC,SAAS,CAAC,YAAY,CAAC,MAAM,CAAC;AAClC,IAAA,GAAG,CAAC,GAAG,CAAC,YAAY,CAAC,IAAI,CAAC;AAE1B,IAAA,OAAO,IAAI;AACb;AAEM,SAAU,6BAA6B,CAAC,GAAmB,EAAE,QAA0C,EAAA;IAC3G,IAAI,CAAC,QAAQ,EAAE;AACb,QAAA,OAAO,KAAK;IACd;AACA,IAAA,GAAG,CAAC,SAAS,CAAC,cAAc,EAAE,kBAAkB,CAAC;AACjD,IAAA,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC;IAClB,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;AACjC,IAAA,OAAO,IAAI;AACb;AAEM,SAAU,iBAAiB,CAAC,GAAmB,EAAE,QAA0C,EAAA;IAC/F,IAAI,CAAC,QAAQ,EAAE;AACb,QAAA,OAAO,KAAK;IACd;AACA,IAAA,GAAG,CAAC,SAAS,CAAC,cAAc,EAAE,kBAAkB,CAAC;AACjD,IAAA,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC;IAClB,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;AACjC,IAAA,OAAO,IAAI;AACb;;;;"}
|
package/dist/oAuthMetadata.js
CHANGED
|
@@ -1,14 +1,5 @@
|
|
|
1
1
|
import { getPath } from './getResource.js';
|
|
2
2
|
|
|
3
|
-
function sendOAuthMetadata(res, metadata) {
|
|
4
|
-
if (!metadata) {
|
|
5
|
-
return false;
|
|
6
|
-
}
|
|
7
|
-
res.setHeader('Content-Type', 'application/json');
|
|
8
|
-
res.writeHead(200);
|
|
9
|
-
res.end(JSON.stringify(metadata));
|
|
10
|
-
return true;
|
|
11
|
-
}
|
|
12
3
|
async function getOAuthMetadata(config, requestUrl) {
|
|
13
4
|
if (isOAuthMetadataRequest(config, requestUrl)) {
|
|
14
5
|
try {
|
|
@@ -40,5 +31,5 @@ function isOAuthMetadataRequest(config, requestUrl) {
|
|
|
40
31
|
return path === '/.well-known/oauth-authorization-server';
|
|
41
32
|
}
|
|
42
33
|
|
|
43
|
-
export { getOAuthMetadata
|
|
34
|
+
export { getOAuthMetadata };
|
|
44
35
|
//# sourceMappingURL=oAuthMetadata.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"oAuthMetadata.js","sources":["../src/oAuthMetadata.ts"],"sourcesContent":[null],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"oAuthMetadata.js","sources":["../src/oAuthMetadata.ts"],"sourcesContent":[null],"names":[],"mappings":";;AAIO,eAAe,gBAAgB,CAAC,MAAkB,EAAE,UAAe,EAAA;AACxE,IAAA,IAAI,sBAAsB,CAAC,MAAM,EAAE,UAAU,CAAC,EAAE;AAC9C,QAAA,IAAI;AACF,YAAA,MAAM,UAAU,GAAG,MAAM,MAAM,CAAC,WAAW,CAAC,0BAA0B,CAAC,IAAI,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;YAE9F,OAAO;gBACL,MAAM,EAAE,MAAM,CAAC,MAAM;gBACrB,sBAAsB,EAAE,UAAU,CAAC,sBAAsB;gBACzD,wBAAwB,EAAE,UAAU,CAAC,wBAAwB;gBAC7D,qBAAqB,EAAE,UAAU,CAAC,qBAAqB;gBACvD,cAAc,EAAE,UAAU,CAAC,cAAc;gBACzC,qCAAqC,EAAE,UAAU,CAAC,qCAAqC;gBACvF,qBAAqB,EAAE,UAAU,CAAC,qBAAqB;gBACvD,mBAAmB,EAAE,UAAU,CAAC,mBAAmB;gBACnD,sBAAsB,EAAE,UAAU,CAAC,sBAAsB;gBACzD,6CAA6C,EAAE,UAAU,CAAC,6CAA6C;gBACvG,gCAAgC,EAAE,UAAU,CAAC,gCAAgC;gBAC7E,gBAAgB,EAAE,UAAU,CAAC;aAC9B;QACH;QAAE,OAAO,KAAK,EAAE;AACd,YAAA,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA,uDAAA,EAA0D,MAAM,CAAC,MAAM,CAAA,EAAA,EAAK,KAAK,CAAA,CAAE,CAAC;AACxG,YAAA,MAAM,KAAK;QACb;IACF;AACA,IAAA,OAAO,IAAI;AACb;AAEA,SAAS,sBAAsB,CAAC,MAAkB,EAAE,UAAe,EAAA;AACjE,IAAA,MAAM,IAAI,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC;IACnD,OAAO,IAAI,KAAK,yCAAyC;AAC3D;;;;"}
|
|
@@ -1,17 +1,8 @@
|
|
|
1
1
|
import { getResource, getPath } from './getResource.js';
|
|
2
2
|
|
|
3
|
-
function
|
|
4
|
-
if (
|
|
5
|
-
|
|
6
|
-
}
|
|
7
|
-
res.setHeader('Content-Type', 'application/json');
|
|
8
|
-
res.writeHead(200);
|
|
9
|
-
res.end(JSON.stringify(metadata));
|
|
10
|
-
return true;
|
|
11
|
-
}
|
|
12
|
-
function getProtectedResourceMetadata(config, requestUrl) {
|
|
13
|
-
if (isProtectedResourceMetadataRequest(config, requestUrl)) {
|
|
14
|
-
const resource = getResource(config, requestUrl);
|
|
3
|
+
function getProtectedResourceMetadata(config, requestUrl, headers) {
|
|
4
|
+
if (isProtectedResourceMetadataRequest(config, requestUrl, headers)) {
|
|
5
|
+
const resource = getResource(config, requestUrl, headers);
|
|
15
6
|
return {
|
|
16
7
|
resource,
|
|
17
8
|
resource_name: config.payeeName || resource.toString(),
|
|
@@ -22,12 +13,12 @@ function getProtectedResourceMetadata(config, requestUrl) {
|
|
|
22
13
|
}
|
|
23
14
|
return null;
|
|
24
15
|
}
|
|
25
|
-
function isProtectedResourceMetadataRequest(config, requestUrl) {
|
|
16
|
+
function isProtectedResourceMetadataRequest(config, requestUrl, headers) {
|
|
26
17
|
const path = getPath(requestUrl);
|
|
27
18
|
if (!path.startsWith('/.well-known/oauth-protected-resource')) {
|
|
28
19
|
return false;
|
|
29
20
|
}
|
|
30
|
-
const resource = getResource(config, requestUrl);
|
|
21
|
+
const resource = getResource(config, requestUrl, headers);
|
|
31
22
|
const resourcePath = getPath(resource);
|
|
32
23
|
const mountPath = config.mountPath.replace(/\/$/, '');
|
|
33
24
|
if (resourcePath === mountPath) {
|
|
@@ -39,5 +30,5 @@ function isProtectedResourceMetadataRequest(config, requestUrl) {
|
|
|
39
30
|
return false;
|
|
40
31
|
}
|
|
41
32
|
|
|
42
|
-
export { getProtectedResourceMetadata
|
|
33
|
+
export { getProtectedResourceMetadata };
|
|
43
34
|
//# sourceMappingURL=protectedResourceMetadata.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"protectedResourceMetadata.js","sources":["../src/protectedResourceMetadata.ts"],"sourcesContent":[null],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"protectedResourceMetadata.js","sources":["../src/protectedResourceMetadata.ts"],"sourcesContent":[null],"names":[],"mappings":";;SAGgB,4BAA4B,CAAC,MAAkB,EAAE,UAAe,EAAE,OAAuD,EAAA;IACvI,IAAI,kCAAkC,CAAC,MAAM,EAAE,UAAU,EAAE,OAAO,CAAC,EAAE;QACnE,MAAM,QAAQ,GAAG,WAAW,CAAC,MAAM,EAAE,UAAU,EAAE,OAAO,CAAC;QACzD,OAAO;YACL,QAAQ;YACR,aAAa,EAAE,MAAM,CAAC,SAAS,IAAI,QAAQ,CAAC,QAAQ,EAAE;AACtD,YAAA,qBAAqB,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC;YACtC,wBAAwB,EAAE,CAAC,QAAQ,CAAC;AACpC,YAAA,gBAAgB,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC;SACpC;IACH;AACA,IAAA,OAAO,IAAI;AACb;AAEA,SAAS,kCAAkC,CAAC,MAAkB,EAAE,UAAe,EAAE,OAAuD,EAAA;AACtI,IAAA,MAAM,IAAI,GAAG,OAAO,CAAC,UAAU,CAAC;IAChC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,uCAAuC,CAAC,EAAE;AAC7D,QAAA,OAAO,KAAK;IACd;IACA,MAAM,QAAQ,GAAG,WAAW,CAAC,MAAM,EAAE,UAAU,EAAE,OAAO,CAAC;AACzD,IAAA,MAAM,YAAY,GAAG,OAAO,CAAC,QAAQ,CAAC;AACtC,IAAA,MAAM,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC;AACrD,IAAA,IAAI,YAAY,KAAK,SAAS,EAAE;AAC9B,QAAA,OAAO,IAAI;IACb;AACA,IAAA,IAAI,YAAY,KAAK,CAAA,EAAG,SAAS,CAAA,QAAA,CAAU,EAAE;AAC3C,QAAA,OAAO,IAAI;IACb;AACA,IAAA,OAAO,KAAK;AACd;;;;"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { DEFAULT_AUTHORIZATION_SERVER, MemoryOAuthDb, OAuthResourceClient, ConsoleLogger } from '@atxp/common';
|
|
2
|
+
import { ATXPPaymentServer } from './paymentServer.js';
|
|
3
|
+
|
|
4
|
+
const DEFAULT_CONFIG = {
|
|
5
|
+
mountPath: '/',
|
|
6
|
+
currency: 'USDC',
|
|
7
|
+
network: 'base',
|
|
8
|
+
server: DEFAULT_AUTHORIZATION_SERVER,
|
|
9
|
+
payeeName: 'An ATXP Server',
|
|
10
|
+
allowHttp: false, // May be overridden in buildServerConfig by process.env.NODE_ENV
|
|
11
|
+
resource: null, // Set dynamically from the request URL
|
|
12
|
+
};
|
|
13
|
+
function buildServerConfig(args) {
|
|
14
|
+
if (!args.destination) {
|
|
15
|
+
throw new Error('destination is required');
|
|
16
|
+
}
|
|
17
|
+
// Read environment variables at runtime, not module load time
|
|
18
|
+
const envDefaults = {
|
|
19
|
+
...DEFAULT_CONFIG,
|
|
20
|
+
atxpAuthClientToken: process.env.ATXP_AUTH_CLIENT_TOKEN,
|
|
21
|
+
allowHttp: process.env.NODE_ENV === 'development',
|
|
22
|
+
};
|
|
23
|
+
const withDefaults = { ...envDefaults, ...args };
|
|
24
|
+
const oAuthDb = withDefaults.oAuthDb ?? new MemoryOAuthDb();
|
|
25
|
+
const oAuthClient = withDefaults.oAuthClient ?? new OAuthResourceClient({
|
|
26
|
+
db: oAuthDb,
|
|
27
|
+
allowInsecureRequests: withDefaults.allowHttp,
|
|
28
|
+
clientName: withDefaults.payeeName,
|
|
29
|
+
});
|
|
30
|
+
const logger = withDefaults.logger ?? new ConsoleLogger();
|
|
31
|
+
const paymentServer = withDefaults.paymentServer ?? new ATXPPaymentServer(withDefaults.server, logger);
|
|
32
|
+
const built = { oAuthDb, oAuthClient, paymentServer, logger };
|
|
33
|
+
return Object.freeze({ ...withDefaults, ...built });
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
export { DEFAULT_CONFIG, buildServerConfig };
|
|
37
|
+
//# sourceMappingURL=serverConfig.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"serverConfig.js","sources":["../src/serverConfig.ts"],"sourcesContent":[null],"names":[],"mappings":";;;AAUO,MAAM,cAAc,GAAkE;AAC3F,IAAA,SAAS,EAAE,GAAG;AACd,IAAA,QAAQ,EAAE,MAAe;AACzB,IAAA,OAAO,EAAE,MAAe;AACxB,IAAA,MAAM,EAAE,4BAA4B;AACpC,IAAA,SAAS,EAAE,gBAAgB;IAC3B,SAAS,EAAE,KAAK;IAChB,QAAQ,EAAE,IAAI;;AAGV,SAAU,iBAAiB,CAAC,IAAc,EAAA;AAC9C,IAAA,IAAG,CAAC,IAAI,CAAC,WAAW,EAAE;AACpB,QAAA,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC;IAC5C;;AAGA,IAAA,MAAM,WAAW,GAAG;AAClB,QAAA,GAAG,cAAc;AACjB,QAAA,mBAAmB,EAAE,OAAO,CAAC,GAAG,CAAC,sBAAsB;AACvD,QAAA,SAAS,EAAE,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,aAAa;KAClD;IACD,MAAM,YAAY,GAAG,EAAE,GAAG,WAAW,EAAE,GAAG,IAAI,EAAE;IAChD,MAAM,OAAO,GAAG,YAAY,CAAC,OAAO,IAAI,IAAI,aAAa,EAAE;IAC3D,MAAM,WAAW,GAAG,YAAY,CAAC,WAAW,IAAI,IAAI,mBAAmB,CAAC;AACtE,QAAA,EAAE,EAAE,OAAO;QACX,qBAAqB,EAAE,YAAY,CAAC,SAAS;QAC7C,UAAU,EAAE,YAAY,CAAC,SAAS;AACnC,KAAA,CAAC;IACF,MAAM,MAAM,GAAG,YAAY,CAAC,MAAM,IAAI,IAAI,aAAa,EAAE;AACzD,IAAA,MAAM,aAAa,GAAG,YAAY,CAAC,aAAa,IAAI,IAAI,iBAAiB,CAAC,YAAY,CAAC,MAAM,EAAE,MAAM,CAAC;IAEtG,MAAM,KAAK,GAAG,EAAE,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,EAAC;AAC5D,IAAA,OAAO,MAAM,CAAC,MAAM,CAAC,EAAE,GAAG,YAAY,EAAE,GAAG,KAAK,EAAE,CAAC;AACrD;;;;"}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import * as vitest from 'vitest';
|
|
2
|
+
import { IncomingHttpHeaders, IncomingMessage, ServerResponse } from 'http';
|
|
3
|
+
import { JSONRPCRequest } from '@modelcontextprotocol/sdk/types.js';
|
|
4
|
+
import { PaymentRequestData, Currency, Network, AuthorizationServerUrl, UrlString, Logger, OAuthDb, OAuthResourceClient, TokenData } from '@atxp/common';
|
|
5
|
+
import * as oauth from 'oauth4webapi';
|
|
6
|
+
|
|
7
|
+
type McpMethod = 'notifications/cancelled' | 'initialize' | 'ping' | 'notifications/progress' | 'resources/list' | 'resources/templates/list' | 'resources/read' | 'notifications/resources/list_changed' | 'resources/subscribe' | 'resources/unsubscribe' | 'notifications/resources/updated' | 'prompts/list' | 'prompts/get' | 'notifications/prompts/list_changed' | 'tools/list' | 'tools/call' | 'notifications/tools/list_changed' | 'logging/setLevel' | 'notifications/message' | 'sampling/createMessage' | 'elicitation/create' | 'completion/complete' | 'roots/list' | 'notifications/roots/list_changed';
|
|
8
|
+
type McpName = string;
|
|
9
|
+
type Charge = Omit<PaymentRequestData, 'resource' | 'resourceName' | 'iss'>;
|
|
10
|
+
type ChargeResponse = {
|
|
11
|
+
success: boolean;
|
|
12
|
+
requiredPayment: PaymentRequestData | null;
|
|
13
|
+
};
|
|
14
|
+
type PaymentServer = {
|
|
15
|
+
charge: (args: Charge) => Promise<ChargeResponse>;
|
|
16
|
+
createPaymentRequest: (args: Charge) => Promise<string>;
|
|
17
|
+
};
|
|
18
|
+
type ATXPConfig = {
|
|
19
|
+
destination: string;
|
|
20
|
+
mountPath: string;
|
|
21
|
+
currency: Currency;
|
|
22
|
+
network: Network;
|
|
23
|
+
server: AuthorizationServerUrl;
|
|
24
|
+
payeeName: string;
|
|
25
|
+
resource: UrlString | null;
|
|
26
|
+
allowHttp: boolean;
|
|
27
|
+
logger: Logger;
|
|
28
|
+
oAuthDb: OAuthDb;
|
|
29
|
+
oAuthClient: OAuthResourceClient;
|
|
30
|
+
paymentServer: PaymentServer;
|
|
31
|
+
};
|
|
32
|
+
declare enum TokenProblem {
|
|
33
|
+
NO_TOKEN = "NO-TOKEN",
|
|
34
|
+
NON_BEARER_AUTH_HEADER = "NON-BEARER-AUTH-HEADER",
|
|
35
|
+
INVALID_TOKEN = "INVALID-TOKEN",
|
|
36
|
+
INVALID_AUDIENCE = "INVALID-AUDIENCE",
|
|
37
|
+
NON_SUFFICIENT_FUNDS = "NON-SUFFICIENT-FUNDS",
|
|
38
|
+
INTROSPECT_ERROR = "INTROSPECT-ERROR"
|
|
39
|
+
}
|
|
40
|
+
type TokenCheckPass = {
|
|
41
|
+
passes: true;
|
|
42
|
+
token: string;
|
|
43
|
+
data: TokenData;
|
|
44
|
+
};
|
|
45
|
+
type TokenCheckFail = {
|
|
46
|
+
passes: false;
|
|
47
|
+
problem: TokenProblem;
|
|
48
|
+
token: string | null;
|
|
49
|
+
data: TokenData | null;
|
|
50
|
+
resourceMetadataUrl: string | null;
|
|
51
|
+
};
|
|
52
|
+
type TokenCheck = TokenCheckPass | TokenCheckFail;
|
|
53
|
+
|
|
54
|
+
declare const DESTINATION = "testDestination";
|
|
55
|
+
declare const SOURCE = "testSource";
|
|
56
|
+
declare function charge({ amount, currency, network, destination, source }?: {
|
|
57
|
+
amount?: BigNumber;
|
|
58
|
+
currency?: Currency;
|
|
59
|
+
network?: Network;
|
|
60
|
+
destination?: string;
|
|
61
|
+
source?: string;
|
|
62
|
+
}): Charge;
|
|
63
|
+
declare const oneCentCharge: Charge;
|
|
64
|
+
declare const zeroCharge: Charge;
|
|
65
|
+
declare function logger(): Logger;
|
|
66
|
+
declare function config(args?: Partial<ATXPConfig>): ATXPConfig;
|
|
67
|
+
declare function paymentServer({ charge, createPaymentRequest }?: {
|
|
68
|
+
charge?: vitest.Mock<(...args: any[]) => any> | undefined;
|
|
69
|
+
createPaymentRequest?: vitest.Mock<(...args: any[]) => any> | undefined;
|
|
70
|
+
}): PaymentServer;
|
|
71
|
+
declare function mcpRequest({ method, params, id }?: {
|
|
72
|
+
method?: McpMethod;
|
|
73
|
+
params?: any;
|
|
74
|
+
id?: string;
|
|
75
|
+
}): JSONRPCRequest;
|
|
76
|
+
declare function mcpToolRequest({ toolName, args, }?: {
|
|
77
|
+
toolName?: McpName;
|
|
78
|
+
args?: any;
|
|
79
|
+
}): JSONRPCRequest;
|
|
80
|
+
declare function incomingMessage({ body, method, url, headers }?: {
|
|
81
|
+
body?: any;
|
|
82
|
+
method?: 'POST' | 'GET' | 'PUT' | 'DELETE' | 'PATCH' | 'OPTIONS';
|
|
83
|
+
url?: string;
|
|
84
|
+
headers?: IncomingHttpHeaders;
|
|
85
|
+
}): IncomingMessage;
|
|
86
|
+
declare function incomingToolMessage({ authHeader, url, }?: {
|
|
87
|
+
authHeader?: string;
|
|
88
|
+
url?: string;
|
|
89
|
+
}): IncomingMessage;
|
|
90
|
+
declare function oAuthClient({ introspectResult, authorizationServer }?: {
|
|
91
|
+
introspectResult?: TokenData;
|
|
92
|
+
authorizationServer?: oauth.AuthorizationServer;
|
|
93
|
+
}): OAuthResourceClient;
|
|
94
|
+
declare function tokenData({ active, sub, scope, aud }?: Partial<TokenData>): TokenData;
|
|
95
|
+
declare function tokenCheck({ data, token, passes, problem, resourceMetadataUrl }?: {
|
|
96
|
+
data?: TokenData;
|
|
97
|
+
token?: string | null;
|
|
98
|
+
passes?: boolean;
|
|
99
|
+
problem?: TokenProblem;
|
|
100
|
+
resourceMetadataUrl?: string;
|
|
101
|
+
}): TokenCheck;
|
|
102
|
+
declare function serverResponse(): ServerResponse;
|
|
103
|
+
|
|
104
|
+
export { DESTINATION, SOURCE, charge, config, incomingMessage, incomingToolMessage, logger, mcpRequest, mcpToolRequest, oAuthClient, oneCentCharge, paymentServer, serverResponse, tokenCheck, tokenData, zeroCharge };
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
import { Readable } from 'stream';
|
|
2
|
+
import { MemoryOAuthDb, DEFAULT_AUTHORIZATION_SERVER } from '@atxp/common';
|
|
3
|
+
import { vi } from 'vitest';
|
|
4
|
+
import { BigNumber } from 'bignumber.js';
|
|
5
|
+
|
|
6
|
+
var TokenProblem;
|
|
7
|
+
(function (TokenProblem) {
|
|
8
|
+
TokenProblem["NO_TOKEN"] = "NO-TOKEN";
|
|
9
|
+
TokenProblem["NON_BEARER_AUTH_HEADER"] = "NON-BEARER-AUTH-HEADER";
|
|
10
|
+
TokenProblem["INVALID_TOKEN"] = "INVALID-TOKEN";
|
|
11
|
+
TokenProblem["INVALID_AUDIENCE"] = "INVALID-AUDIENCE";
|
|
12
|
+
TokenProblem["NON_SUFFICIENT_FUNDS"] = "NON-SUFFICIENT-FUNDS";
|
|
13
|
+
TokenProblem["INTROSPECT_ERROR"] = "INTROSPECT-ERROR";
|
|
14
|
+
})(TokenProblem || (TokenProblem = {}));
|
|
15
|
+
|
|
16
|
+
/* eslint-disable @typescript-eslint/no-explicit-any, no-console */
|
|
17
|
+
const DESTINATION = 'testDestination';
|
|
18
|
+
const SOURCE = 'testSource';
|
|
19
|
+
function charge({ amount = BigNumber(0.01), currency = 'USDC', network = 'solana', destination = DESTINATION, source = SOURCE } = {}) {
|
|
20
|
+
return { amount, currency, network, destination, source };
|
|
21
|
+
}
|
|
22
|
+
const oneCentCharge = charge({ amount: BigNumber(0.01) });
|
|
23
|
+
const zeroCharge = charge({ amount: BigNumber(0) });
|
|
24
|
+
function logger() {
|
|
25
|
+
return {
|
|
26
|
+
debug: vi.fn().mockImplementation((msg) => { console.debug(msg); }),
|
|
27
|
+
info: vi.fn().mockImplementation((msg) => { console.info(msg); }),
|
|
28
|
+
warn: vi.fn().mockImplementation((msg) => { console.warn(msg); }),
|
|
29
|
+
error: vi.fn().mockImplementation((msg) => { console.error(msg); }),
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
function config(args = {}) {
|
|
33
|
+
// Create a basic config without using buildServerConfig to avoid circular dependency
|
|
34
|
+
const mockLogger = logger();
|
|
35
|
+
const oAuthDb = args.oAuthDb ?? new MemoryOAuthDb();
|
|
36
|
+
const oAuthClient = args.oAuthClient ?? {
|
|
37
|
+
introspect: vi.fn().mockResolvedValue(tokenData()),
|
|
38
|
+
validateClientCredentials: vi.fn().mockResolvedValue(true),
|
|
39
|
+
extractAccessToken: vi.fn().mockReturnValue('test-token')
|
|
40
|
+
};
|
|
41
|
+
const config = {
|
|
42
|
+
destination: args.destination ?? DESTINATION,
|
|
43
|
+
mountPath: args.mountPath ?? '/',
|
|
44
|
+
currency: args.currency ?? 'USDC',
|
|
45
|
+
network: args.network ?? 'base',
|
|
46
|
+
server: args.server ?? DEFAULT_AUTHORIZATION_SERVER,
|
|
47
|
+
payeeName: args.payeeName ?? 'Test ATXP Server',
|
|
48
|
+
allowHttp: args.allowHttp ?? true,
|
|
49
|
+
resource: args.resource ?? null,
|
|
50
|
+
oAuthDb,
|
|
51
|
+
oAuthClient,
|
|
52
|
+
paymentServer: args.paymentServer ?? paymentServer(),
|
|
53
|
+
logger: args.logger ?? mockLogger,
|
|
54
|
+
...args
|
|
55
|
+
};
|
|
56
|
+
return config;
|
|
57
|
+
}
|
|
58
|
+
function paymentServer({ charge = vi.fn().mockResolvedValue({ success: true, requiredPaymentId: null }), createPaymentRequest = vi.fn().mockResolvedValue('test-payment-request-id') } = {}) {
|
|
59
|
+
return {
|
|
60
|
+
charge,
|
|
61
|
+
createPaymentRequest,
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
function mcpRequest({ method = 'tools/call', params = {}, id = 'call-1' } = {}) {
|
|
65
|
+
return { jsonrpc: "2.0", method, params, id };
|
|
66
|
+
}
|
|
67
|
+
function mcpToolRequest({ toolName = 'testTool', args = { paramOne: 'test' }, } = {}) {
|
|
68
|
+
return mcpRequest({ method: 'tools/call', params: { name: toolName, arguments: args } });
|
|
69
|
+
}
|
|
70
|
+
function incomingMessage({ body = {}, method = 'POST', url = '/', headers = { 'content-type': 'application/json' } } = {}) {
|
|
71
|
+
const bodyString = JSON.stringify(body);
|
|
72
|
+
const stream = new Readable({
|
|
73
|
+
read() {
|
|
74
|
+
this.push(bodyString);
|
|
75
|
+
this.push(null);
|
|
76
|
+
}
|
|
77
|
+
});
|
|
78
|
+
stream.method = method;
|
|
79
|
+
stream.url = url;
|
|
80
|
+
stream.headers = headers;
|
|
81
|
+
return stream;
|
|
82
|
+
}
|
|
83
|
+
function incomingToolMessage({ authHeader = undefined, url = '/', } = {}) {
|
|
84
|
+
return incomingMessage({
|
|
85
|
+
body: mcpToolRequest({ toolName: 'testTool' }),
|
|
86
|
+
headers: { 'authorization': authHeader, 'content-type': 'application/json' },
|
|
87
|
+
url
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
function oAuthClient({ introspectResult = tokenData(), authorizationServer = {
|
|
91
|
+
issuer: 'https://auth.atxp.ai',
|
|
92
|
+
} } = {}) {
|
|
93
|
+
return {
|
|
94
|
+
introspectToken: vi.fn().mockResolvedValue(introspectResult),
|
|
95
|
+
authorizationServerFromUrl: vi.fn().mockResolvedValue(authorizationServer)
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
function tokenData({ active = true, sub = 'test-user', scope = 'tools:read', aud = 'https://example.com' } = {}) {
|
|
99
|
+
return { active, sub, scope, aud };
|
|
100
|
+
}
|
|
101
|
+
function tokenCheck({ data = tokenData(), token = 'test-token', passes = true, problem = TokenProblem.NO_TOKEN, resourceMetadataUrl = 'https://example.com/.well-known/oauth-protected-resource' } = {}) {
|
|
102
|
+
if (passes) {
|
|
103
|
+
return { passes, token, data, };
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
return { passes, token, data, problem, resourceMetadataUrl };
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
function serverResponse() {
|
|
110
|
+
return {
|
|
111
|
+
getHeader: vi.fn(),
|
|
112
|
+
setHeader: vi.fn(),
|
|
113
|
+
writeHead: vi.fn(),
|
|
114
|
+
end: vi.fn(),
|
|
115
|
+
};
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
export { DESTINATION, SOURCE, charge, config, incomingMessage, incomingToolMessage, logger, mcpRequest, mcpToolRequest, oAuthClient, oneCentCharge, paymentServer, serverResponse, tokenCheck, tokenData, zeroCharge };
|
|
119
|
+
//# sourceMappingURL=serverTestHelpers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"serverTestHelpers.js","sources":["../src/types.ts","../src/serverTestHelpers.ts"],"sourcesContent":[null,null],"names":[],"mappings":"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"}
|
package/dist/webapi/mcp.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mcp.js","sources":["../../src/webapi/mcp.ts"],"sourcesContent":[null],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"mcp.js","sources":["../../src/webapi/mcp.ts"],"sourcesContent":[null],"names":[],"mappings":";;AAIA;;;AAGG;AACI,eAAe,sBAAsB,CAC1C,MAAkB,EAClB,OAAgB,EAAA;IAEhB,MAAM,UAAU,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC;AAEvC,IAAA,IAAI;AACF,QAAA,MAAM,IAAI,GAAG,MAAM,OAAO,CAAC,IAAI,EAAE;QACjC,IAAI,CAAC,IAAI,EAAE;AACT,YAAA,OAAO,EAAE;QACX;QAEA,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;;AAGnC,QAAA,OAAO,oBAAoB,CAAC,MAAM,EAAE,UAAU,EAAE,OAAO,CAAC,MAAM,EAAE,UAAU,CAAqB;IACjG;IAAE,OAAO,KAAK,EAAE;QACd,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,8BAA8B,KAAK,YAAY,KAAK,GAAG,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC,KAAK,CAAC,CAAA,CAAE,CAAC;AAC3G,QAAA,OAAO,EAAE;IACX;AACF;;;;"}
|
package/dist/webapi/oauth.js
CHANGED
|
@@ -16,6 +16,28 @@ function sendOAuthChallengeWebApi(tokenCheck) {
|
|
|
16
16
|
headers: responseData.headers
|
|
17
17
|
});
|
|
18
18
|
}
|
|
19
|
+
function sendProtectedResourceMetadata(metadata) {
|
|
20
|
+
if (!metadata) {
|
|
21
|
+
return null;
|
|
22
|
+
}
|
|
23
|
+
return new Response(JSON.stringify(metadata), {
|
|
24
|
+
status: 200,
|
|
25
|
+
headers: {
|
|
26
|
+
'Content-Type': 'application/json'
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
function sendOAuthMetadata(metadata) {
|
|
31
|
+
if (!metadata) {
|
|
32
|
+
return null;
|
|
33
|
+
}
|
|
34
|
+
return new Response(JSON.stringify(metadata), {
|
|
35
|
+
status: 200,
|
|
36
|
+
headers: {
|
|
37
|
+
'Content-Type': 'application/json'
|
|
38
|
+
}
|
|
39
|
+
});
|
|
40
|
+
}
|
|
19
41
|
|
|
20
|
-
export { sendOAuthChallengeWebApi };
|
|
42
|
+
export { sendOAuthChallengeWebApi, sendOAuthMetadata, sendProtectedResourceMetadata };
|
|
21
43
|
//# sourceMappingURL=oauth.js.map
|
package/dist/webapi/oauth.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"oauth.js","sources":["../../src/webapi/oauth.ts"],"sourcesContent":[null],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"oauth.js","sources":["../../src/webapi/oauth.ts"],"sourcesContent":[null],"names":[],"mappings":";;AAIA;;;AAGG;AACG,SAAU,wBAAwB,CAAC,UAAsB,EAAA;;AAE7D,IAAA,MAAM,YAAY,GAAG,gCAAgC,CAAC,UAAU,CAAC;IAEjE,IAAI,CAAC,YAAY,EAAE;AACjB,QAAA,OAAO,IAAI;IACb;;AAGA,IAAA,OAAO,IAAI,QAAQ,CAAC,YAAY,CAAC,IAAI,EAAE;QACrC,MAAM,EAAE,YAAY,CAAC,MAAM;QAC3B,OAAO,EAAE,YAAY,CAAC;AACvB,KAAA,CAAC;AACJ;AAEM,SAAU,6BAA6B,CAAC,QAA0C,EAAA;IACtF,IAAI,CAAC,QAAQ,EAAE;AACb,QAAA,OAAO,IAAI;IACb;IAEA,OAAO,IAAI,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE;AAC5C,QAAA,MAAM,EAAE,GAAG;AACX,QAAA,OAAO,EAAE;AACP,YAAA,cAAc,EAAE;AACjB;AACF,KAAA,CAAC;AACJ;AAEM,SAAU,iBAAiB,CAAC,QAA0C,EAAA;IAC1E,IAAI,CAAC,QAAQ,EAAE;AACb,QAAA,OAAO,IAAI;IACb;IAEA,OAAO,IAAI,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE;AAC5C,QAAA,MAAM,EAAE,GAAG;AACX,QAAA,OAAO,EAAE;AACP,YAAA,cAAc,EAAE;AACjB;AACF,KAAA,CAAC;AACJ;;;;"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@atxp/server",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.4.0",
|
|
4
4
|
"description": "ATXP Server - MCP server implementation with payment processing capabilities",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"repository": {
|
|
@@ -18,6 +18,11 @@
|
|
|
18
18
|
"types": "./dist/index.d.ts",
|
|
19
19
|
"import": "./dist/index.js",
|
|
20
20
|
"require": "./dist/index.cjs"
|
|
21
|
+
},
|
|
22
|
+
"./serverTestHelpers": {
|
|
23
|
+
"types": "./dist/serverTestHelpers.d.ts",
|
|
24
|
+
"import": "./dist/serverTestHelpers.js",
|
|
25
|
+
"require": "./dist/serverTestHelpers.js"
|
|
21
26
|
}
|
|
22
27
|
},
|
|
23
28
|
"files": [
|
|
@@ -33,25 +38,20 @@
|
|
|
33
38
|
"pack:dry": "npm pack --dry-run"
|
|
34
39
|
},
|
|
35
40
|
"dependencies": {
|
|
36
|
-
"@atxp/common": "0.
|
|
41
|
+
"@atxp/common": "0.4.0",
|
|
37
42
|
"@modelcontextprotocol/sdk": "^1.15.0",
|
|
38
43
|
"bignumber.js": "^9.3.0",
|
|
39
|
-
"content-type": "^1.0.5",
|
|
40
44
|
"oauth4webapi": "^3.5.0"
|
|
41
45
|
},
|
|
42
46
|
"peerDependencies": {
|
|
43
|
-
"
|
|
47
|
+
"content-type": "^1.0.5"
|
|
44
48
|
},
|
|
45
49
|
"devDependencies": {
|
|
46
|
-
"@types/express": "^5.0.0",
|
|
47
50
|
"@types/node": "^22.13.0",
|
|
48
|
-
"@types/supertest": "^6.0.3",
|
|
49
51
|
"@typescript-eslint/eslint-plugin": "^8.38.0",
|
|
50
52
|
"@typescript-eslint/parser": "^8.38.0",
|
|
51
53
|
"eslint": "^9.32.0",
|
|
52
|
-
"express": "^5.0.0",
|
|
53
54
|
"node-mocks-http": "^1.17.2",
|
|
54
|
-
"supertest": "^7.1.4",
|
|
55
55
|
"typescript": "^5.7.3",
|
|
56
56
|
"vitest": "^3.0.9"
|
|
57
57
|
}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};
|
|
2
|
-
|
|
3
|
-
function getDefaultExportFromCjs (x) {
|
|
4
|
-
return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, 'default') ? x['default'] : x;
|
|
5
|
-
}
|
|
6
|
-
|
|
7
|
-
export { commonjsGlobal, getDefaultExportFromCjs };
|
|
8
|
-
//# sourceMappingURL=_commonjsHelpers.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"_commonjsHelpers.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"bom-handling.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"dbcs-codec.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
|
package/dist/_virtual/index.js
DELETED
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import { getDefaultExportFromCjs } from './_commonjsHelpers.js';
|
|
2
|
-
import { __require as requireRawBody } from '../node_modules/raw-body/index.js';
|
|
3
|
-
|
|
4
|
-
var rawBodyExports = requireRawBody();
|
|
5
|
-
var getRawBody = /*@__PURE__*/getDefaultExportFromCjs(rawBodyExports);
|
|
6
|
-
|
|
7
|
-
export { getRawBody as default };
|
|
8
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;"}
|
package/dist/_virtual/index2.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index2.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
|
package/dist/_virtual/index3.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index3.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
|
package/dist/_virtual/index4.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index4.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
|