@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.
Files changed (63) hide show
  1. package/dist/es/mcp/base-server.mjs +241 -0
  2. package/dist/es/mcp/base-tools.mjs +84 -0
  3. package/dist/es/mcp/index.mjs +4 -0
  4. package/dist/es/mcp/tool-generator.mjs +215 -0
  5. package/dist/es/mcp/types.mjs +3 -0
  6. package/dist/es/node/fs.mjs +1 -1
  7. package/dist/lib/baseDB.js +2 -2
  8. package/dist/lib/build/copy-static.js +2 -2
  9. package/dist/lib/build/rspack-config.js +2 -2
  10. package/dist/lib/common.js +2 -2
  11. package/dist/lib/constants/example-code.js +2 -2
  12. package/dist/lib/constants/index.js +2 -2
  13. package/dist/lib/env/basic.js +2 -2
  14. package/dist/lib/env/constants.js +2 -2
  15. package/dist/lib/env/global-config-manager.js +2 -2
  16. package/dist/lib/env/helper.js +2 -2
  17. package/dist/lib/env/index.js +6 -6
  18. package/dist/lib/env/init-debug.js +2 -2
  19. package/dist/lib/env/model-config-manager.js +2 -2
  20. package/dist/lib/env/parse-model-config.js +2 -2
  21. package/dist/lib/env/types.js +2 -2
  22. package/dist/lib/env/utils.js +2 -2
  23. package/dist/lib/extractor/constants.js +2 -2
  24. package/dist/lib/extractor/debug.js +1 -1
  25. package/dist/lib/extractor/dom-util.js +2 -2
  26. package/dist/lib/extractor/index.js +2 -2
  27. package/dist/lib/extractor/locator.js +2 -2
  28. package/dist/lib/extractor/tree.js +2 -2
  29. package/dist/lib/extractor/util.js +2 -2
  30. package/dist/lib/extractor/web-extractor.js +2 -2
  31. package/dist/lib/img/box-select.js +2 -2
  32. package/dist/lib/img/draw-box.js +2 -2
  33. package/dist/lib/img/get-jimp.js +2 -2
  34. package/dist/lib/img/get-photon.js +2 -2
  35. package/dist/lib/img/get-sharp.js +2 -2
  36. package/dist/lib/img/index.js +2 -2
  37. package/dist/lib/img/info.js +2 -2
  38. package/dist/lib/img/transform.js +2 -2
  39. package/dist/lib/index.js +2 -2
  40. package/dist/lib/logger.js +2 -2
  41. package/dist/lib/mcp/base-server.js +281 -0
  42. package/dist/lib/mcp/base-tools.js +118 -0
  43. package/dist/lib/mcp/index.js +79 -0
  44. package/dist/lib/mcp/tool-generator.js +252 -0
  45. package/dist/lib/mcp/types.js +40 -0
  46. package/dist/lib/node/fs.js +3 -3
  47. package/dist/lib/node/index.js +2 -2
  48. package/dist/lib/polyfills/async-hooks.js +2 -2
  49. package/dist/lib/polyfills/index.js +2 -2
  50. package/dist/lib/types/index.js +2 -2
  51. package/dist/lib/us-keyboard-layout.js +2 -2
  52. package/dist/lib/utils.js +2 -2
  53. package/dist/types/mcp/base-server.d.ts +77 -0
  54. package/dist/types/mcp/base-tools.d.ts +51 -0
  55. package/dist/types/mcp/index.d.ts +4 -0
  56. package/dist/types/mcp/tool-generator.d.ts +11 -0
  57. package/dist/types/mcp/types.d.ts +98 -0
  58. package/package.json +17 -3
  59. package/src/mcp/base-server.ts +419 -0
  60. package/src/mcp/base-tools.ts +190 -0
  61. package/src/mcp/index.ts +4 -0
  62. package/src/mcp/tool-generator.ts +311 -0
  63. 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 __webpack_i__ in __webpack_exports__)if (-1 === [
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(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
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 __webpack_i__ in __webpack_exports__)exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
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 __webpack_i__ in __webpack_exports__)if (-1 === [
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(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
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 __webpack_i__ in __webpack_exports__)if (-1 === [
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(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
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 __webpack_i__ in __webpack_exports__)if (-1 === [
123
+ for(var __rspack_i in __webpack_exports__)if (-1 === [
124
124
  "getElementInfoByXpath",
125
125
  "getElementXpath",
126
126
  "getNodeInfoByXpath",
127
127
  "getXpathsByPoint"
128
- ].indexOf(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
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 __webpack_i__ in __webpack_exports__)if (-1 === [
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(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
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 __webpack_i__ in __webpack_exports__)if (-1 === [
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(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
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 __webpack_i__ in __webpack_exports__)if (-1 === [
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(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
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 __webpack_i__ in __webpack_exports__)if (-1 === [
226
+ for(var __rspack_i in __webpack_exports__)if (-1 === [
227
227
  "compositeElementInfoImg",
228
228
  "processImageElementInfo"
229
- ].indexOf(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
229
+ ].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
230
230
  Object.defineProperty(exports, '__esModule', {
231
231
  value: true
232
232
  });
@@ -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 __webpack_i__ in __webpack_exports__)if (-1 === [
83
+ for(var __rspack_i in __webpack_exports__)if (-1 === [
84
84
  "drawBoxOnImage",
85
85
  "savePositionImg"
86
- ].indexOf(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
86
+ ].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
87
87
  Object.defineProperty(exports, '__esModule', {
88
88
  value: true
89
89
  });
@@ -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 __webpack_i__ in __webpack_exports__)if (-1 === [
49
+ for(var __rspack_i in __webpack_exports__)if (-1 === [
50
50
  "default"
51
- ].indexOf(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
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 __webpack_i__ in __webpack_exports__)if (-1 === [
48
+ for(var __rspack_i in __webpack_exports__)if (-1 === [
49
49
  "default"
50
- ].indexOf(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
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 __webpack_i__ in __webpack_exports__)if (-1 === [
40
+ for(var __rspack_i in __webpack_exports__)if (-1 === [
41
41
  "default"
42
- ].indexOf(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
42
+ ].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
43
43
  Object.defineProperty(exports, '__esModule', {
44
44
  value: true
45
45
  });
@@ -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 __webpack_i__ in __webpack_exports__)if (-1 === [
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(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
99
+ ].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
100
100
  Object.defineProperty(exports, '__esModule', {
101
101
  value: true
102
102
  });
@@ -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 __webpack_i__ in __webpack_exports__)if (-1 === [
78
+ for(var __rspack_i in __webpack_exports__)if (-1 === [
79
79
  "bufferFromBase64",
80
80
  "imageInfo",
81
81
  "imageInfoOfBase64",
82
82
  "isValidPNGImageBuffer"
83
- ].indexOf(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
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 __webpack_i__ in __webpack_exports__)if (-1 === [
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(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
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 __webpack_i__ in __webpack_exports__)if (-1 === [
39
+ for(var __rspack_i in __webpack_exports__)if (-1 === [
40
40
  "commonIgnoreWarnings",
41
41
  "createCopyStaticPlugin",
42
42
  "createPlaygroundCopyPlugin",
43
43
  "default"
44
- ].indexOf(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
44
+ ].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
45
45
  Object.defineProperty(exports, '__esModule', {
46
46
  value: true
47
47
  });
@@ -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 __webpack_i__ in __webpack_exports__)if (-1 === [
107
+ for(var __rspack_i in __webpack_exports__)if (-1 === [
108
108
  "cleanupLogStreams",
109
109
  "enableDebug",
110
110
  "getDebug"
111
- ].indexOf(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
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
+ });