mcp-use 1.10.1-canary.1 → 1.10.1-canary.2
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/.tsbuildinfo +1 -1
- package/dist/{chunk-NS7PNUAI.js → chunk-4NC7PPVE.js} +1 -1
- package/dist/{chunk-BXYYBPWE.js → chunk-CFX74U7W.js} +2 -2
- package/dist/{chunk-3WQPXSMB.js → chunk-FAELBZOW.js} +1 -1
- package/dist/{chunk-BO2DLS2U.js → chunk-KFTQ3UL5.js} +2 -2
- package/dist/{chunk-K6EZ46MT.js → chunk-OTZ32HGI.js} +1 -1
- package/dist/{chunk-IVXE5QZD.js → chunk-QNZMNQCY.js} +1 -1
- package/dist/{chunk-ES5N2BQY.js → chunk-VTNHO2TS.js} +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.js +6 -6
- package/dist/src/agents/index.cjs +1 -1
- package/dist/src/agents/index.js +4 -4
- package/dist/src/browser.cjs +1 -1
- package/dist/src/browser.js +4 -4
- package/dist/src/client/prompts.js +3 -3
- package/dist/src/react/index.cjs +1 -1
- package/dist/src/react/index.js +4 -4
- package/dist/src/server/endpoints/mount-mcp.d.ts.map +1 -1
- package/dist/src/server/index.cjs +23 -3
- package/dist/src/server/index.js +27 -7
- package/dist/src/server/sessions/session-manager.d.ts +6 -3
- package/dist/src/server/sessions/session-manager.d.ts.map +1 -1
- package/dist/src/version.d.ts +1 -1
- package/dist/{tool-execution-helpers-G74FG2CI.js → tool-execution-helpers-PQGEPYY3.js} +2 -2
- package/package.json +3 -3
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
import {
|
|
2
2
|
BrowserMCPClient
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-KFTQ3UL5.js";
|
|
4
4
|
import {
|
|
5
5
|
BrowserOAuthClientProvider,
|
|
6
6
|
sanitizeUrl
|
|
7
7
|
} from "./chunk-J75I2C26.js";
|
|
8
8
|
import {
|
|
9
9
|
Tel
|
|
10
|
-
} from "./chunk-
|
|
10
|
+
} from "./chunk-VTNHO2TS.js";
|
|
11
11
|
import {
|
|
12
12
|
__name
|
|
13
13
|
} from "./chunk-3GQAWCBQ.js";
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import {
|
|
2
2
|
BaseConnector
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-4NC7PPVE.js";
|
|
4
4
|
import {
|
|
5
5
|
Tel,
|
|
6
6
|
generateUUID,
|
|
7
7
|
getPackageVersion
|
|
8
|
-
} from "./chunk-
|
|
8
|
+
} from "./chunk-VTNHO2TS.js";
|
|
9
9
|
import {
|
|
10
10
|
logger
|
|
11
11
|
} from "./chunk-34R6SIER.js";
|
package/dist/index.cjs
CHANGED
package/dist/index.js
CHANGED
|
@@ -16,13 +16,13 @@ import {
|
|
|
16
16
|
ReleaseMCPServerConnectionTool,
|
|
17
17
|
RemoteAgent,
|
|
18
18
|
ServerManager
|
|
19
|
-
} from "./chunk-
|
|
19
|
+
} from "./chunk-FAELBZOW.js";
|
|
20
20
|
import "./chunk-CPG2WZUL.js";
|
|
21
21
|
import "./chunk-JQKKMUCT.js";
|
|
22
22
|
import {
|
|
23
23
|
CodeModeConnector,
|
|
24
24
|
PROMPTS
|
|
25
|
-
} from "./chunk-
|
|
25
|
+
} from "./chunk-OTZ32HGI.js";
|
|
26
26
|
import {
|
|
27
27
|
ErrorBoundary,
|
|
28
28
|
Image,
|
|
@@ -34,21 +34,21 @@ import {
|
|
|
34
34
|
useWidgetProps,
|
|
35
35
|
useWidgetState,
|
|
36
36
|
useWidgetTheme
|
|
37
|
-
} from "./chunk-
|
|
37
|
+
} from "./chunk-CFX74U7W.js";
|
|
38
38
|
import {
|
|
39
39
|
BaseMCPClient,
|
|
40
40
|
ConnectionManager,
|
|
41
41
|
HttpConnector,
|
|
42
42
|
MCPSession,
|
|
43
43
|
WebSocketConnector
|
|
44
|
-
} from "./chunk-
|
|
44
|
+
} from "./chunk-KFTQ3UL5.js";
|
|
45
45
|
import {
|
|
46
46
|
BrowserOAuthClientProvider,
|
|
47
47
|
onMcpAuthorization
|
|
48
48
|
} from "./chunk-J75I2C26.js";
|
|
49
49
|
import {
|
|
50
50
|
BaseConnector
|
|
51
|
-
} from "./chunk-
|
|
51
|
+
} from "./chunk-4NC7PPVE.js";
|
|
52
52
|
import {
|
|
53
53
|
ElicitationDeclinedError,
|
|
54
54
|
ElicitationTimeoutError,
|
|
@@ -60,7 +60,7 @@ import {
|
|
|
60
60
|
VERSION,
|
|
61
61
|
getPackageVersion,
|
|
62
62
|
setTelemetrySource
|
|
63
|
-
} from "./chunk-
|
|
63
|
+
} from "./chunk-VTNHO2TS.js";
|
|
64
64
|
import {
|
|
65
65
|
Logger,
|
|
66
66
|
logger
|
package/dist/src/agents/index.js
CHANGED
|
@@ -4,13 +4,13 @@ import {
|
|
|
4
4
|
import {
|
|
5
5
|
MCPAgent,
|
|
6
6
|
RemoteAgent
|
|
7
|
-
} from "../../chunk-
|
|
7
|
+
} from "../../chunk-FAELBZOW.js";
|
|
8
8
|
import "../../chunk-CPG2WZUL.js";
|
|
9
9
|
import {
|
|
10
10
|
PROMPTS
|
|
11
|
-
} from "../../chunk-
|
|
12
|
-
import "../../chunk-
|
|
13
|
-
import "../../chunk-
|
|
11
|
+
} from "../../chunk-OTZ32HGI.js";
|
|
12
|
+
import "../../chunk-4NC7PPVE.js";
|
|
13
|
+
import "../../chunk-VTNHO2TS.js";
|
|
14
14
|
import "../../chunk-34R6SIER.js";
|
|
15
15
|
import "../../chunk-3GQAWCBQ.js";
|
|
16
16
|
export {
|
package/dist/src/browser.cjs
CHANGED
package/dist/src/browser.js
CHANGED
|
@@ -9,28 +9,28 @@ import {
|
|
|
9
9
|
MCPAgent,
|
|
10
10
|
ObservabilityManager,
|
|
11
11
|
RemoteAgent
|
|
12
|
-
} from "../chunk-
|
|
12
|
+
} from "../chunk-FAELBZOW.js";
|
|
13
13
|
import "../chunk-CPG2WZUL.js";
|
|
14
14
|
import {
|
|
15
15
|
BrowserMCPClient,
|
|
16
16
|
HttpConnector,
|
|
17
17
|
MCPSession,
|
|
18
18
|
WebSocketConnector
|
|
19
|
-
} from "../chunk-
|
|
19
|
+
} from "../chunk-KFTQ3UL5.js";
|
|
20
20
|
import {
|
|
21
21
|
BrowserOAuthClientProvider,
|
|
22
22
|
onMcpAuthorization
|
|
23
23
|
} from "../chunk-J75I2C26.js";
|
|
24
24
|
import {
|
|
25
25
|
BaseConnector
|
|
26
|
-
} from "../chunk-
|
|
26
|
+
} from "../chunk-4NC7PPVE.js";
|
|
27
27
|
import {
|
|
28
28
|
Tel,
|
|
29
29
|
Telemetry,
|
|
30
30
|
VERSION,
|
|
31
31
|
getPackageVersion,
|
|
32
32
|
setTelemetrySource
|
|
33
|
-
} from "../chunk-
|
|
33
|
+
} from "../chunk-VTNHO2TS.js";
|
|
34
34
|
import {
|
|
35
35
|
Logger,
|
|
36
36
|
logger
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import {
|
|
2
2
|
PROMPTS
|
|
3
|
-
} from "../../chunk-
|
|
4
|
-
import "../../chunk-
|
|
5
|
-
import "../../chunk-
|
|
3
|
+
} from "../../chunk-OTZ32HGI.js";
|
|
4
|
+
import "../../chunk-4NC7PPVE.js";
|
|
5
|
+
import "../../chunk-VTNHO2TS.js";
|
|
6
6
|
import "../../chunk-34R6SIER.js";
|
|
7
7
|
import "../../chunk-3GQAWCBQ.js";
|
|
8
8
|
export {
|
package/dist/src/react/index.cjs
CHANGED
package/dist/src/react/index.js
CHANGED
|
@@ -9,17 +9,17 @@ import {
|
|
|
9
9
|
useWidgetProps,
|
|
10
10
|
useWidgetState,
|
|
11
11
|
useWidgetTheme
|
|
12
|
-
} from "../../chunk-
|
|
13
|
-
import "../../chunk-
|
|
12
|
+
} from "../../chunk-CFX74U7W.js";
|
|
13
|
+
import "../../chunk-KFTQ3UL5.js";
|
|
14
14
|
import {
|
|
15
15
|
onMcpAuthorization
|
|
16
16
|
} from "../../chunk-J75I2C26.js";
|
|
17
|
-
import "../../chunk-
|
|
17
|
+
import "../../chunk-4NC7PPVE.js";
|
|
18
18
|
import {
|
|
19
19
|
Tel,
|
|
20
20
|
Telemetry,
|
|
21
21
|
setTelemetrySource
|
|
22
|
-
} from "../../chunk-
|
|
22
|
+
} from "../../chunk-VTNHO2TS.js";
|
|
23
23
|
import "../../chunk-34R6SIER.js";
|
|
24
24
|
import "../../chunk-3GQAWCBQ.js";
|
|
25
25
|
export {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mount-mcp.d.ts","sourceRoot":"","sources":["../../../../src/server/endpoints/mount-mcp.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAW,IAAI,IAAI,QAAQ,EAAE,MAAM,MAAM,CAAC;AACtD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAExD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAItD;;;;;GAKG;AACH,wBAAsB,QAAQ,CAC5B,GAAG,EAAE,QAAQ,EACb,iBAAiB,EAAE;IACjB,mBAAmB,EAAE,MAAM,OAAO,iDAAiD,EAAE,SAAS,CAAC;IAC/F,2BAA2B,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;CAC3D,EAAE,2DAA2D;AAC9D,QAAQ,EAAE,GAAG,CAAC,MAAM,EAAE,WAAW,CAAC,EAClC,MAAM,EAAE,YAAY,EACpB,gBAAgB,EAAE,OAAO,GACxB,OAAO,CAAC;IAAE,UAAU,EAAE,OAAO,CAAC;IAAC,mBAAmB,CAAC,EAAE,MAAM,CAAC,OAAO,CAAA;CAAE,CAAC,
|
|
1
|
+
{"version":3,"file":"mount-mcp.d.ts","sourceRoot":"","sources":["../../../../src/server/endpoints/mount-mcp.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAW,IAAI,IAAI,QAAQ,EAAE,MAAM,MAAM,CAAC;AACtD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAExD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAItD;;;;;GAKG;AACH,wBAAsB,QAAQ,CAC5B,GAAG,EAAE,QAAQ,EACb,iBAAiB,EAAE;IACjB,mBAAmB,EAAE,MAAM,OAAO,iDAAiD,EAAE,SAAS,CAAC;IAC/F,2BAA2B,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;CAC3D,EAAE,2DAA2D;AAC9D,QAAQ,EAAE,GAAG,CAAC,MAAM,EAAE,WAAW,CAAC,EAClC,MAAM,EAAE,YAAY,EACpB,gBAAgB,EAAE,OAAO,GACxB,OAAO,CAAC;IAAE,UAAU,EAAE,OAAO,CAAC;IAAC,mBAAmB,CAAC,EAAE,MAAM,CAAC,OAAO,CAAA;CAAE,CAAC,CAyHxE"}
|
|
@@ -761,7 +761,7 @@ var VERSION;
|
|
|
761
761
|
var init_version = __esm({
|
|
762
762
|
"src/version.ts"() {
|
|
763
763
|
"use strict";
|
|
764
|
-
VERSION = "1.10.1-canary.
|
|
764
|
+
VERSION = "1.10.1-canary.2";
|
|
765
765
|
__name(getPackageVersion, "getPackageVersion");
|
|
766
766
|
}
|
|
767
767
|
});
|
|
@@ -4632,7 +4632,7 @@ init_tool_execution_helpers();
|
|
|
4632
4632
|
init_context_storage();
|
|
4633
4633
|
|
|
4634
4634
|
// src/server/sessions/session-manager.ts
|
|
4635
|
-
function startIdleCleanup(sessions, idleTimeoutMs, mcpServerInstance) {
|
|
4635
|
+
function startIdleCleanup(sessions, idleTimeoutMs, transports, mcpServerInstance) {
|
|
4636
4636
|
if (idleTimeoutMs <= 0) {
|
|
4637
4637
|
return void 0;
|
|
4638
4638
|
}
|
|
@@ -4649,8 +4649,21 @@ function startIdleCleanup(sessions, idleTimeoutMs, mcpServerInstance) {
|
|
|
4649
4649
|
`[MCP] Cleaning up ${expiredSessions.length} idle session(s)`
|
|
4650
4650
|
);
|
|
4651
4651
|
for (const sessionId of expiredSessions) {
|
|
4652
|
+
const transport = transports?.get(sessionId);
|
|
4653
|
+
if (transport?.close) {
|
|
4654
|
+
Promise.resolve(transport.close()).catch((e) => {
|
|
4655
|
+
console.warn(
|
|
4656
|
+
`[MCP] Error closing transport for session ${sessionId}:`,
|
|
4657
|
+
e
|
|
4658
|
+
);
|
|
4659
|
+
});
|
|
4660
|
+
}
|
|
4661
|
+
transports?.delete(sessionId);
|
|
4652
4662
|
sessions.delete(sessionId);
|
|
4653
4663
|
mcpServerInstance?.cleanupSessionSubscriptions?.(sessionId);
|
|
4664
|
+
console.log(
|
|
4665
|
+
`[MCP] Cleaned up resource subscriptions for session ${sessionId}`
|
|
4666
|
+
);
|
|
4654
4667
|
}
|
|
4655
4668
|
}
|
|
4656
4669
|
}, 6e4);
|
|
@@ -4669,11 +4682,18 @@ async function mountMcp(app, mcpServerInstance, sessions, config, isProductionMo
|
|
|
4669
4682
|
idleCleanupInterval = startIdleCleanup(
|
|
4670
4683
|
sessions,
|
|
4671
4684
|
idleTimeoutMs,
|
|
4685
|
+
transports,
|
|
4672
4686
|
mcpServerInstance
|
|
4673
4687
|
);
|
|
4674
4688
|
}
|
|
4675
4689
|
const handleRequest = /* @__PURE__ */ __name(async (c) => {
|
|
4676
4690
|
const sessionId = c.req.header("mcp-session-id");
|
|
4691
|
+
if (c.req.method === "HEAD") {
|
|
4692
|
+
if (sessionId && sessions.has(sessionId)) {
|
|
4693
|
+
sessions.get(sessionId).lastAccessedAt = Date.now();
|
|
4694
|
+
}
|
|
4695
|
+
return new Response(null, { status: 200 });
|
|
4696
|
+
}
|
|
4677
4697
|
if (sessionId && transports.has(sessionId)) {
|
|
4678
4698
|
const transport2 = transports.get(sessionId);
|
|
4679
4699
|
if (sessions.has(sessionId)) {
|
|
@@ -4730,7 +4750,7 @@ async function mountMcp(app, mcpServerInstance, sessions, config, isProductionMo
|
|
|
4730
4750
|
return transport.handleRequest(c.req.raw);
|
|
4731
4751
|
}, "handleRequest");
|
|
4732
4752
|
for (const endpoint of ["/mcp", "/sse"]) {
|
|
4733
|
-
app.on(["GET", "POST", "DELETE"], endpoint, handleRequest);
|
|
4753
|
+
app.on(["GET", "POST", "DELETE", "HEAD"], endpoint, handleRequest);
|
|
4734
4754
|
}
|
|
4735
4755
|
console.log(
|
|
4736
4756
|
`[MCP] Server mounted at /mcp and /sse (using FetchStreamableHTTPServerTransport - Web Standard APIs)`
|
package/dist/src/server/index.js
CHANGED
|
@@ -7,7 +7,7 @@ import {
|
|
|
7
7
|
createEnhancedContext,
|
|
8
8
|
findSessionContext,
|
|
9
9
|
isValidLogLevel
|
|
10
|
-
} from "../../chunk-
|
|
10
|
+
} from "../../chunk-QNZMNQCY.js";
|
|
11
11
|
import {
|
|
12
12
|
convertToolResultToResourceResult
|
|
13
13
|
} from "../../chunk-362PI25Z.js";
|
|
@@ -25,7 +25,7 @@ import {
|
|
|
25
25
|
getPackageVersion,
|
|
26
26
|
isDeno,
|
|
27
27
|
pathHelpers
|
|
28
|
-
} from "../../chunk-
|
|
28
|
+
} from "../../chunk-VTNHO2TS.js";
|
|
29
29
|
import "../../chunk-34R6SIER.js";
|
|
30
30
|
import {
|
|
31
31
|
__name
|
|
@@ -2091,7 +2091,7 @@ function registerResource(resourceDefinition, callback) {
|
|
|
2091
2091
|
const explicitMimeType = resourceDefinition.mimeType;
|
|
2092
2092
|
const wrappedCallback = /* @__PURE__ */ __name(async () => {
|
|
2093
2093
|
const { getRequestContext: getRequestContext2, runWithContext: runWithContext2 } = await import("../../context-storage-NA4MHWOZ.js");
|
|
2094
|
-
const { findSessionContext: findSessionContext2 } = await import("../../tool-execution-helpers-
|
|
2094
|
+
const { findSessionContext: findSessionContext2 } = await import("../../tool-execution-helpers-PQGEPYY3.js");
|
|
2095
2095
|
const initialRequestContext = getRequestContext2();
|
|
2096
2096
|
const sessions = this.sessions || /* @__PURE__ */ new Map();
|
|
2097
2097
|
const { requestContext } = findSessionContext2(
|
|
@@ -2169,7 +2169,7 @@ function registerResourceTemplate(resourceTemplateDefinition, callback) {
|
|
|
2169
2169
|
async (uri) => {
|
|
2170
2170
|
const params = this.parseTemplateUri(uriTemplate, uri.toString());
|
|
2171
2171
|
const { getRequestContext: getRequestContext2, runWithContext: runWithContext2 } = await import("../../context-storage-NA4MHWOZ.js");
|
|
2172
|
-
const { findSessionContext: findSessionContext2 } = await import("../../tool-execution-helpers-
|
|
2172
|
+
const { findSessionContext: findSessionContext2 } = await import("../../tool-execution-helpers-PQGEPYY3.js");
|
|
2173
2173
|
const initialRequestContext = getRequestContext2();
|
|
2174
2174
|
const sessions = this.sessions || /* @__PURE__ */ new Map();
|
|
2175
2175
|
const { requestContext } = findSessionContext2(
|
|
@@ -2224,7 +2224,7 @@ function registerPrompt(promptDefinition, callback) {
|
|
|
2224
2224
|
}
|
|
2225
2225
|
const wrappedCallback = /* @__PURE__ */ __name(async (params, extra) => {
|
|
2226
2226
|
const { getRequestContext: getRequestContext2, runWithContext: runWithContext2 } = await import("../../context-storage-NA4MHWOZ.js");
|
|
2227
|
-
const { findSessionContext: findSessionContext2 } = await import("../../tool-execution-helpers-
|
|
2227
|
+
const { findSessionContext: findSessionContext2 } = await import("../../tool-execution-helpers-PQGEPYY3.js");
|
|
2228
2228
|
const initialRequestContext = getRequestContext2();
|
|
2229
2229
|
const sessions = this.sessions || /* @__PURE__ */ new Map();
|
|
2230
2230
|
const { requestContext } = findSessionContext2(
|
|
@@ -2495,7 +2495,7 @@ async function sendNotificationToSession2(sessionId, method, params) {
|
|
|
2495
2495
|
__name(sendNotificationToSession2, "sendNotificationToSession");
|
|
2496
2496
|
|
|
2497
2497
|
// src/server/sessions/session-manager.ts
|
|
2498
|
-
function startIdleCleanup(sessions, idleTimeoutMs, mcpServerInstance) {
|
|
2498
|
+
function startIdleCleanup(sessions, idleTimeoutMs, transports, mcpServerInstance) {
|
|
2499
2499
|
if (idleTimeoutMs <= 0) {
|
|
2500
2500
|
return void 0;
|
|
2501
2501
|
}
|
|
@@ -2512,8 +2512,21 @@ function startIdleCleanup(sessions, idleTimeoutMs, mcpServerInstance) {
|
|
|
2512
2512
|
`[MCP] Cleaning up ${expiredSessions.length} idle session(s)`
|
|
2513
2513
|
);
|
|
2514
2514
|
for (const sessionId of expiredSessions) {
|
|
2515
|
+
const transport = transports?.get(sessionId);
|
|
2516
|
+
if (transport?.close) {
|
|
2517
|
+
Promise.resolve(transport.close()).catch((e) => {
|
|
2518
|
+
console.warn(
|
|
2519
|
+
`[MCP] Error closing transport for session ${sessionId}:`,
|
|
2520
|
+
e
|
|
2521
|
+
);
|
|
2522
|
+
});
|
|
2523
|
+
}
|
|
2524
|
+
transports?.delete(sessionId);
|
|
2515
2525
|
sessions.delete(sessionId);
|
|
2516
2526
|
mcpServerInstance?.cleanupSessionSubscriptions?.(sessionId);
|
|
2527
|
+
console.log(
|
|
2528
|
+
`[MCP] Cleaned up resource subscriptions for session ${sessionId}`
|
|
2529
|
+
);
|
|
2517
2530
|
}
|
|
2518
2531
|
}
|
|
2519
2532
|
}, 6e4);
|
|
@@ -2530,11 +2543,18 @@ async function mountMcp(app, mcpServerInstance, sessions, config, isProductionMo
|
|
|
2530
2543
|
idleCleanupInterval = startIdleCleanup(
|
|
2531
2544
|
sessions,
|
|
2532
2545
|
idleTimeoutMs,
|
|
2546
|
+
transports,
|
|
2533
2547
|
mcpServerInstance
|
|
2534
2548
|
);
|
|
2535
2549
|
}
|
|
2536
2550
|
const handleRequest = /* @__PURE__ */ __name(async (c) => {
|
|
2537
2551
|
const sessionId = c.req.header("mcp-session-id");
|
|
2552
|
+
if (c.req.method === "HEAD") {
|
|
2553
|
+
if (sessionId && sessions.has(sessionId)) {
|
|
2554
|
+
sessions.get(sessionId).lastAccessedAt = Date.now();
|
|
2555
|
+
}
|
|
2556
|
+
return new Response(null, { status: 200 });
|
|
2557
|
+
}
|
|
2538
2558
|
if (sessionId && transports.has(sessionId)) {
|
|
2539
2559
|
const transport2 = transports.get(sessionId);
|
|
2540
2560
|
if (sessions.has(sessionId)) {
|
|
@@ -2591,7 +2611,7 @@ async function mountMcp(app, mcpServerInstance, sessions, config, isProductionMo
|
|
|
2591
2611
|
return transport.handleRequest(c.req.raw);
|
|
2592
2612
|
}, "handleRequest");
|
|
2593
2613
|
for (const endpoint of ["/mcp", "/sse"]) {
|
|
2594
|
-
app.on(["GET", "POST", "DELETE"], endpoint, handleRequest);
|
|
2614
|
+
app.on(["GET", "POST", "DELETE", "HEAD"], endpoint, handleRequest);
|
|
2595
2615
|
}
|
|
2596
2616
|
console.log(
|
|
2597
2617
|
`[MCP] Server mounted at /mcp and /sse (using FetchStreamableHTTPServerTransport - Web Standard APIs)`
|
|
@@ -40,14 +40,17 @@ export interface SessionData {
|
|
|
40
40
|
* Start idle session cleanup interval
|
|
41
41
|
*
|
|
42
42
|
* Monitors sessions and removes them if they've been inactive for too long.
|
|
43
|
-
*
|
|
44
|
-
*
|
|
43
|
+
* Also cleans up the associated transports to prevent "Server not initialized" errors
|
|
44
|
+
* when clients try to reconnect with expired session IDs.
|
|
45
45
|
*
|
|
46
46
|
* @param sessions - Map of active sessions
|
|
47
47
|
* @param idleTimeoutMs - Idle timeout in milliseconds
|
|
48
|
+
* @param transports - Optional map of transports by session ID (to close on cleanup)
|
|
48
49
|
* @param mcpServerInstance - Optional MCP server instance for cleanup callbacks
|
|
49
50
|
*/
|
|
50
|
-
export declare function startIdleCleanup(sessions: Map<string, SessionData>, idleTimeoutMs: number,
|
|
51
|
+
export declare function startIdleCleanup(sessions: Map<string, SessionData>, idleTimeoutMs: number, transports?: Map<string, {
|
|
52
|
+
close?: () => Promise<void> | void;
|
|
53
|
+
}>, mcpServerInstance?: {
|
|
51
54
|
cleanupSessionSubscriptions?: (sessionId: string) => void;
|
|
52
55
|
}): NodeJS.Timeout | undefined;
|
|
53
56
|
//# sourceMappingURL=session-manager.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"session-manager.d.ts","sourceRoot":"","sources":["../../../../src/server/sessions/session-manager.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACpC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,uDAAuD,CAAC;AACvF,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iDAAiD,CAAC;AAEjF;;;GAGG;AACH,MAAM,WAAW,WAAW;IAC1B,qDAAqD;IACrD,SAAS,EAAE,SAAS,CAAC;IACrB,kDAAkD;IAClD,MAAM,CAAC,EAAE,SAAS,CAAC;IACnB,2DAA2D;IAC3D,cAAc,EAAE,MAAM,CAAC;IACvB,sDAAsD;IACtD,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,oDAAoD;IACpD,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,mDAAmD;IACnD,gBAAgB,CAAC,EAAE,CAAC,YAAY,EAAE;QAChC,MAAM,EAAE,MAAM,CAAC;QACf,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;KACjC,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACpB,qDAAqD;IACrD,UAAU,CAAC,EAAE,QAAQ,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAChD,8CAA8C;IAC9C,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,qEAAqE;IACrE,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,2DAA2D;IAC3D,kBAAkB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAC9C;AAED
|
|
1
|
+
{"version":3,"file":"session-manager.d.ts","sourceRoot":"","sources":["../../../../src/server/sessions/session-manager.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACpC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,uDAAuD,CAAC;AACvF,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iDAAiD,CAAC;AAEjF;;;GAGG;AACH,MAAM,WAAW,WAAW;IAC1B,qDAAqD;IACrD,SAAS,EAAE,SAAS,CAAC;IACrB,kDAAkD;IAClD,MAAM,CAAC,EAAE,SAAS,CAAC;IACnB,2DAA2D;IAC3D,cAAc,EAAE,MAAM,CAAC;IACvB,sDAAsD;IACtD,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,oDAAoD;IACpD,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,mDAAmD;IACnD,gBAAgB,CAAC,EAAE,CAAC,YAAY,EAAE;QAChC,MAAM,EAAE,MAAM,CAAC;QACf,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;KACjC,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACpB,qDAAqD;IACrD,UAAU,CAAC,EAAE,QAAQ,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAChD,8CAA8C;IAC9C,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,qEAAqE;IACrE,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,2DAA2D;IAC3D,kBAAkB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAC9C;AAED;;;;;;;;;;;GAWG;AACH,wBAAgB,gBAAgB,CAC9B,QAAQ,EAAE,GAAG,CAAC,MAAM,EAAE,WAAW,CAAC,EAClC,aAAa,EAAE,MAAM,EACrB,UAAU,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE;IAAE,KAAK,CAAC,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAA;CAAE,CAAC,EAChE,iBAAiB,CAAC,EAAE;IAClB,2BAA2B,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;CAC3D,GACA,MAAM,CAAC,OAAO,GAAG,SAAS,CAyC5B"}
|
package/dist/src/version.d.ts
CHANGED
|
@@ -10,9 +10,9 @@ import {
|
|
|
10
10
|
sendProgressNotification,
|
|
11
11
|
shouldLogMessage,
|
|
12
12
|
withTimeout
|
|
13
|
-
} from "./chunk-
|
|
13
|
+
} from "./chunk-QNZMNQCY.js";
|
|
14
14
|
import "./chunk-KUEVOU4M.js";
|
|
15
|
-
import "./chunk-
|
|
15
|
+
import "./chunk-VTNHO2TS.js";
|
|
16
16
|
import "./chunk-34R6SIER.js";
|
|
17
17
|
import "./chunk-3GQAWCBQ.js";
|
|
18
18
|
export {
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "mcp-use",
|
|
3
3
|
"type": "module",
|
|
4
|
-
"version": "1.10.1-canary.
|
|
4
|
+
"version": "1.10.1-canary.2",
|
|
5
5
|
"description": "Opinionated MCP Framework for TypeScript (@modelcontextprotocol/sdk compatible) - Build MCP Agents, Clients and Servers with support for ChatGPT Apps, Code Mode, OAuth, Notifications, Sampling, Observability and more.",
|
|
6
6
|
"author": "mcp-use, Inc.",
|
|
7
7
|
"license": "MIT",
|
|
@@ -115,8 +115,8 @@
|
|
|
115
115
|
"posthog-node": "^5.14.1",
|
|
116
116
|
"ws": "^8.18.3",
|
|
117
117
|
"zod": "^4.1.13",
|
|
118
|
-
"@mcp-use/cli": "2.5.1-canary.
|
|
119
|
-
"@mcp-use/inspector": "0.12.1-canary.
|
|
118
|
+
"@mcp-use/cli": "2.5.1-canary.2",
|
|
119
|
+
"@mcp-use/inspector": "0.12.1-canary.2"
|
|
120
120
|
},
|
|
121
121
|
"optionalDependencies": {
|
|
122
122
|
"chalk": "^5.6.2",
|