@jissp/nestjs-mcp-server 0.0.7 → 0.0.9
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/base.executor.d.ts +4 -1
- package/dist/decorators/mcp-schema-property.decorator.d.ts +5 -0
- package/dist/decorators/mcp-schema-property.decorator.js.map +1 -1
- package/dist/decorators/mcp-tool.decorator.d.ts +4 -0
- package/dist/decorators/mcp-tool.decorator.js.map +1 -1
- package/dist/index.d.ts +0 -1
- package/dist/index.js +0 -1
- package/dist/index.js.map +1 -1
- package/dist/mcp-metadata-input-schema.builder.d.ts +1 -0
- package/dist/mcp-metadata-input-schema.builder.js +24 -4
- package/dist/mcp-metadata-input-schema.builder.js.map +1 -1
- package/dist/mcp-metadata-registry.service.d.ts +2 -1
- package/dist/mcp-metadata-registry.service.js.map +1 -1
- package/dist/mcp-server.controller.d.ts +6 -3
- package/dist/mcp-server.controller.js +77 -23
- package/dist/mcp-server.controller.js.map +1 -1
- package/dist/mcp-server.service.js +4 -4
- package/dist/mcp-server.service.js.map +1 -1
- package/dist/mcp-server.types.d.ts +5 -1
- package/package.json +3 -2
- package/dist/transports/sse-http-transport.d.ts +0 -18
- package/dist/transports/sse-http-transport.js +0 -76
- package/dist/transports/sse-http-transport.js.map +0 -1
package/dist/base.executor.d.ts
CHANGED
|
@@ -1,4 +1,7 @@
|
|
|
1
|
+
import type { RequestHandlerExtra } from '@modelcontextprotocol/sdk/shared/protocol.js';
|
|
2
|
+
import type { ServerNotification, ServerRequest } from '@modelcontextprotocol/sdk/types.js';
|
|
1
3
|
import { JsonRpcToolRequest } from './mcp-server.types';
|
|
4
|
+
export type ExecutorExtra = RequestHandlerExtra<ServerRequest, ServerNotification>;
|
|
2
5
|
export interface BaseExecutor<T = unknown> {
|
|
3
|
-
execute: (request: JsonRpcToolRequest) => T | Promise<T>;
|
|
6
|
+
execute: (request: JsonRpcToolRequest, extra: ExecutorExtra) => T | Promise<T>;
|
|
4
7
|
}
|
|
@@ -1,7 +1,12 @@
|
|
|
1
|
+
import { ConstructorType } from '@jissp/metadata-scanner';
|
|
2
|
+
import { InputSchemaProperty } from './mcp-tool.decorator';
|
|
1
3
|
export declare const MCP_SCHEMA_PROPERTIES_METADATA = "MCP_SCHEMA_PROPERTIES_METADATA";
|
|
2
4
|
export interface McpSchemaPropertyOptions {
|
|
3
5
|
type: string;
|
|
4
6
|
description: string;
|
|
5
7
|
isRequired: boolean;
|
|
8
|
+
enum?: (string | number)[];
|
|
9
|
+
items?: ConstructorType | InputSchemaProperty;
|
|
10
|
+
properties?: ConstructorType;
|
|
6
11
|
}
|
|
7
12
|
export declare const McpSchemaProperty: (options?: McpSchemaPropertyOptions | undefined) => (...args: [target: Object, propertyKey: string | symbol]) => void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mcp-schema-property.decorator.js","sourceRoot":"","sources":["../../lib/mcp-server/decorators/mcp-schema-property.decorator.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"mcp-schema-property.decorator.js","sourceRoot":"","sources":["../../lib/mcp-server/decorators/mcp-schema-property.decorator.ts"],"names":[],"mappings":";;;AAAA,8DAGiC;AAGpB,QAAA,8BAA8B,GAAG,gCAAgC,CAAC;AAmBlE,QAAA,iBAAiB,GAC5B,IAAA,0CAAuB,EACrB,sCAA8B,CAC/B,CAAC"}
|
|
@@ -12,6 +12,10 @@ export interface JsonSchema {
|
|
|
12
12
|
export interface InputSchemaProperty {
|
|
13
13
|
type: string;
|
|
14
14
|
description?: string;
|
|
15
|
+
enum?: (string | number)[];
|
|
16
|
+
items?: InputSchemaProperty;
|
|
17
|
+
properties?: InputSchemaProperties;
|
|
18
|
+
required?: string[];
|
|
15
19
|
}
|
|
16
20
|
export type InputSchemaProperties = Record<string, InputSchemaProperty>;
|
|
17
21
|
export declare const McpTool: import("@nestjs/core").ReflectableDecorator<McpToolOptions, McpToolOptions>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mcp-tool.decorator.js","sourceRoot":"","sources":["../../lib/mcp-server/decorators/mcp-tool.decorator.ts"],"names":[],"mappings":";;;AAAA,uCAAyC;
|
|
1
|
+
{"version":3,"file":"mcp-tool.decorator.js","sourceRoot":"","sources":["../../lib/mcp-server/decorators/mcp-tool.decorator.ts"],"names":[],"mappings":";;;AAAA,uCAAyC;AA0B5B,QAAA,OAAO,GAAG,gBAAS,CAAC,eAAe,EAAkB,CAAC"}
|
package/dist/index.d.ts
CHANGED
package/dist/index.js
CHANGED
|
@@ -23,5 +23,4 @@ __exportStar(require("./mcp-metadata-input-schema.builder"), exports);
|
|
|
23
23
|
__exportStar(require("./mcp-server.controller"), exports);
|
|
24
24
|
__exportStar(require("./mcp-server.service"), exports);
|
|
25
25
|
__exportStar(require("./mcp-server.module"), exports);
|
|
26
|
-
__exportStar(require("./transports/sse-http-transport"), exports);
|
|
27
26
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../lib/mcp-server/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAAyB;AACzB,+CAA6B;AAC7B,qDAAmC;AACnC,kDAAgC;AAChC,kEAAgD;AAChD,sEAAoD;AACpD,0DAAwC;AACxC,uDAAqC;AACrC,sDAAoC
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../lib/mcp-server/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAAyB;AACzB,+CAA6B;AAC7B,qDAAmC;AACnC,kDAAgC;AAChC,kEAAgD;AAChD,sEAAoD;AACpD,0DAAwC;AACxC,uDAAqC;AACrC,sDAAoC"}
|
|
@@ -35,13 +35,33 @@ let McpMetadataInputSchemaBuilder = class McpMetadataInputSchemaBuilder {
|
|
|
35
35
|
buildSchemaProperties(propertiesMetadata) {
|
|
36
36
|
const entries = propertiesMetadata.map(({ key, metadata }) => [
|
|
37
37
|
key,
|
|
38
|
-
|
|
39
|
-
type: metadata.type,
|
|
40
|
-
description: metadata.description,
|
|
41
|
-
},
|
|
38
|
+
this.toInputSchemaProperty(metadata),
|
|
42
39
|
]);
|
|
43
40
|
return Object.fromEntries(entries);
|
|
44
41
|
}
|
|
42
|
+
toInputSchemaProperty(options) {
|
|
43
|
+
const property = {
|
|
44
|
+
type: options.type,
|
|
45
|
+
description: options.description,
|
|
46
|
+
};
|
|
47
|
+
if (options.enum) {
|
|
48
|
+
property.enum = options.enum;
|
|
49
|
+
}
|
|
50
|
+
if (options.items !== undefined) {
|
|
51
|
+
property.items = (0, metadata_scanner_1.isConstructorType)(options.items)
|
|
52
|
+
? this.generateInputSchema(options.items)
|
|
53
|
+
: options.items;
|
|
54
|
+
}
|
|
55
|
+
if (options.properties !== undefined &&
|
|
56
|
+
(0, metadata_scanner_1.isConstructorType)(options.properties)) {
|
|
57
|
+
const nested = this.generateInputSchema(options.properties);
|
|
58
|
+
property.properties = nested.properties;
|
|
59
|
+
if (nested.required && nested.required.length > 0) {
|
|
60
|
+
property.required = nested.required;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
return property;
|
|
64
|
+
}
|
|
45
65
|
buildRequired(propertiesMetadata) {
|
|
46
66
|
const filteredEntries = propertiesMetadata.filter(({ metadata: { isRequired } }) => {
|
|
47
67
|
return isRequired;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mcp-metadata-input-schema.builder.js","sourceRoot":"","sources":["../lib/mcp-server/mcp-metadata-input-schema.builder.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAC5C,8DAKiC;AACjC,6CAOsB;AAGf,IAAM,6BAA6B,GAAnC,MAAM,6BAA6B;IAErB;IADnB,YACmB,sBAA8C;QAA9C,2BAAsB,GAAtB,sBAAsB,CAAwB;IAC9D,CAAC;IAEG,KAAK,CAAC,cAA8B;QACzC,IAAI,CAAC,IAAA,oCAAiB,EAAC,cAAc,CAAC,WAAW,CAAC,EAAE,CAAC;YACnD,OAAO,cAAc,CAAC,WAAW,CAAC;QACpC,CAAC;QAED,OAAO,IAAI,CAAC,mBAAmB,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;IAC9D,CAAC;IAEO,mBAAmB,CAAC,gBAAiC;QAC3D,MAAM,UAAU,GACd,IAAI,CAAC,sBAAsB,CAAC,cAAc,CACxC,2CAA8B,EAC9B,gBAAgB,CACjB,CAAC;QAEJ,OAAO;YACL,IAAI,EAAE,QAAQ;YACd,UAAU,EAAE,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC;YAClD,QAAQ,EAAE,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC;SACzC,CAAC;IACJ,CAAC;IAEO,qBAAqB,CAC3B,kBAAuE;QAEvE,MAAM,OAAO,GAAG,kBAAkB,CAAC,GAAG,CACpC,CAAC,EAAE,GAAG,EAAE,QAAQ,EAAE,EAAiC,EAAE,CAAC;YACpD,GAAG;YACH;
|
|
1
|
+
{"version":3,"file":"mcp-metadata-input-schema.builder.js","sourceRoot":"","sources":["../lib/mcp-server/mcp-metadata-input-schema.builder.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAC5C,8DAKiC;AACjC,6CAOsB;AAGf,IAAM,6BAA6B,GAAnC,MAAM,6BAA6B;IAErB;IADnB,YACmB,sBAA8C;QAA9C,2BAAsB,GAAtB,sBAAsB,CAAwB;IAC9D,CAAC;IAEG,KAAK,CAAC,cAA8B;QACzC,IAAI,CAAC,IAAA,oCAAiB,EAAC,cAAc,CAAC,WAAW,CAAC,EAAE,CAAC;YACnD,OAAO,cAAc,CAAC,WAAW,CAAC;QACpC,CAAC;QAED,OAAO,IAAI,CAAC,mBAAmB,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;IAC9D,CAAC;IAEO,mBAAmB,CAAC,gBAAiC;QAC3D,MAAM,UAAU,GACd,IAAI,CAAC,sBAAsB,CAAC,cAAc,CACxC,2CAA8B,EAC9B,gBAAgB,CACjB,CAAC;QAEJ,OAAO;YACL,IAAI,EAAE,QAAQ;YACd,UAAU,EAAE,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC;YAClD,QAAQ,EAAE,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC;SACzC,CAAC;IACJ,CAAC;IAEO,qBAAqB,CAC3B,kBAAuE;QAEvE,MAAM,OAAO,GAAG,kBAAkB,CAAC,GAAG,CACpC,CAAC,EAAE,GAAG,EAAE,QAAQ,EAAE,EAAiC,EAAE,CAAC;YACpD,GAAG;YACH,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC;SACrC,CACF,CAAC;QAEF,OAAO,MAAM,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;IACrC,CAAC;IAEO,qBAAqB,CAC3B,OAAiC;QAEjC,MAAM,QAAQ,GAAwB;YACpC,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,WAAW,EAAE,OAAO,CAAC,WAAW;SACjC,CAAC;QAEF,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;YACjB,QAAQ,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;QAC/B,CAAC;QAED,IAAI,OAAO,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YAChC,QAAQ,CAAC,KAAK,GAAG,IAAA,oCAAiB,EAAC,OAAO,CAAC,KAAK,CAAC;gBAC/C,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,KAAK,CAAC;gBACzC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC;QACpB,CAAC;QAED,IACE,OAAO,CAAC,UAAU,KAAK,SAAS;YAChC,IAAA,oCAAiB,EAAC,OAAO,CAAC,UAAU,CAAC,EACrC,CAAC;YACD,MAAM,MAAM,GAAG,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;YAC5D,QAAQ,CAAC,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC;YACxC,IAAI,MAAM,CAAC,QAAQ,IAAI,MAAM,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAClD,QAAQ,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;YACtC,CAAC;QACH,CAAC;QAED,OAAO,QAAQ,CAAC;IAClB,CAAC;IAEO,aAAa,CACnB,kBAAuE;QAEvE,MAAM,eAAe,GAAG,kBAAkB,CAAC,MAAM,CAC/C,CAAC,EAAE,QAAQ,EAAE,EAAE,UAAU,EAAE,EAAE,EAAE,EAAE;YAC/B,OAAO,UAAU,CAAC;QACpB,CAAC,CACF,CAAC;QAEF,OAAO,eAAe,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC;IAC/C,CAAC;CACF,CAAA;AAnFY,sEAA6B;wCAA7B,6BAA6B;IADzC,IAAA,mBAAU,GAAE;qCAGgC,yCAAsB;GAFtD,6BAA6B,CAmFzC"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { OnModuleInit } from '@nestjs/common';
|
|
2
2
|
import { MetadataScannerService } from '@jissp/metadata-scanner';
|
|
3
3
|
import { McpResourceOptions, McpToolOptions } from './decorators';
|
|
4
|
+
import { McpResourceHandler } from './mcp-server.types';
|
|
4
5
|
import { BaseExecutor } from './base.executor';
|
|
5
6
|
import { McpMetadataInputSchemaBuilder } from './mcp-metadata-input-schema.builder';
|
|
6
7
|
export declare class McpMetadataRegistryService implements OnModuleInit {
|
|
@@ -16,7 +17,7 @@ export declare class McpMetadataRegistryService implements OnModuleInit {
|
|
|
16
17
|
getToolExecutor(name: string): BaseExecutor<unknown> | undefined;
|
|
17
18
|
getResources(): McpResourceOptions[];
|
|
18
19
|
getResourceHandler(uri: string): {
|
|
19
|
-
handler:
|
|
20
|
+
handler: McpResourceHandler;
|
|
20
21
|
params: Record<string, string>;
|
|
21
22
|
} | null;
|
|
22
23
|
private matchUri;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mcp-metadata-registry.service.js","sourceRoot":"","sources":["../lib/mcp-server/mcp-metadata-registry.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA0D;AAC1D,8DAAiE;AACjE,6CAKsB;
|
|
1
|
+
{"version":3,"file":"mcp-metadata-registry.service.js","sourceRoot":"","sources":["../lib/mcp-server/mcp-metadata-registry.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,8 +2,11 @@ import type { Request, Response } from 'express';
|
|
|
2
2
|
import { McpServerService } from './mcp-server.service';
|
|
3
3
|
export declare class McpServerController {
|
|
4
4
|
private readonly mcpService;
|
|
5
|
-
private readonly
|
|
5
|
+
private readonly transports;
|
|
6
6
|
constructor(mcpService: McpServerService);
|
|
7
|
-
|
|
8
|
-
|
|
7
|
+
handlePost(req: Request, res: Response): Promise<void>;
|
|
8
|
+
handleGet(req: Request, res: Response): Promise<void>;
|
|
9
|
+
handleDelete(req: Request, res: Response): Promise<void>;
|
|
10
|
+
private handleSessionRequest;
|
|
11
|
+
private createTransport;
|
|
9
12
|
}
|
|
@@ -14,53 +14,107 @@ var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
|
14
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
15
|
exports.McpServerController = void 0;
|
|
16
16
|
const common_1 = require("@nestjs/common");
|
|
17
|
+
const streamableHttp_js_1 = require("@modelcontextprotocol/sdk/server/streamableHttp.js");
|
|
18
|
+
const types_js_1 = require("@modelcontextprotocol/sdk/types.js");
|
|
19
|
+
const node_crypto_1 = require("node:crypto");
|
|
17
20
|
const mcp_server_service_1 = require("./mcp-server.service");
|
|
18
|
-
const sse_http_transport_1 = require("./transports/sse-http-transport");
|
|
19
21
|
let McpServerController = class McpServerController {
|
|
20
22
|
mcpService;
|
|
21
|
-
|
|
23
|
+
transports = new Map();
|
|
22
24
|
constructor(mcpService) {
|
|
23
25
|
this.mcpService = mcpService;
|
|
24
26
|
}
|
|
25
|
-
async
|
|
26
|
-
const
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
this.
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
27
|
+
async handlePost(req, res) {
|
|
28
|
+
const sessionId = req.headers['mcp-session-id'];
|
|
29
|
+
let transport;
|
|
30
|
+
if (sessionId && this.transports.has(sessionId)) {
|
|
31
|
+
transport = this.transports.get(sessionId);
|
|
32
|
+
}
|
|
33
|
+
else if (!sessionId && (0, types_js_1.isInitializeRequest)(req.body)) {
|
|
34
|
+
transport = await this.createTransport();
|
|
35
|
+
}
|
|
36
|
+
else if (sessionId) {
|
|
37
|
+
res.status(common_1.HttpStatus.NOT_FOUND).json({
|
|
38
|
+
jsonrpc: '2.0',
|
|
39
|
+
error: { code: -32001, message: 'Session not found' },
|
|
40
|
+
id: null,
|
|
41
|
+
});
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
res.status(common_1.HttpStatus.BAD_REQUEST).json({
|
|
46
|
+
jsonrpc: '2.0',
|
|
47
|
+
error: {
|
|
48
|
+
code: -32000,
|
|
49
|
+
message: 'Bad Request: No valid session ID provided',
|
|
50
|
+
},
|
|
51
|
+
id: null,
|
|
52
|
+
});
|
|
53
|
+
return;
|
|
54
|
+
}
|
|
55
|
+
await transport.handleRequest(req, res, req.body);
|
|
56
|
+
}
|
|
57
|
+
async handleGet(req, res) {
|
|
58
|
+
await this.handleSessionRequest(req, res);
|
|
35
59
|
}
|
|
36
|
-
async
|
|
37
|
-
|
|
38
|
-
|
|
60
|
+
async handleDelete(req, res) {
|
|
61
|
+
await this.handleSessionRequest(req, res);
|
|
62
|
+
}
|
|
63
|
+
async handleSessionRequest(req, res) {
|
|
64
|
+
const sessionId = req.headers['mcp-session-id'];
|
|
65
|
+
if (!sessionId) {
|
|
66
|
+
res.status(common_1.HttpStatus.BAD_REQUEST).send('Missing session ID');
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
const transport = this.transports.get(sessionId);
|
|
39
70
|
if (!transport) {
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
.json({ error: 'Session not found' });
|
|
71
|
+
res.status(common_1.HttpStatus.NOT_FOUND).send('Session not found');
|
|
72
|
+
return;
|
|
43
73
|
}
|
|
44
|
-
await transport.
|
|
74
|
+
await transport.handleRequest(req, res);
|
|
75
|
+
}
|
|
76
|
+
async createTransport() {
|
|
77
|
+
const transport = new streamableHttp_js_1.StreamableHTTPServerTransport({
|
|
78
|
+
sessionIdGenerator: () => (0, node_crypto_1.randomUUID)(),
|
|
79
|
+
onsessioninitialized: (sessionId) => {
|
|
80
|
+
this.transports.set(sessionId, transport);
|
|
81
|
+
},
|
|
82
|
+
});
|
|
83
|
+
transport.onclose = () => {
|
|
84
|
+
if (transport.sessionId) {
|
|
85
|
+
this.transports.delete(transport.sessionId);
|
|
86
|
+
}
|
|
87
|
+
};
|
|
88
|
+
const server = this.mcpService.createConfiguredServer();
|
|
89
|
+
await server.connect(transport);
|
|
90
|
+
return transport;
|
|
45
91
|
}
|
|
46
92
|
};
|
|
47
93
|
exports.McpServerController = McpServerController;
|
|
48
94
|
__decorate([
|
|
49
|
-
(0, common_1.
|
|
95
|
+
(0, common_1.Post)(),
|
|
96
|
+
__param(0, (0, common_1.Req)()),
|
|
97
|
+
__param(1, (0, common_1.Res)()),
|
|
98
|
+
__metadata("design:type", Function),
|
|
99
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
100
|
+
__metadata("design:returntype", Promise)
|
|
101
|
+
], McpServerController.prototype, "handlePost", null);
|
|
102
|
+
__decorate([
|
|
103
|
+
(0, common_1.Get)(),
|
|
50
104
|
__param(0, (0, common_1.Req)()),
|
|
51
105
|
__param(1, (0, common_1.Res)()),
|
|
52
106
|
__metadata("design:type", Function),
|
|
53
107
|
__metadata("design:paramtypes", [Object, Object]),
|
|
54
108
|
__metadata("design:returntype", Promise)
|
|
55
|
-
], McpServerController.prototype, "
|
|
109
|
+
], McpServerController.prototype, "handleGet", null);
|
|
56
110
|
__decorate([
|
|
57
|
-
(0, common_1.
|
|
111
|
+
(0, common_1.Delete)(),
|
|
58
112
|
__param(0, (0, common_1.Req)()),
|
|
59
113
|
__param(1, (0, common_1.Res)()),
|
|
60
114
|
__metadata("design:type", Function),
|
|
61
115
|
__metadata("design:paramtypes", [Object, Object]),
|
|
62
116
|
__metadata("design:returntype", Promise)
|
|
63
|
-
], McpServerController.prototype, "
|
|
117
|
+
], McpServerController.prototype, "handleDelete", null);
|
|
64
118
|
exports.McpServerController = McpServerController = __decorate([
|
|
65
119
|
(0, common_1.Controller)('mcp'),
|
|
66
120
|
__metadata("design:paramtypes", [mcp_server_service_1.McpServerService])
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mcp-server.controller.js","sourceRoot":"","sources":["../lib/mcp-server/mcp-server.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"mcp-server.controller.js","sourceRoot":"","sources":["../lib/mcp-server/mcp-server.controller.ts"],"names":[],"mappings":"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"}
|
|
@@ -31,7 +31,7 @@ let McpServerService = class McpServerService {
|
|
|
31
31
|
},
|
|
32
32
|
})),
|
|
33
33
|
}));
|
|
34
|
-
server.setRequestHandler(types_js_1.CallToolRequestSchema, async (req) => {
|
|
34
|
+
server.setRequestHandler(types_js_1.CallToolRequestSchema, async (req, extra) => {
|
|
35
35
|
const executor = this.registry.getToolExecutor(req.params.name);
|
|
36
36
|
if (!executor) {
|
|
37
37
|
throw new Error(`Tool not found: ${req.params.name}`);
|
|
@@ -44,7 +44,7 @@ let McpServerService = class McpServerService {
|
|
|
44
44
|
name: req.params.name,
|
|
45
45
|
arguments: req.params.arguments ?? {},
|
|
46
46
|
},
|
|
47
|
-
});
|
|
47
|
+
}, extra);
|
|
48
48
|
return {
|
|
49
49
|
content: [{ type: 'text', text: JSON.stringify(result) }],
|
|
50
50
|
};
|
|
@@ -52,7 +52,7 @@ let McpServerService = class McpServerService {
|
|
|
52
52
|
server.setRequestHandler(types_js_1.ListResourcesRequestSchema, () => ({
|
|
53
53
|
resources: this.registry.getResources(),
|
|
54
54
|
}));
|
|
55
|
-
server.setRequestHandler(types_js_1.ReadResourceRequestSchema, async (req) => {
|
|
55
|
+
server.setRequestHandler(types_js_1.ReadResourceRequestSchema, async (req, extra) => {
|
|
56
56
|
const uri = req.params.uri;
|
|
57
57
|
const match = this.registry.getResourceHandler(uri);
|
|
58
58
|
if (!match) {
|
|
@@ -63,7 +63,7 @@ let McpServerService = class McpServerService {
|
|
|
63
63
|
id: undefined,
|
|
64
64
|
method: 'resources/read',
|
|
65
65
|
params: { arguments: match.params },
|
|
66
|
-
});
|
|
66
|
+
}, extra);
|
|
67
67
|
return {
|
|
68
68
|
contents: [
|
|
69
69
|
{
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mcp-server.service.js","sourceRoot":"","sources":["../lib/mcp-server/mcp-server.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAC5C,wEAAmE;AACnE,iEAK4C;
|
|
1
|
+
{"version":3,"file":"mcp-server.service.js","sourceRoot":"","sources":["../lib/mcp-server/mcp-server.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ModuleMetadata, Provider } from '@nestjs/common';
|
|
2
|
-
import { BaseExecutor } from './base.executor';
|
|
2
|
+
import { BaseExecutor, ExecutorExtra } from './base.executor';
|
|
3
3
|
export interface McpServerConfig {
|
|
4
4
|
name: string;
|
|
5
5
|
version: string;
|
|
@@ -18,3 +18,7 @@ export type JsonRpcToolRequest<T = unknown> = JsonRpcRequest<{
|
|
|
18
18
|
name: string;
|
|
19
19
|
arguments: T;
|
|
20
20
|
}>;
|
|
21
|
+
export type JsonRpcResourceRequest<T = unknown> = JsonRpcRequest<{
|
|
22
|
+
arguments: T;
|
|
23
|
+
}>;
|
|
24
|
+
export type McpResourceHandler<T = unknown> = (request: JsonRpcResourceRequest<Record<string, string>>, extra: ExecutorExtra) => T | Promise<T>;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@jissp/nestjs-mcp-server",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.9",
|
|
4
4
|
"description": "NestJS-based MCP Server with metadata scanning support",
|
|
5
5
|
"author": "jissp <jisspant@gmail.com>",
|
|
6
6
|
"private": false,
|
|
@@ -52,7 +52,8 @@
|
|
|
52
52
|
"dependencies": {
|
|
53
53
|
"@jissp/metadata-scanner": "^0.0.4",
|
|
54
54
|
"@modelcontextprotocol/sdk": "^1.29.0",
|
|
55
|
-
"@nestjs/platform-express": "^11.1.18"
|
|
55
|
+
"@nestjs/platform-express": "^11.1.18",
|
|
56
|
+
"zod": "^3.25 || ^4.0"
|
|
56
57
|
},
|
|
57
58
|
"devDependencies": {
|
|
58
59
|
"@eslint/eslintrc": "^3.2.0",
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { Transport } from '@modelcontextprotocol/sdk/shared/transport.js';
|
|
2
|
-
import { JSONRPCMessage } from '@modelcontextprotocol/sdk/types.js';
|
|
3
|
-
import type { Request, Response } from 'express';
|
|
4
|
-
export declare class SseHttpTransport implements Transport {
|
|
5
|
-
private readonly _endpoint;
|
|
6
|
-
private _sessionId;
|
|
7
|
-
private _res;
|
|
8
|
-
onclose?: () => void;
|
|
9
|
-
onerror?: (error: Error) => void;
|
|
10
|
-
onmessage?: (message: JSONRPCMessage) => void;
|
|
11
|
-
constructor(_endpoint: string);
|
|
12
|
-
get sessionId(): string;
|
|
13
|
-
attachResponse(res: Response): void;
|
|
14
|
-
start(): Promise<void>;
|
|
15
|
-
send(message: JSONRPCMessage): Promise<void>;
|
|
16
|
-
close(): Promise<void>;
|
|
17
|
-
handlePostMessage(req: Request, res: Response): Promise<void>;
|
|
18
|
-
}
|
|
@@ -1,76 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.SseHttpTransport = void 0;
|
|
4
|
-
const types_js_1 = require("@modelcontextprotocol/sdk/types.js");
|
|
5
|
-
const node_crypto_1 = require("node:crypto");
|
|
6
|
-
class SseHttpTransport {
|
|
7
|
-
_endpoint;
|
|
8
|
-
_sessionId;
|
|
9
|
-
_res = null;
|
|
10
|
-
onclose;
|
|
11
|
-
onerror;
|
|
12
|
-
onmessage;
|
|
13
|
-
constructor(_endpoint) {
|
|
14
|
-
this._endpoint = _endpoint;
|
|
15
|
-
this._sessionId = (0, node_crypto_1.randomUUID)();
|
|
16
|
-
}
|
|
17
|
-
get sessionId() {
|
|
18
|
-
return this._sessionId;
|
|
19
|
-
}
|
|
20
|
-
attachResponse(res) {
|
|
21
|
-
this._res = res;
|
|
22
|
-
res.writeHead(200, {
|
|
23
|
-
'Content-Type': 'text/event-stream',
|
|
24
|
-
'Cache-Control': 'no-cache, no-transform',
|
|
25
|
-
Connection: 'keep-alive',
|
|
26
|
-
});
|
|
27
|
-
res.write(`event: endpoint\ndata: ${this._endpoint}?sessionId=${this._sessionId}\n\n`);
|
|
28
|
-
res.on('close', () => {
|
|
29
|
-
this._res = null;
|
|
30
|
-
this.onclose?.();
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
|
-
async start() {
|
|
34
|
-
}
|
|
35
|
-
async send(message) {
|
|
36
|
-
if (!this._res) {
|
|
37
|
-
throw new Error('SSE connection not established');
|
|
38
|
-
}
|
|
39
|
-
this._res.write(`event: message\ndata: ${JSON.stringify(message)}\n\n`);
|
|
40
|
-
}
|
|
41
|
-
async close() {
|
|
42
|
-
this._res?.end();
|
|
43
|
-
this._res = null;
|
|
44
|
-
this.onclose?.();
|
|
45
|
-
}
|
|
46
|
-
async handlePostMessage(req, res) {
|
|
47
|
-
if (!this._res) {
|
|
48
|
-
res.writeHead(500).end('SSE connection not established');
|
|
49
|
-
return;
|
|
50
|
-
}
|
|
51
|
-
let body;
|
|
52
|
-
try {
|
|
53
|
-
body = req.body;
|
|
54
|
-
if (!body || typeof body !== 'object') {
|
|
55
|
-
throw new Error('Invalid body');
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
catch (error) {
|
|
59
|
-
res.writeHead(400).end(String(error));
|
|
60
|
-
this.onerror?.(error);
|
|
61
|
-
return;
|
|
62
|
-
}
|
|
63
|
-
try {
|
|
64
|
-
const message = types_js_1.JSONRPCMessageSchema.parse(body);
|
|
65
|
-
this.onmessage?.(message);
|
|
66
|
-
}
|
|
67
|
-
catch (error) {
|
|
68
|
-
res.writeHead(400).end(`Invalid message: ${JSON.stringify(body)}`);
|
|
69
|
-
this.onerror?.(error);
|
|
70
|
-
return;
|
|
71
|
-
}
|
|
72
|
-
res.writeHead(202).end('Accepted');
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
exports.SseHttpTransport = SseHttpTransport;
|
|
76
|
-
//# sourceMappingURL=sse-http-transport.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sse-http-transport.js","sourceRoot":"","sources":["../../lib/mcp-server/transports/sse-http-transport.ts"],"names":[],"mappings":"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"}
|