@midscene/shared 1.0.1-beta-20251208031823.0 → 1.0.1-beta-20251208031856.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/es/mcp/base-server.mjs +241 -0
- package/dist/es/mcp/base-tools.mjs +84 -0
- package/dist/es/mcp/index.mjs +4 -0
- package/dist/es/mcp/tool-generator.mjs +215 -0
- package/dist/es/mcp/types.mjs +3 -0
- package/dist/es/node/fs.mjs +1 -1
- package/dist/lib/baseDB.js +2 -2
- package/dist/lib/build/copy-static.js +2 -2
- package/dist/lib/build/rspack-config.js +2 -2
- package/dist/lib/common.js +2 -2
- package/dist/lib/constants/example-code.js +2 -2
- package/dist/lib/constants/index.js +2 -2
- package/dist/lib/env/basic.js +2 -2
- package/dist/lib/env/constants.js +2 -2
- package/dist/lib/env/global-config-manager.js +2 -2
- package/dist/lib/env/helper.js +2 -2
- package/dist/lib/env/index.js +6 -6
- package/dist/lib/env/init-debug.js +2 -2
- package/dist/lib/env/model-config-manager.js +2 -2
- package/dist/lib/env/parse-model-config.js +2 -2
- package/dist/lib/env/types.js +2 -2
- package/dist/lib/env/utils.js +2 -2
- package/dist/lib/extractor/constants.js +2 -2
- package/dist/lib/extractor/debug.js +1 -1
- package/dist/lib/extractor/dom-util.js +2 -2
- package/dist/lib/extractor/index.js +2 -2
- package/dist/lib/extractor/locator.js +2 -2
- package/dist/lib/extractor/tree.js +2 -2
- package/dist/lib/extractor/util.js +2 -2
- package/dist/lib/extractor/web-extractor.js +2 -2
- package/dist/lib/img/box-select.js +2 -2
- package/dist/lib/img/draw-box.js +2 -2
- package/dist/lib/img/get-jimp.js +2 -2
- package/dist/lib/img/get-photon.js +2 -2
- package/dist/lib/img/get-sharp.js +2 -2
- package/dist/lib/img/index.js +2 -2
- package/dist/lib/img/info.js +2 -2
- package/dist/lib/img/transform.js +2 -2
- package/dist/lib/index.js +2 -2
- package/dist/lib/logger.js +2 -2
- package/dist/lib/mcp/base-server.js +281 -0
- package/dist/lib/mcp/base-tools.js +118 -0
- package/dist/lib/mcp/index.js +79 -0
- package/dist/lib/mcp/tool-generator.js +252 -0
- package/dist/lib/mcp/types.js +40 -0
- package/dist/lib/node/fs.js +3 -3
- package/dist/lib/node/index.js +2 -2
- package/dist/lib/polyfills/async-hooks.js +2 -2
- package/dist/lib/polyfills/index.js +2 -2
- package/dist/lib/types/index.js +2 -2
- package/dist/lib/us-keyboard-layout.js +2 -2
- package/dist/lib/utils.js +2 -2
- package/dist/types/mcp/base-server.d.ts +77 -0
- package/dist/types/mcp/base-tools.d.ts +51 -0
- package/dist/types/mcp/index.d.ts +4 -0
- package/dist/types/mcp/tool-generator.d.ts +11 -0
- package/dist/types/mcp/types.d.ts +98 -0
- package/package.json +17 -3
- package/src/mcp/base-server.ts +419 -0
- package/src/mcp/base-tools.ts +190 -0
- package/src/mcp/index.ts +4 -0
- package/src/mcp/tool-generator.ts +311 -0
- package/src/mcp/types.ts +106 -0
|
@@ -32,11 +32,11 @@ const index_js_namespaceObject = require("../constants/index.js");
|
|
|
32
32
|
exports.NodeType = __webpack_exports__.NodeType;
|
|
33
33
|
exports.TEXT_MAX_SIZE = __webpack_exports__.TEXT_MAX_SIZE;
|
|
34
34
|
exports.TEXT_SIZE_THRESHOLD = __webpack_exports__.TEXT_SIZE_THRESHOLD;
|
|
35
|
-
for(var
|
|
35
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
36
36
|
"NodeType",
|
|
37
37
|
"TEXT_MAX_SIZE",
|
|
38
38
|
"TEXT_SIZE_THRESHOLD"
|
|
39
|
-
].indexOf(
|
|
39
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
40
40
|
Object.defineProperty(exports, '__esModule', {
|
|
41
41
|
value: true
|
|
42
42
|
});
|
|
@@ -6,7 +6,7 @@ console.log((0, external_index_js_namespaceObject.webExtractTextWithPosition)(do
|
|
|
6
6
|
console.log(JSON.stringify((0, external_index_js_namespaceObject.webExtractTextWithPosition)(document.body, true)));
|
|
7
7
|
(0, external_util_js_namespaceObject.setExtractTextWithPositionOnWindow)();
|
|
8
8
|
(0, external_util_js_namespaceObject.setMidsceneVisibleRectOnWindow)();
|
|
9
|
-
for(var
|
|
9
|
+
for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
10
10
|
Object.defineProperty(exports, '__esModule', {
|
|
11
11
|
value: true
|
|
12
12
|
});
|
|
@@ -126,7 +126,7 @@ exports.isImgElement = __webpack_exports__.isImgElement;
|
|
|
126
126
|
exports.isNotContainerElement = __webpack_exports__.isNotContainerElement;
|
|
127
127
|
exports.isSvgElement = __webpack_exports__.isSvgElement;
|
|
128
128
|
exports.isTextElement = __webpack_exports__.isTextElement;
|
|
129
|
-
for(var
|
|
129
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
130
130
|
"generateElementByPosition",
|
|
131
131
|
"isAElement",
|
|
132
132
|
"isButtonElement",
|
|
@@ -136,7 +136,7 @@ for(var __webpack_i__ in __webpack_exports__)if (-1 === [
|
|
|
136
136
|
"isNotContainerElement",
|
|
137
137
|
"isSvgElement",
|
|
138
138
|
"isTextElement"
|
|
139
|
-
].indexOf(
|
|
139
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
140
140
|
Object.defineProperty(exports, '__esModule', {
|
|
141
141
|
value: true
|
|
142
142
|
});
|
|
@@ -57,7 +57,7 @@ exports.truncateText = __webpack_exports__.truncateText;
|
|
|
57
57
|
exports.webExtractNodeTree = __webpack_exports__.webExtractNodeTree;
|
|
58
58
|
exports.webExtractNodeTreeAsString = __webpack_exports__.webExtractNodeTreeAsString;
|
|
59
59
|
exports.webExtractTextWithPosition = __webpack_exports__.webExtractTextWithPosition;
|
|
60
|
-
for(var
|
|
60
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
61
61
|
"descriptionOfTree",
|
|
62
62
|
"generateElementByPosition",
|
|
63
63
|
"getElementInfoByXpath",
|
|
@@ -72,7 +72,7 @@ for(var __webpack_i__ in __webpack_exports__)if (-1 === [
|
|
|
72
72
|
"webExtractNodeTree",
|
|
73
73
|
"webExtractNodeTreeAsString",
|
|
74
74
|
"webExtractTextWithPosition"
|
|
75
|
-
].indexOf(
|
|
75
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
76
76
|
Object.defineProperty(exports, '__esModule', {
|
|
77
77
|
value: true
|
|
78
78
|
});
|
|
@@ -120,12 +120,12 @@ exports.getElementInfoByXpath = __webpack_exports__.getElementInfoByXpath;
|
|
|
120
120
|
exports.getElementXpath = __webpack_exports__.getElementXpath;
|
|
121
121
|
exports.getNodeInfoByXpath = __webpack_exports__.getNodeInfoByXpath;
|
|
122
122
|
exports.getXpathsByPoint = __webpack_exports__.getXpathsByPoint;
|
|
123
|
-
for(var
|
|
123
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
124
124
|
"getElementInfoByXpath",
|
|
125
125
|
"getElementXpath",
|
|
126
126
|
"getNodeInfoByXpath",
|
|
127
127
|
"getXpathsByPoint"
|
|
128
|
-
].indexOf(
|
|
128
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
129
129
|
Object.defineProperty(exports, '__esModule', {
|
|
130
130
|
value: true
|
|
131
131
|
});
|
|
@@ -112,13 +112,13 @@ exports.traverseTree = __webpack_exports__.traverseTree;
|
|
|
112
112
|
exports.treeToList = __webpack_exports__.treeToList;
|
|
113
113
|
exports.trimAttributes = __webpack_exports__.trimAttributes;
|
|
114
114
|
exports.truncateText = __webpack_exports__.truncateText;
|
|
115
|
-
for(var
|
|
115
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
116
116
|
"descriptionOfTree",
|
|
117
117
|
"traverseTree",
|
|
118
118
|
"treeToList",
|
|
119
119
|
"trimAttributes",
|
|
120
120
|
"truncateText"
|
|
121
|
-
].indexOf(
|
|
121
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
122
122
|
Object.defineProperty(exports, '__esModule', {
|
|
123
123
|
value: true
|
|
124
124
|
});
|
|
@@ -278,7 +278,7 @@ exports.setExtractTextWithPositionOnWindow = __webpack_exports__.setExtractTextW
|
|
|
278
278
|
exports.setGenerateHashOnWindow = __webpack_exports__.setGenerateHashOnWindow;
|
|
279
279
|
exports.setMidsceneVisibleRectOnWindow = __webpack_exports__.setMidsceneVisibleRectOnWindow;
|
|
280
280
|
exports.validTextNodeContent = __webpack_exports__.validTextNodeContent;
|
|
281
|
-
for(var
|
|
281
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
282
282
|
"elementRect",
|
|
283
283
|
"generateId",
|
|
284
284
|
"getDebugMode",
|
|
@@ -296,7 +296,7 @@ for(var __webpack_i__ in __webpack_exports__)if (-1 === [
|
|
|
296
296
|
"setGenerateHashOnWindow",
|
|
297
297
|
"setMidsceneVisibleRectOnWindow",
|
|
298
298
|
"validTextNodeContent"
|
|
299
|
-
].indexOf(
|
|
299
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
300
300
|
Object.defineProperty(exports, '__esModule', {
|
|
301
301
|
value: true
|
|
302
302
|
});
|
|
@@ -337,13 +337,13 @@ exports.extractTextWithPosition = __webpack_exports__.extractTextWithPosition;
|
|
|
337
337
|
exports.extractTreeNode = __webpack_exports__.extractTreeNode;
|
|
338
338
|
exports.extractTreeNodeAsString = __webpack_exports__.extractTreeNodeAsString;
|
|
339
339
|
exports.mergeElementAndChildrenRects = __webpack_exports__.mergeElementAndChildrenRects;
|
|
340
|
-
for(var
|
|
340
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
341
341
|
"collectElementInfo",
|
|
342
342
|
"extractTextWithPosition",
|
|
343
343
|
"extractTreeNode",
|
|
344
344
|
"extractTreeNodeAsString",
|
|
345
345
|
"mergeElementAndChildrenRects"
|
|
346
|
-
].indexOf(
|
|
346
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
347
347
|
Object.defineProperty(exports, '__esModule', {
|
|
348
348
|
value: true
|
|
349
349
|
});
|
|
@@ -223,10 +223,10 @@ const processImageElementInfo = async (options)=>{
|
|
|
223
223
|
};
|
|
224
224
|
exports.compositeElementInfoImg = __webpack_exports__.compositeElementInfoImg;
|
|
225
225
|
exports.processImageElementInfo = __webpack_exports__.processImageElementInfo;
|
|
226
|
-
for(var
|
|
226
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
227
227
|
"compositeElementInfoImg",
|
|
228
228
|
"processImageElementInfo"
|
|
229
|
-
].indexOf(
|
|
229
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
230
230
|
Object.defineProperty(exports, '__esModule', {
|
|
231
231
|
value: true
|
|
232
232
|
});
|
package/dist/lib/img/draw-box.js
CHANGED
|
@@ -80,10 +80,10 @@ async function savePositionImg(options) {
|
|
|
80
80
|
}
|
|
81
81
|
exports.drawBoxOnImage = __webpack_exports__.drawBoxOnImage;
|
|
82
82
|
exports.savePositionImg = __webpack_exports__.savePositionImg;
|
|
83
|
-
for(var
|
|
83
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
84
84
|
"drawBoxOnImage",
|
|
85
85
|
"savePositionImg"
|
|
86
|
-
].indexOf(
|
|
86
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
87
87
|
Object.defineProperty(exports, '__esModule', {
|
|
88
88
|
value: true
|
|
89
89
|
});
|
package/dist/lib/img/get-jimp.js
CHANGED
|
@@ -46,9 +46,9 @@ async function getJimp() {
|
|
|
46
46
|
return external_jimp_default();
|
|
47
47
|
}
|
|
48
48
|
exports["default"] = __webpack_exports__["default"];
|
|
49
|
-
for(var
|
|
49
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
50
50
|
"default"
|
|
51
|
-
].indexOf(
|
|
51
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
52
52
|
Object.defineProperty(exports, '__esModule', {
|
|
53
53
|
value: true
|
|
54
54
|
});
|
|
@@ -45,9 +45,9 @@ async function getPhoton() {
|
|
|
45
45
|
}
|
|
46
46
|
}
|
|
47
47
|
exports["default"] = __webpack_exports__["default"];
|
|
48
|
-
for(var
|
|
48
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
49
49
|
"default"
|
|
50
|
-
].indexOf(
|
|
50
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
51
51
|
Object.defineProperty(exports, '__esModule', {
|
|
52
52
|
value: true
|
|
53
53
|
});
|
|
@@ -37,9 +37,9 @@ async function getSharp() {
|
|
|
37
37
|
}
|
|
38
38
|
}
|
|
39
39
|
exports["default"] = __webpack_exports__["default"];
|
|
40
|
-
for(var
|
|
40
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
41
41
|
"default"
|
|
42
|
-
].indexOf(
|
|
42
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
43
43
|
Object.defineProperty(exports, '__esModule', {
|
|
44
44
|
value: true
|
|
45
45
|
});
|
package/dist/lib/img/index.js
CHANGED
|
@@ -73,7 +73,7 @@ exports.resizeImgBase64 = __webpack_exports__.resizeImgBase64;
|
|
|
73
73
|
exports.saveBase64Image = __webpack_exports__.saveBase64Image;
|
|
74
74
|
exports.savePositionImg = __webpack_exports__.savePositionImg;
|
|
75
75
|
exports.zoomForGPT4o = __webpack_exports__.zoomForGPT4o;
|
|
76
|
-
for(var
|
|
76
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
77
77
|
"bufferFromBase64",
|
|
78
78
|
"compositeElementInfoImg",
|
|
79
79
|
"createImgBase64ByFormat",
|
|
@@ -96,7 +96,7 @@ for(var __webpack_i__ in __webpack_exports__)if (-1 === [
|
|
|
96
96
|
"saveBase64Image",
|
|
97
97
|
"savePositionImg",
|
|
98
98
|
"zoomForGPT4o"
|
|
99
|
-
].indexOf(
|
|
99
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
100
100
|
Object.defineProperty(exports, '__esModule', {
|
|
101
101
|
value: true
|
|
102
102
|
});
|
package/dist/lib/img/info.js
CHANGED
|
@@ -75,12 +75,12 @@ exports.bufferFromBase64 = __webpack_exports__.bufferFromBase64;
|
|
|
75
75
|
exports.imageInfo = __webpack_exports__.imageInfo;
|
|
76
76
|
exports.imageInfoOfBase64 = __webpack_exports__.imageInfoOfBase64;
|
|
77
77
|
exports.isValidPNGImageBuffer = __webpack_exports__.isValidPNGImageBuffer;
|
|
78
|
-
for(var
|
|
78
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
79
79
|
"bufferFromBase64",
|
|
80
80
|
"imageInfo",
|
|
81
81
|
"imageInfoOfBase64",
|
|
82
82
|
"isValidPNGImageBuffer"
|
|
83
|
-
].indexOf(
|
|
83
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
84
84
|
Object.defineProperty(exports, '__esModule', {
|
|
85
85
|
value: true
|
|
86
86
|
});
|
|
@@ -258,7 +258,7 @@ exports.resizeAndConvertImgBuffer = __webpack_exports__.resizeAndConvertImgBuffe
|
|
|
258
258
|
exports.resizeImgBase64 = __webpack_exports__.resizeImgBase64;
|
|
259
259
|
exports.saveBase64Image = __webpack_exports__.saveBase64Image;
|
|
260
260
|
exports.zoomForGPT4o = __webpack_exports__.zoomForGPT4o;
|
|
261
|
-
for(var
|
|
261
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
262
262
|
"createImgBase64ByFormat",
|
|
263
263
|
"cropByRect",
|
|
264
264
|
"httpImg2Base64",
|
|
@@ -273,7 +273,7 @@ for(var __webpack_i__ in __webpack_exports__)if (-1 === [
|
|
|
273
273
|
"resizeImgBase64",
|
|
274
274
|
"saveBase64Image",
|
|
275
275
|
"zoomForGPT4o"
|
|
276
|
-
].indexOf(
|
|
276
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
277
277
|
Object.defineProperty(exports, '__esModule', {
|
|
278
278
|
value: true
|
|
279
279
|
});
|
package/dist/lib/index.js
CHANGED
|
@@ -36,12 +36,12 @@ exports.commonIgnoreWarnings = __webpack_exports__.commonIgnoreWarnings;
|
|
|
36
36
|
exports.createCopyStaticPlugin = __webpack_exports__.createCopyStaticPlugin;
|
|
37
37
|
exports.createPlaygroundCopyPlugin = __webpack_exports__.createPlaygroundCopyPlugin;
|
|
38
38
|
exports["default"] = __webpack_exports__["default"];
|
|
39
|
-
for(var
|
|
39
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
40
40
|
"commonIgnoreWarnings",
|
|
41
41
|
"createCopyStaticPlugin",
|
|
42
42
|
"createPlaygroundCopyPlugin",
|
|
43
43
|
"default"
|
|
44
|
-
].indexOf(
|
|
44
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
45
45
|
Object.defineProperty(exports, '__esModule', {
|
|
46
46
|
value: true
|
|
47
47
|
});
|
package/dist/lib/logger.js
CHANGED
|
@@ -104,11 +104,11 @@ function cleanupLogStreams() {
|
|
|
104
104
|
exports.cleanupLogStreams = __webpack_exports__.cleanupLogStreams;
|
|
105
105
|
exports.enableDebug = __webpack_exports__.enableDebug;
|
|
106
106
|
exports.getDebug = __webpack_exports__.getDebug;
|
|
107
|
-
for(var
|
|
107
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
108
108
|
"cleanupLogStreams",
|
|
109
109
|
"enableDebug",
|
|
110
110
|
"getDebug"
|
|
111
|
-
].indexOf(
|
|
111
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
112
112
|
Object.defineProperty(exports, '__esModule', {
|
|
113
113
|
value: true
|
|
114
114
|
});
|
|
@@ -0,0 +1,281 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __webpack_require__ = {};
|
|
3
|
+
(()=>{
|
|
4
|
+
__webpack_require__.d = (exports1, definition)=>{
|
|
5
|
+
for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: definition[key]
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
})();
|
|
11
|
+
(()=>{
|
|
12
|
+
__webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
|
|
13
|
+
})();
|
|
14
|
+
(()=>{
|
|
15
|
+
__webpack_require__.r = (exports1)=>{
|
|
16
|
+
if ('undefined' != typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
|
|
17
|
+
value: 'Module'
|
|
18
|
+
});
|
|
19
|
+
Object.defineProperty(exports1, '__esModule', {
|
|
20
|
+
value: true
|
|
21
|
+
});
|
|
22
|
+
};
|
|
23
|
+
})();
|
|
24
|
+
var __webpack_exports__ = {};
|
|
25
|
+
__webpack_require__.r(__webpack_exports__);
|
|
26
|
+
__webpack_require__.d(__webpack_exports__, {
|
|
27
|
+
CLI_ARGS_CONFIG: ()=>CLI_ARGS_CONFIG,
|
|
28
|
+
launchMCPServer: ()=>launchMCPServer,
|
|
29
|
+
BaseMCPServer: ()=>BaseMCPServer
|
|
30
|
+
});
|
|
31
|
+
const external_node_crypto_namespaceObject = require("node:crypto");
|
|
32
|
+
const utils_namespaceObject = require("@midscene/shared/utils");
|
|
33
|
+
const mcp_js_namespaceObject = require("@modelcontextprotocol/sdk/server/mcp.js");
|
|
34
|
+
const stdio_js_namespaceObject = require("@modelcontextprotocol/sdk/server/stdio.js");
|
|
35
|
+
const streamableHttp_js_namespaceObject = require("@modelcontextprotocol/sdk/server/streamableHttp.js");
|
|
36
|
+
function _define_property(obj, key, value) {
|
|
37
|
+
if (key in obj) Object.defineProperty(obj, key, {
|
|
38
|
+
value: value,
|
|
39
|
+
enumerable: true,
|
|
40
|
+
configurable: true,
|
|
41
|
+
writable: true
|
|
42
|
+
});
|
|
43
|
+
else obj[key] = value;
|
|
44
|
+
return obj;
|
|
45
|
+
}
|
|
46
|
+
const CLI_ARGS_CONFIG = {
|
|
47
|
+
mode: {
|
|
48
|
+
type: 'string',
|
|
49
|
+
default: 'stdio'
|
|
50
|
+
},
|
|
51
|
+
port: {
|
|
52
|
+
type: 'string',
|
|
53
|
+
default: '3000'
|
|
54
|
+
},
|
|
55
|
+
host: {
|
|
56
|
+
type: 'string',
|
|
57
|
+
default: 'localhost'
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
function launchMCPServer(server, args) {
|
|
61
|
+
if ('http' === args.mode) return server.launchHttp({
|
|
62
|
+
port: Number.parseInt(args.port || '3000', 10),
|
|
63
|
+
host: args.host || 'localhost'
|
|
64
|
+
});
|
|
65
|
+
return server.launch();
|
|
66
|
+
}
|
|
67
|
+
const SESSION_TIMEOUT_MS = 1800000;
|
|
68
|
+
const CLEANUP_INTERVAL_MS = 300000;
|
|
69
|
+
const MAX_SESSIONS = 100;
|
|
70
|
+
class BaseMCPServer {
|
|
71
|
+
async initializeToolsManager() {
|
|
72
|
+
(0, utils_namespaceObject.setIsMcp)(true);
|
|
73
|
+
this.toolsManager = this.createToolsManager();
|
|
74
|
+
try {
|
|
75
|
+
await this.toolsManager.initTools();
|
|
76
|
+
} catch (error) {
|
|
77
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
78
|
+
console.error(`Failed to initialize tools: ${message}`);
|
|
79
|
+
console.error('Tools will be initialized on first use');
|
|
80
|
+
}
|
|
81
|
+
this.toolsManager.attachToServer(this.mcpServer);
|
|
82
|
+
}
|
|
83
|
+
performCleanup() {
|
|
84
|
+
console.error(`${this.config.name} closing...`);
|
|
85
|
+
this.mcpServer.close();
|
|
86
|
+
this.toolsManager?.closeBrowser?.().catch(console.error);
|
|
87
|
+
}
|
|
88
|
+
async launch() {
|
|
89
|
+
await this.initializeToolsManager();
|
|
90
|
+
const transport = new stdio_js_namespaceObject.StdioServerTransport();
|
|
91
|
+
try {
|
|
92
|
+
await this.mcpServer.connect(transport);
|
|
93
|
+
} catch (error) {
|
|
94
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
95
|
+
console.error(`Failed to connect MCP stdio transport: ${message}`);
|
|
96
|
+
throw new Error(`Failed to initialize MCP stdio transport: ${message}`);
|
|
97
|
+
}
|
|
98
|
+
process.on('uncaughtException', (error)=>{
|
|
99
|
+
console.error(`[${this.config.name}] Uncaught Exception:`, error);
|
|
100
|
+
console.error('Stack:', error.stack);
|
|
101
|
+
});
|
|
102
|
+
process.on('unhandledRejection', (reason)=>{
|
|
103
|
+
console.error(`[${this.config.name}] Unhandled Rejection:`, reason);
|
|
104
|
+
if (reason instanceof Error) console.error('Stack:', reason.stack);
|
|
105
|
+
});
|
|
106
|
+
process.stdin.on('close', ()=>this.performCleanup());
|
|
107
|
+
const cleanup = ()=>{
|
|
108
|
+
console.error(`${this.config.name} shutting down...`);
|
|
109
|
+
this.performCleanup();
|
|
110
|
+
process.exit(0);
|
|
111
|
+
};
|
|
112
|
+
process.once('SIGINT', cleanup);
|
|
113
|
+
process.once('SIGTERM', cleanup);
|
|
114
|
+
}
|
|
115
|
+
async launchHttp(options) {
|
|
116
|
+
if (!Number.isInteger(options.port) || options.port < 1 || options.port > 65535) throw new Error(`Invalid port number: ${options.port}. Port must be between 1 and 65535.`);
|
|
117
|
+
await this.initializeToolsManager();
|
|
118
|
+
const express = await import("express");
|
|
119
|
+
const app = express.default();
|
|
120
|
+
app.use(express.default.json({
|
|
121
|
+
limit: '10mb'
|
|
122
|
+
}));
|
|
123
|
+
const sessions = new Map();
|
|
124
|
+
app.all('/mcp', async (req, res)=>{
|
|
125
|
+
const startTime = Date.now();
|
|
126
|
+
const requestId = (0, external_node_crypto_namespaceObject.randomUUID)().substring(0, 8);
|
|
127
|
+
try {
|
|
128
|
+
const rawSessionId = req.headers['mcp-session-id'];
|
|
129
|
+
const sessionId = Array.isArray(rawSessionId) ? rawSessionId[0] : rawSessionId;
|
|
130
|
+
let session = sessionId ? sessions.get(sessionId) : void 0;
|
|
131
|
+
if (!session && 'POST' === req.method) {
|
|
132
|
+
if (sessions.size >= MAX_SESSIONS) {
|
|
133
|
+
console.error(`[${new Date().toISOString()}] [${requestId}] Session limit reached: ${sessions.size}/${MAX_SESSIONS}`);
|
|
134
|
+
res.status(503).json({
|
|
135
|
+
error: 'Too many active sessions',
|
|
136
|
+
message: 'Server is at maximum capacity. Please try again later.'
|
|
137
|
+
});
|
|
138
|
+
return;
|
|
139
|
+
}
|
|
140
|
+
session = await this.createHttpSession(sessions);
|
|
141
|
+
console.log(`[${new Date().toISOString()}] [${requestId}] New session created: ${session.transport.sessionId}`);
|
|
142
|
+
}
|
|
143
|
+
if (session) {
|
|
144
|
+
session.lastAccessedAt = new Date();
|
|
145
|
+
await session.transport.handleRequest(req, res, req.body);
|
|
146
|
+
const duration = Date.now() - startTime;
|
|
147
|
+
console.log(`[${new Date().toISOString()}] [${requestId}] Request completed in ${duration}ms`);
|
|
148
|
+
} else {
|
|
149
|
+
console.error(`[${new Date().toISOString()}] [${requestId}] Invalid session or GET without session`);
|
|
150
|
+
res.status(400).json({
|
|
151
|
+
error: 'Invalid session or GET without session'
|
|
152
|
+
});
|
|
153
|
+
}
|
|
154
|
+
} catch (error) {
|
|
155
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
156
|
+
const duration = Date.now() - startTime;
|
|
157
|
+
console.error(`[${new Date().toISOString()}] [${requestId}] MCP request error after ${duration}ms: ${message}`);
|
|
158
|
+
if (!res.headersSent) res.status(500).json({
|
|
159
|
+
error: 'Internal server error',
|
|
160
|
+
message: 'Failed to process MCP request'
|
|
161
|
+
});
|
|
162
|
+
}
|
|
163
|
+
});
|
|
164
|
+
const host = options.host || 'localhost';
|
|
165
|
+
const server = app.listen(options.port, host, ()=>{
|
|
166
|
+
console.log(`${this.config.name} HTTP server listening on http://${host}:${options.port}/mcp`);
|
|
167
|
+
}).on('error', (error)=>{
|
|
168
|
+
if ('EADDRINUSE' === error.code) console.error(`ERROR: Port ${options.port} is already in use.\nPlease try a different port: --port=<number>\nExample: --mode=http --port=${options.port + 1}`);
|
|
169
|
+
else if ('EACCES' === error.code) console.error(`ERROR: Permission denied to bind to port ${options.port}.\nPorts below 1024 require root/admin privileges.\nPlease use a port above 1024 or run with elevated privileges.`);
|
|
170
|
+
else console.error(`ERROR: Failed to start HTTP server on ${host}:${options.port}\nReason: ${error.message}\nCode: ${error.code || 'unknown'}`);
|
|
171
|
+
process.exit(1);
|
|
172
|
+
});
|
|
173
|
+
const cleanupInterval = this.startSessionCleanup(sessions);
|
|
174
|
+
this.setupHttpShutdownHandlers(server, sessions, cleanupInterval);
|
|
175
|
+
}
|
|
176
|
+
async createHttpSession(sessions) {
|
|
177
|
+
const transport = new streamableHttp_js_namespaceObject.StreamableHTTPServerTransport({
|
|
178
|
+
sessionIdGenerator: ()=>(0, external_node_crypto_namespaceObject.randomUUID)(),
|
|
179
|
+
onsessioninitialized: (sid)=>{
|
|
180
|
+
sessions.set(sid, {
|
|
181
|
+
transport,
|
|
182
|
+
createdAt: new Date(),
|
|
183
|
+
lastAccessedAt: new Date()
|
|
184
|
+
});
|
|
185
|
+
console.log(`[${new Date().toISOString()}] Session ${sid} initialized (total: ${sessions.size})`);
|
|
186
|
+
}
|
|
187
|
+
});
|
|
188
|
+
transport.onclose = ()=>{
|
|
189
|
+
if (transport.sessionId) {
|
|
190
|
+
sessions.delete(transport.sessionId);
|
|
191
|
+
console.log(`[${new Date().toISOString()}] Session ${transport.sessionId} closed (remaining: ${sessions.size})`);
|
|
192
|
+
}
|
|
193
|
+
};
|
|
194
|
+
try {
|
|
195
|
+
await this.mcpServer.connect(transport);
|
|
196
|
+
} catch (error) {
|
|
197
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
198
|
+
console.error(`[${new Date().toISOString()}] Failed to connect MCP transport: ${message}`);
|
|
199
|
+
if (transport.sessionId) sessions.delete(transport.sessionId);
|
|
200
|
+
throw new Error(`Failed to initialize MCP session: ${message}`);
|
|
201
|
+
}
|
|
202
|
+
return {
|
|
203
|
+
transport,
|
|
204
|
+
createdAt: new Date(),
|
|
205
|
+
lastAccessedAt: new Date()
|
|
206
|
+
};
|
|
207
|
+
}
|
|
208
|
+
startSessionCleanup(sessions) {
|
|
209
|
+
return setInterval(()=>{
|
|
210
|
+
const now = Date.now();
|
|
211
|
+
for (const [sid, session] of sessions)if (now - session.lastAccessedAt.getTime() > SESSION_TIMEOUT_MS) try {
|
|
212
|
+
session.transport.close();
|
|
213
|
+
sessions.delete(sid);
|
|
214
|
+
console.log(`[${new Date().toISOString()}] Session ${sid} cleaned up due to inactivity (remaining: ${sessions.size})`);
|
|
215
|
+
} catch (error) {
|
|
216
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
217
|
+
console.error(`[${new Date().toISOString()}] Failed to close session ${sid} during cleanup: ${message}`);
|
|
218
|
+
sessions.delete(sid);
|
|
219
|
+
}
|
|
220
|
+
}, CLEANUP_INTERVAL_MS);
|
|
221
|
+
}
|
|
222
|
+
setupHttpShutdownHandlers(server, sessions, cleanupInterval) {
|
|
223
|
+
const cleanup = ()=>{
|
|
224
|
+
console.error(`${this.config.name} shutting down...`);
|
|
225
|
+
clearInterval(cleanupInterval);
|
|
226
|
+
for (const session of sessions.values())try {
|
|
227
|
+
session.transport.close();
|
|
228
|
+
} catch (error) {
|
|
229
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
230
|
+
console.error(`Error closing session during shutdown: ${message}`);
|
|
231
|
+
}
|
|
232
|
+
sessions.clear();
|
|
233
|
+
try {
|
|
234
|
+
server.close(()=>{
|
|
235
|
+
this.performCleanup();
|
|
236
|
+
process.exit(0);
|
|
237
|
+
});
|
|
238
|
+
setTimeout(()=>{
|
|
239
|
+
console.error('Forcefully shutting down after timeout');
|
|
240
|
+
this.performCleanup();
|
|
241
|
+
process.exit(1);
|
|
242
|
+
}, 5000);
|
|
243
|
+
} catch (error) {
|
|
244
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
245
|
+
console.error(`Error closing HTTP server: ${message}`);
|
|
246
|
+
this.performCleanup();
|
|
247
|
+
process.exit(1);
|
|
248
|
+
}
|
|
249
|
+
};
|
|
250
|
+
process.once('SIGINT', cleanup);
|
|
251
|
+
process.once('SIGTERM', cleanup);
|
|
252
|
+
}
|
|
253
|
+
getServer() {
|
|
254
|
+
return this.mcpServer;
|
|
255
|
+
}
|
|
256
|
+
getToolsManager() {
|
|
257
|
+
return this.toolsManager;
|
|
258
|
+
}
|
|
259
|
+
constructor(config){
|
|
260
|
+
_define_property(this, "mcpServer", void 0);
|
|
261
|
+
_define_property(this, "toolsManager", void 0);
|
|
262
|
+
_define_property(this, "config", void 0);
|
|
263
|
+
this.config = config;
|
|
264
|
+
this.mcpServer = new mcp_js_namespaceObject.McpServer({
|
|
265
|
+
name: config.name,
|
|
266
|
+
version: config.version,
|
|
267
|
+
description: config.description
|
|
268
|
+
});
|
|
269
|
+
}
|
|
270
|
+
}
|
|
271
|
+
exports.BaseMCPServer = __webpack_exports__.BaseMCPServer;
|
|
272
|
+
exports.CLI_ARGS_CONFIG = __webpack_exports__.CLI_ARGS_CONFIG;
|
|
273
|
+
exports.launchMCPServer = __webpack_exports__.launchMCPServer;
|
|
274
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
275
|
+
"BaseMCPServer",
|
|
276
|
+
"CLI_ARGS_CONFIG",
|
|
277
|
+
"launchMCPServer"
|
|
278
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
279
|
+
Object.defineProperty(exports, '__esModule', {
|
|
280
|
+
value: true
|
|
281
|
+
});
|