mcp-proxy 2.14.3 → 3.0.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.
@@ -1,471 +0,0 @@
1
- // src/InMemoryEventStore.ts
2
- var InMemoryEventStore = class {
3
- events = /* @__PURE__ */ new Map();
4
- /**
5
- * Replays events that occurred after a specific event ID
6
- * Implements EventStore.replayEventsAfter
7
- */
8
- async replayEventsAfter(lastEventId, {
9
- send
10
- }) {
11
- if (!lastEventId || !this.events.has(lastEventId)) {
12
- return "";
13
- }
14
- const streamId = this.getStreamIdFromEventId(lastEventId);
15
- if (!streamId) {
16
- return "";
17
- }
18
- let foundLastEvent = false;
19
- const sortedEvents = [...this.events.entries()].sort(
20
- (a, b) => a[0].localeCompare(b[0])
21
- );
22
- for (const [
23
- eventId,
24
- { message, streamId: eventStreamId }
25
- ] of sortedEvents) {
26
- if (eventStreamId !== streamId) {
27
- continue;
28
- }
29
- if (eventId === lastEventId) {
30
- foundLastEvent = true;
31
- continue;
32
- }
33
- if (foundLastEvent) {
34
- await send(eventId, message);
35
- }
36
- }
37
- return streamId;
38
- }
39
- /**
40
- * Stores an event with a generated event ID
41
- * Implements EventStore.storeEvent
42
- */
43
- async storeEvent(streamId, message) {
44
- const eventId = this.generateEventId(streamId);
45
- this.events.set(eventId, { message, streamId });
46
- return eventId;
47
- }
48
- /**
49
- * Generates a unique event ID for a given stream ID
50
- */
51
- generateEventId(streamId) {
52
- return `${streamId}_${Date.now()}_${Math.random().toString(36).substring(2, 10)}`;
53
- }
54
- /**
55
- * Extracts the stream ID from an event ID
56
- */
57
- getStreamIdFromEventId(eventId) {
58
- const parts = eventId.split("_");
59
- return parts.length > 0 ? parts[0] : "";
60
- }
61
- };
62
-
63
- // src/proxyServer.ts
64
- import {
65
- CallToolRequestSchema,
66
- CompleteRequestSchema,
67
- GetPromptRequestSchema,
68
- ListPromptsRequestSchema,
69
- ListResourcesRequestSchema,
70
- ListResourceTemplatesRequestSchema,
71
- ListToolsRequestSchema,
72
- LoggingMessageNotificationSchema,
73
- ReadResourceRequestSchema,
74
- ResourceUpdatedNotificationSchema,
75
- SubscribeRequestSchema,
76
- UnsubscribeRequestSchema
77
- } from "@modelcontextprotocol/sdk/types.js";
78
- var proxyServer = async ({
79
- client,
80
- server,
81
- serverCapabilities
82
- }) => {
83
- if (serverCapabilities?.logging) {
84
- server.setNotificationHandler(
85
- LoggingMessageNotificationSchema,
86
- async (args) => {
87
- return client.notification(args);
88
- }
89
- );
90
- client.setNotificationHandler(
91
- LoggingMessageNotificationSchema,
92
- async (args) => {
93
- return server.notification(args);
94
- }
95
- );
96
- }
97
- if (serverCapabilities?.prompts) {
98
- server.setRequestHandler(GetPromptRequestSchema, async (args) => {
99
- return client.getPrompt(args.params);
100
- });
101
- server.setRequestHandler(ListPromptsRequestSchema, async (args) => {
102
- return client.listPrompts(args.params);
103
- });
104
- }
105
- if (serverCapabilities?.resources) {
106
- server.setRequestHandler(ListResourcesRequestSchema, async (args) => {
107
- return client.listResources(args.params);
108
- });
109
- server.setRequestHandler(
110
- ListResourceTemplatesRequestSchema,
111
- async (args) => {
112
- return client.listResourceTemplates(args.params);
113
- }
114
- );
115
- server.setRequestHandler(ReadResourceRequestSchema, async (args) => {
116
- return client.readResource(args.params);
117
- });
118
- if (serverCapabilities?.resources.subscribe) {
119
- server.setNotificationHandler(
120
- ResourceUpdatedNotificationSchema,
121
- async (args) => {
122
- return client.notification(args);
123
- }
124
- );
125
- server.setRequestHandler(SubscribeRequestSchema, async (args) => {
126
- return client.subscribeResource(args.params);
127
- });
128
- server.setRequestHandler(UnsubscribeRequestSchema, async (args) => {
129
- return client.unsubscribeResource(args.params);
130
- });
131
- }
132
- }
133
- if (serverCapabilities?.tools) {
134
- server.setRequestHandler(CallToolRequestSchema, async (args) => {
135
- return client.callTool(args.params);
136
- });
137
- server.setRequestHandler(ListToolsRequestSchema, async (args) => {
138
- return client.listTools(args.params);
139
- });
140
- }
141
- server.setRequestHandler(CompleteRequestSchema, async (args) => {
142
- return client.complete(args.params);
143
- });
144
- };
145
-
146
- // src/startHTTPStreamServer.ts
147
- import {
148
- StreamableHTTPServerTransport
149
- } from "@modelcontextprotocol/sdk/server/streamableHttp.js";
150
- import { isInitializeRequest } from "@modelcontextprotocol/sdk/types.js";
151
- import http from "http";
152
- import { randomUUID } from "crypto";
153
- var startHTTPStreamServer = async ({
154
- createServer,
155
- endpoint,
156
- eventStore,
157
- onClose,
158
- onConnect,
159
- onUnhandledRequest,
160
- port
161
- }) => {
162
- const activeTransports = {};
163
- const httpServer = http.createServer(async (req, res) => {
164
- if (req.headers.origin) {
165
- try {
166
- const origin = new URL(req.headers.origin);
167
- res.setHeader("Access-Control-Allow-Origin", origin.origin);
168
- res.setHeader("Access-Control-Allow-Credentials", "true");
169
- res.setHeader("Access-Control-Allow-Methods", "GET, POST, OPTIONS");
170
- res.setHeader("Access-Control-Allow-Headers", "*");
171
- } catch (error) {
172
- console.error("Error parsing origin:", error);
173
- }
174
- }
175
- if (req.method === "OPTIONS") {
176
- res.writeHead(204);
177
- res.end();
178
- return;
179
- }
180
- if (req.method === "GET" && req.url === `/ping`) {
181
- res.writeHead(200).end("pong");
182
- return;
183
- }
184
- if (req.method === "POST" && new URL(req.url, "http://localhost").pathname === endpoint) {
185
- try {
186
- const sessionId = Array.isArray(req.headers["mcp-session-id"]) ? req.headers["mcp-session-id"][0] : req.headers["mcp-session-id"];
187
- let transport;
188
- let server;
189
- const body = await getBody(req);
190
- if (sessionId && activeTransports[sessionId]) {
191
- transport = activeTransports[sessionId].transport;
192
- server = activeTransports[sessionId].server;
193
- } else if (!sessionId && isInitializeRequest(body)) {
194
- transport = new StreamableHTTPServerTransport({
195
- eventStore: eventStore || new InMemoryEventStore(),
196
- onsessioninitialized: (_sessionId) => {
197
- activeTransports[_sessionId] = {
198
- server,
199
- transport
200
- };
201
- },
202
- sessionIdGenerator: randomUUID
203
- });
204
- transport.onclose = async () => {
205
- const sid = transport.sessionId;
206
- if (sid && activeTransports[sid]) {
207
- onClose?.(server);
208
- try {
209
- await server.close();
210
- } catch (error) {
211
- console.error("Error closing server:", error);
212
- }
213
- delete activeTransports[sid];
214
- }
215
- };
216
- try {
217
- server = await createServer(req);
218
- } catch (error) {
219
- if (error instanceof Response) {
220
- res.writeHead(error.status).end(error.statusText);
221
- return;
222
- }
223
- res.writeHead(500).end("Error creating server");
224
- return;
225
- }
226
- server.connect(transport);
227
- onConnect?.(server);
228
- await transport.handleRequest(req, res, body);
229
- return;
230
- } else {
231
- res.setHeader("Content-Type", "application/json");
232
- res.writeHead(400).end(
233
- JSON.stringify({
234
- error: {
235
- code: -32e3,
236
- message: "Bad Request: No valid session ID provided"
237
- },
238
- id: null,
239
- jsonrpc: "2.0"
240
- })
241
- );
242
- return;
243
- }
244
- await transport.handleRequest(req, res, body);
245
- } catch (error) {
246
- console.error("Error handling request:", error);
247
- res.setHeader("Content-Type", "application/json");
248
- res.writeHead(500).end(
249
- JSON.stringify({
250
- error: { code: -32603, message: "Internal Server Error" },
251
- id: null,
252
- jsonrpc: "2.0"
253
- })
254
- );
255
- }
256
- return;
257
- }
258
- if (req.method === "GET" && new URL(req.url, "http://localhost").pathname === endpoint) {
259
- const sessionId = req.headers["mcp-session-id"];
260
- const activeTransport = sessionId ? activeTransports[sessionId] : void 0;
261
- if (!sessionId) {
262
- res.writeHead(400).end("No sessionId");
263
- return;
264
- }
265
- if (!activeTransport) {
266
- res.writeHead(400).end("No active transport");
267
- return;
268
- }
269
- const lastEventId = req.headers["last-event-id"];
270
- if (lastEventId) {
271
- console.log(`Client reconnecting with Last-Event-ID: ${lastEventId}`);
272
- } else {
273
- console.log(`Establishing new SSE stream for session ${sessionId}`);
274
- }
275
- await activeTransport.transport.handleRequest(req, res);
276
- return;
277
- }
278
- if (req.method === "DELETE" && new URL(req.url, "http://localhost").pathname === endpoint) {
279
- console.log("received delete request");
280
- const sessionId = req.headers["mcp-session-id"];
281
- if (!sessionId) {
282
- res.writeHead(400).end("Invalid or missing sessionId");
283
- return;
284
- }
285
- console.log("received delete request for session", sessionId);
286
- const { server, transport } = activeTransports[sessionId];
287
- if (!transport) {
288
- res.writeHead(400).end("No active transport");
289
- return;
290
- }
291
- try {
292
- await transport.handleRequest(req, res);
293
- onClose?.(server);
294
- } catch (error) {
295
- console.error("Error handling delete request:", error);
296
- res.writeHead(500).end("Error handling delete request");
297
- }
298
- return;
299
- }
300
- if (onUnhandledRequest) {
301
- await onUnhandledRequest(req, res);
302
- } else {
303
- res.writeHead(404).end();
304
- }
305
- });
306
- await new Promise((resolve) => {
307
- httpServer.listen(port, "::", () => {
308
- resolve(void 0);
309
- });
310
- });
311
- return {
312
- close: async () => {
313
- for (const transport of Object.values(activeTransports)) {
314
- await transport.transport.close();
315
- }
316
- return new Promise((resolve, reject) => {
317
- httpServer.close((error) => {
318
- if (error) {
319
- reject(error);
320
- return;
321
- }
322
- resolve();
323
- });
324
- });
325
- }
326
- };
327
- };
328
- function getBody(request) {
329
- return new Promise((resolve) => {
330
- const bodyParts = [];
331
- let body;
332
- request.on("data", (chunk) => {
333
- bodyParts.push(chunk);
334
- }).on("end", () => {
335
- body = Buffer.concat(bodyParts).toString();
336
- resolve(JSON.parse(body));
337
- });
338
- });
339
- }
340
-
341
- // src/startSSEServer.ts
342
- import { SSEServerTransport } from "@modelcontextprotocol/sdk/server/sse.js";
343
- import http2 from "http";
344
- var startSSEServer = async ({
345
- createServer,
346
- endpoint,
347
- onClose,
348
- onConnect,
349
- onUnhandledRequest,
350
- port
351
- }) => {
352
- const activeTransports = {};
353
- const httpServer = http2.createServer(async (req, res) => {
354
- if (req.headers.origin) {
355
- try {
356
- const origin = new URL(req.headers.origin);
357
- res.setHeader("Access-Control-Allow-Origin", origin.origin);
358
- res.setHeader("Access-Control-Allow-Credentials", "true");
359
- res.setHeader("Access-Control-Allow-Methods", "GET, POST, OPTIONS");
360
- res.setHeader("Access-Control-Allow-Headers", "*");
361
- } catch (error) {
362
- console.error("Error parsing origin:", error);
363
- }
364
- }
365
- if (req.method === "OPTIONS") {
366
- res.writeHead(204);
367
- res.end();
368
- return;
369
- }
370
- if (req.method === "GET" && req.url === "/health") {
371
- res.writeHead(200, { "Content-Type": "text/plain" }).end("OK");
372
- return;
373
- }
374
- if (req.method === "GET" && req.url === `/ping`) {
375
- res.writeHead(200).end("pong");
376
- return;
377
- }
378
- if (req.method === "GET" && new URL(req.url, "http://localhost").pathname === endpoint) {
379
- const transport = new SSEServerTransport("/messages", res);
380
- let server;
381
- try {
382
- server = await createServer(req);
383
- } catch (error) {
384
- if (error instanceof Response) {
385
- res.writeHead(error.status).end(error.statusText);
386
- return;
387
- }
388
- res.writeHead(500).end("Error creating server");
389
- return;
390
- }
391
- activeTransports[transport.sessionId] = transport;
392
- let closed = false;
393
- res.on("close", async () => {
394
- closed = true;
395
- try {
396
- await server.close();
397
- } catch (error) {
398
- console.error("Error closing server:", error);
399
- }
400
- delete activeTransports[transport.sessionId];
401
- onClose?.(server);
402
- });
403
- try {
404
- await server.connect(transport);
405
- await transport.send({
406
- jsonrpc: "2.0",
407
- method: "sse/connection",
408
- params: { message: "SSE Connection established" }
409
- });
410
- onConnect?.(server);
411
- } catch (error) {
412
- if (!closed) {
413
- console.error("Error connecting to server:", error);
414
- res.writeHead(500).end("Error connecting to server");
415
- }
416
- }
417
- return;
418
- }
419
- if (req.method === "POST" && req.url?.startsWith("/messages")) {
420
- const sessionId = new URL(
421
- req.url,
422
- "https://example.com"
423
- ).searchParams.get("sessionId");
424
- if (!sessionId) {
425
- res.writeHead(400).end("No sessionId");
426
- return;
427
- }
428
- const activeTransport = activeTransports[sessionId];
429
- if (!activeTransport) {
430
- res.writeHead(400).end("No active transport");
431
- return;
432
- }
433
- await activeTransport.handlePostMessage(req, res);
434
- return;
435
- }
436
- if (onUnhandledRequest) {
437
- await onUnhandledRequest(req, res);
438
- } else {
439
- res.writeHead(404).end();
440
- }
441
- });
442
- await new Promise((resolve) => {
443
- httpServer.listen(port, "::", () => {
444
- resolve(void 0);
445
- });
446
- });
447
- return {
448
- close: async () => {
449
- for (const transport of Object.values(activeTransports)) {
450
- await transport.close();
451
- }
452
- return new Promise((resolve, reject) => {
453
- httpServer.close((error) => {
454
- if (error) {
455
- reject(error);
456
- return;
457
- }
458
- resolve();
459
- });
460
- });
461
- }
462
- };
463
- };
464
-
465
- export {
466
- InMemoryEventStore,
467
- proxyServer,
468
- startHTTPStreamServer,
469
- startSSEServer
470
- };
471
- //# sourceMappingURL=chunk-43AXMLZU.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/InMemoryEventStore.ts","../src/proxyServer.ts","../src/startHTTPStreamServer.ts","../src/startSSEServer.ts"],"sourcesContent":["/**\n * This is a copy of the InMemoryEventStore from the typescript-sdk\n * https://github.com/modelcontextprotocol/typescript-sdk/blob/main/src/inMemoryEventStore.ts\n */\n\nimport type { EventStore } from \"@modelcontextprotocol/sdk/server/streamableHttp.js\";\nimport type { JSONRPCMessage } from \"@modelcontextprotocol/sdk/types.js\";\n\n/**\n * Simple in-memory implementation of the EventStore interface for resumability\n * This is primarily intended for examples and testing, not for production use\n * where a persistent storage solution would be more appropriate.\n */\nexport class InMemoryEventStore implements EventStore {\n private events: Map<string, { message: JSONRPCMessage; streamId: string }> =\n new Map();\n\n /**\n * Replays events that occurred after a specific event ID\n * Implements EventStore.replayEventsAfter\n */\n async replayEventsAfter(\n lastEventId: string,\n {\n send,\n }: { send: (eventId: string, message: JSONRPCMessage) => Promise<void> },\n ): Promise<string> {\n if (!lastEventId || !this.events.has(lastEventId)) {\n return \"\";\n }\n\n // Extract the stream ID from the event ID\n const streamId = this.getStreamIdFromEventId(lastEventId);\n if (!streamId) {\n return \"\";\n }\n\n let foundLastEvent = false;\n\n // Sort events by eventId for chronological ordering\n const sortedEvents = [...this.events.entries()].sort((a, b) =>\n a[0].localeCompare(b[0]),\n );\n\n for (const [\n eventId,\n { message, streamId: eventStreamId },\n ] of sortedEvents) {\n // Only include events from the same stream\n if (eventStreamId !== streamId) {\n continue;\n }\n\n // Start sending events after we find the lastEventId\n if (eventId === lastEventId) {\n foundLastEvent = true;\n continue;\n }\n\n if (foundLastEvent) {\n await send(eventId, message);\n }\n }\n return streamId;\n }\n\n /**\n * Stores an event with a generated event ID\n * Implements EventStore.storeEvent\n */\n async storeEvent(streamId: string, message: JSONRPCMessage): Promise<string> {\n const eventId = this.generateEventId(streamId);\n this.events.set(eventId, { message, streamId });\n return eventId;\n }\n\n /**\n * Generates a unique event ID for a given stream ID\n */\n private generateEventId(streamId: string): string {\n return `${streamId}_${Date.now()}_${Math.random().toString(36).substring(2, 10)}`;\n }\n\n /**\n * Extracts the stream ID from an event ID\n */\n private getStreamIdFromEventId(eventId: string): string {\n const parts = eventId.split(\"_\");\n return parts.length > 0 ? parts[0] : \"\";\n }\n}\n","import { Client } from \"@modelcontextprotocol/sdk/client/index.js\";\nimport { Server } from \"@modelcontextprotocol/sdk/server/index.js\";\nimport {\n CallToolRequestSchema,\n CompleteRequestSchema,\n GetPromptRequestSchema,\n ListPromptsRequestSchema,\n ListResourcesRequestSchema,\n ListResourceTemplatesRequestSchema,\n ListToolsRequestSchema,\n LoggingMessageNotificationSchema,\n ReadResourceRequestSchema,\n ResourceUpdatedNotificationSchema,\n ServerCapabilities,\n SubscribeRequestSchema,\n UnsubscribeRequestSchema,\n} from \"@modelcontextprotocol/sdk/types.js\";\n\nexport const proxyServer = async ({\n client,\n server,\n serverCapabilities,\n}: {\n client: Client;\n server: Server;\n serverCapabilities: ServerCapabilities;\n}): Promise<void> => {\n if (serverCapabilities?.logging) {\n server.setNotificationHandler(\n LoggingMessageNotificationSchema,\n async (args) => {\n return client.notification(args);\n },\n );\n client.setNotificationHandler(\n LoggingMessageNotificationSchema,\n async (args) => {\n return server.notification(args);\n },\n );\n }\n\n if (serverCapabilities?.prompts) {\n server.setRequestHandler(GetPromptRequestSchema, async (args) => {\n return client.getPrompt(args.params);\n });\n\n server.setRequestHandler(ListPromptsRequestSchema, async (args) => {\n return client.listPrompts(args.params);\n });\n }\n\n if (serverCapabilities?.resources) {\n server.setRequestHandler(ListResourcesRequestSchema, async (args) => {\n return client.listResources(args.params);\n });\n\n server.setRequestHandler(\n ListResourceTemplatesRequestSchema,\n async (args) => {\n return client.listResourceTemplates(args.params);\n },\n );\n\n server.setRequestHandler(ReadResourceRequestSchema, async (args) => {\n return client.readResource(args.params);\n });\n\n if (serverCapabilities?.resources.subscribe) {\n server.setNotificationHandler(\n ResourceUpdatedNotificationSchema,\n async (args) => {\n return client.notification(args);\n },\n );\n\n server.setRequestHandler(SubscribeRequestSchema, async (args) => {\n return client.subscribeResource(args.params);\n });\n\n server.setRequestHandler(UnsubscribeRequestSchema, async (args) => {\n return client.unsubscribeResource(args.params);\n });\n }\n }\n\n if (serverCapabilities?.tools) {\n server.setRequestHandler(CallToolRequestSchema, async (args) => {\n return client.callTool(args.params);\n });\n\n server.setRequestHandler(ListToolsRequestSchema, async (args) => {\n return client.listTools(args.params);\n });\n }\n\n server.setRequestHandler(CompleteRequestSchema, async (args) => {\n return client.complete(args.params);\n });\n};\n","import { Server } from \"@modelcontextprotocol/sdk/server/index.js\";\nimport {\n EventStore,\n StreamableHTTPServerTransport,\n} from \"@modelcontextprotocol/sdk/server/streamableHttp.js\";\nimport { isInitializeRequest } from \"@modelcontextprotocol/sdk/types.js\";\nimport http from \"http\";\nimport { randomUUID } from \"node:crypto\";\n\nimport { InMemoryEventStore } from \"./InMemoryEventStore.js\";\n\nexport type SSEServer = {\n close: () => Promise<void>;\n};\n\ntype ServerLike = {\n close: Server[\"close\"];\n connect: Server[\"connect\"];\n};\n\nexport const startHTTPStreamServer = async <T extends ServerLike>({\n createServer,\n endpoint,\n eventStore,\n onClose,\n onConnect,\n onUnhandledRequest,\n port,\n}: {\n createServer: (request: http.IncomingMessage) => Promise<T>;\n endpoint: string;\n eventStore?: EventStore;\n onClose?: (server: T) => void;\n onConnect?: (server: T) => void;\n onUnhandledRequest?: (\n req: http.IncomingMessage,\n res: http.ServerResponse,\n ) => Promise<void>;\n port: number;\n}): Promise<SSEServer> => {\n const activeTransports: Record<\n string,\n {\n server: T;\n transport: StreamableHTTPServerTransport;\n }\n > = {};\n\n /**\n * @author https://dev.classmethod.jp/articles/mcp-sse/\n */\n const httpServer = http.createServer(async (req, res) => {\n if (req.headers.origin) {\n try {\n const origin = new URL(req.headers.origin);\n\n res.setHeader(\"Access-Control-Allow-Origin\", origin.origin);\n res.setHeader(\"Access-Control-Allow-Credentials\", \"true\");\n res.setHeader(\"Access-Control-Allow-Methods\", \"GET, POST, OPTIONS\");\n res.setHeader(\"Access-Control-Allow-Headers\", \"*\");\n } catch (error) {\n console.error(\"Error parsing origin:\", error);\n }\n }\n\n if (req.method === \"OPTIONS\") {\n res.writeHead(204);\n res.end();\n return;\n }\n\n if (req.method === \"GET\" && req.url === `/ping`) {\n res.writeHead(200).end(\"pong\");\n return;\n }\n\n if (\n req.method === \"POST\" &&\n new URL(req.url!, \"http://localhost\").pathname === endpoint\n ) {\n try {\n const sessionId = Array.isArray(req.headers[\"mcp-session-id\"])\n ? req.headers[\"mcp-session-id\"][0]\n : req.headers[\"mcp-session-id\"];\n let transport: StreamableHTTPServerTransport;\n let server: T;\n\n const body = await getBody(req);\n\n if (sessionId && activeTransports[sessionId]) {\n transport = activeTransports[sessionId].transport;\n server = activeTransports[sessionId].server;\n } else if (!sessionId && isInitializeRequest(body)) {\n // Create a new transport for the session\n transport = new StreamableHTTPServerTransport({\n eventStore: eventStore || new InMemoryEventStore(),\n onsessioninitialized: (_sessionId) => {\n // add only when the id Sesison id is generated\n activeTransports[_sessionId] = {\n server,\n transport,\n };\n },\n sessionIdGenerator: randomUUID,\n });\n\n // Handle the server close event\n transport.onclose = async () => {\n const sid = transport.sessionId;\n if (sid && activeTransports[sid]) {\n onClose?.(server);\n try {\n await server.close();\n } catch (error) {\n console.error(\"Error closing server:\", error);\n }\n delete activeTransports[sid];\n }\n };\n\n // Create the server\n try {\n server = await createServer(req);\n } catch (error) {\n if (error instanceof Response) {\n res.writeHead(error.status).end(error.statusText);\n return;\n }\n res.writeHead(500).end(\"Error creating server\");\n return;\n }\n\n server.connect(transport);\n onConnect?.(server);\n\n await transport.handleRequest(req, res, body);\n return;\n } else {\n // Error if the server is not created but the request is not an initialize request\n res.setHeader(\"Content-Type\", \"application/json\");\n res.writeHead(400).end(\n JSON.stringify({\n error: {\n code: -32000,\n message: \"Bad Request: No valid session ID provided\",\n },\n id: null,\n jsonrpc: \"2.0\",\n }),\n );\n\n return;\n }\n\n // Handle ther request if the server is already created\n await transport.handleRequest(req, res, body);\n } catch (error) {\n console.error(\"Error handling request:\", error);\n res.setHeader(\"Content-Type\", \"application/json\");\n res.writeHead(500).end(\n JSON.stringify({\n error: { code: -32603, message: \"Internal Server Error\" },\n id: null,\n jsonrpc: \"2.0\",\n }),\n );\n }\n return;\n }\n\n if (\n req.method === \"GET\" &&\n new URL(req.url!, \"http://localhost\").pathname === endpoint\n ) {\n const sessionId = req.headers[\"mcp-session-id\"] as string | undefined;\n const activeTransport:\n | {\n server: T;\n transport: StreamableHTTPServerTransport;\n }\n | undefined = sessionId ? activeTransports[sessionId] : undefined;\n\n if (!sessionId) {\n res.writeHead(400).end(\"No sessionId\");\n return;\n }\n\n if (!activeTransport) {\n res.writeHead(400).end(\"No active transport\");\n return;\n }\n\n const lastEventId = req.headers[\"last-event-id\"] as string | undefined;\n if (lastEventId) {\n console.log(`Client reconnecting with Last-Event-ID: ${lastEventId}`);\n } else {\n console.log(`Establishing new SSE stream for session ${sessionId}`);\n }\n\n await activeTransport.transport.handleRequest(req, res);\n return;\n }\n\n if (\n req.method === \"DELETE\" &&\n new URL(req.url!, \"http://localhost\").pathname === endpoint\n ) {\n console.log(\"received delete request\");\n const sessionId = req.headers[\"mcp-session-id\"] as string | undefined;\n if (!sessionId) {\n res.writeHead(400).end(\"Invalid or missing sessionId\");\n return;\n }\n\n console.log(\"received delete request for session\", sessionId);\n\n const { server, transport } = activeTransports[sessionId];\n if (!transport) {\n res.writeHead(400).end(\"No active transport\");\n return;\n }\n\n try {\n await transport.handleRequest(req, res);\n onClose?.(server);\n } catch (error) {\n console.error(\"Error handling delete request:\", error);\n res.writeHead(500).end(\"Error handling delete request\");\n }\n\n return;\n }\n\n if (onUnhandledRequest) {\n await onUnhandledRequest(req, res);\n } else {\n res.writeHead(404).end();\n }\n });\n\n await new Promise((resolve) => {\n httpServer.listen(port, \"::\", () => {\n resolve(undefined);\n });\n });\n\n return {\n close: async () => {\n for (const transport of Object.values(activeTransports)) {\n await transport.transport.close();\n }\n\n return new Promise((resolve, reject) => {\n httpServer.close((error) => {\n if (error) {\n reject(error);\n\n return;\n }\n\n resolve();\n });\n });\n },\n };\n};\n\nfunction getBody(request: http.IncomingMessage) {\n return new Promise((resolve) => {\n const bodyParts: Buffer[] = [];\n let body: string;\n request\n .on(\"data\", (chunk) => {\n bodyParts.push(chunk);\n })\n .on(\"end\", () => {\n body = Buffer.concat(bodyParts).toString();\n resolve(JSON.parse(body));\n });\n });\n}\n","import { Server } from \"@modelcontextprotocol/sdk/server/index.js\";\nimport { SSEServerTransport } from \"@modelcontextprotocol/sdk/server/sse.js\";\nimport http from \"http\";\n\nexport type SSEServer = {\n close: () => Promise<void>;\n};\n\ntype ServerLike = {\n close: Server[\"close\"];\n connect: Server[\"connect\"];\n};\n\nexport const startSSEServer = async <T extends ServerLike>({\n createServer,\n endpoint,\n onClose,\n onConnect,\n onUnhandledRequest,\n port,\n}: {\n createServer: (request: http.IncomingMessage) => Promise<T>;\n endpoint: string;\n onClose?: (server: T) => void;\n onConnect?: (server: T) => void;\n onUnhandledRequest?: (\n req: http.IncomingMessage,\n res: http.ServerResponse,\n ) => Promise<void>;\n port: number;\n}): Promise<SSEServer> => {\n const activeTransports: Record<string, SSEServerTransport> = {};\n\n /**\n * @author https://dev.classmethod.jp/articles/mcp-sse/\n */\n const httpServer = http.createServer(async (req, res) => {\n if (req.headers.origin) {\n try {\n const origin = new URL(req.headers.origin);\n\n res.setHeader(\"Access-Control-Allow-Origin\", origin.origin);\n res.setHeader(\"Access-Control-Allow-Credentials\", \"true\");\n res.setHeader(\"Access-Control-Allow-Methods\", \"GET, POST, OPTIONS\");\n res.setHeader(\"Access-Control-Allow-Headers\", \"*\");\n } catch (error) {\n console.error(\"Error parsing origin:\", error);\n }\n }\n\n if (req.method === \"OPTIONS\") {\n res.writeHead(204);\n res.end();\n return;\n }\n\n if (req.method === \"GET\" && req.url === \"/health\") {\n res.writeHead(200, { \"Content-Type\": \"text/plain\" }).end(\"OK\");\n return;\n }\n\n if (req.method === \"GET\" && req.url === `/ping`) {\n res.writeHead(200).end(\"pong\");\n\n return;\n }\n\n if (\n req.method === \"GET\" &&\n new URL(req.url!, \"http://localhost\").pathname === endpoint\n ) {\n const transport = new SSEServerTransport(\"/messages\", res);\n\n let server: T;\n\n try {\n server = await createServer(req);\n } catch (error) {\n if (error instanceof Response) {\n res.writeHead(error.status).end(error.statusText);\n\n return;\n }\n\n res.writeHead(500).end(\"Error creating server\");\n\n return;\n }\n\n activeTransports[transport.sessionId] = transport;\n\n let closed = false;\n\n res.on(\"close\", async () => {\n closed = true;\n\n try {\n await server.close();\n } catch (error) {\n console.error(\"Error closing server:\", error);\n }\n\n delete activeTransports[transport.sessionId];\n\n onClose?.(server);\n });\n\n try {\n await server.connect(transport);\n\n await transport.send({\n jsonrpc: \"2.0\",\n method: \"sse/connection\",\n params: { message: \"SSE Connection established\" },\n });\n\n onConnect?.(server);\n } catch (error) {\n if (!closed) {\n console.error(\"Error connecting to server:\", error);\n\n res.writeHead(500).end(\"Error connecting to server\");\n }\n }\n\n return;\n }\n\n if (req.method === \"POST\" && req.url?.startsWith(\"/messages\")) {\n const sessionId = new URL(\n req.url,\n \"https://example.com\",\n ).searchParams.get(\"sessionId\");\n\n if (!sessionId) {\n res.writeHead(400).end(\"No sessionId\");\n\n return;\n }\n\n const activeTransport: SSEServerTransport | undefined =\n activeTransports[sessionId];\n\n if (!activeTransport) {\n res.writeHead(400).end(\"No active transport\");\n\n return;\n }\n\n await activeTransport.handlePostMessage(req, res);\n\n return;\n }\n\n if (onUnhandledRequest) {\n await onUnhandledRequest(req, res);\n } else {\n res.writeHead(404).end();\n }\n });\n\n await new Promise((resolve) => {\n httpServer.listen(port, \"::\", () => {\n resolve(undefined);\n });\n });\n\n return {\n close: async () => {\n for (const transport of Object.values(activeTransports)) {\n await transport.close();\n }\n\n return new Promise((resolve, reject) => {\n httpServer.close((error) => {\n if (error) {\n reject(error);\n\n return;\n }\n\n resolve();\n });\n });\n },\n };\n};\n"],"mappings":"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","names":["http"]}