@opensumi/ide-ai-native 3.7.1-next-1737628160.0 → 3.7.1-next-1737703128.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/browser/ai-core.contribution.d.ts +3 -0
- package/lib/browser/ai-core.contribution.d.ts.map +1 -1
- package/lib/browser/ai-core.contribution.js +31 -4
- package/lib/browser/ai-core.contribution.js.map +1 -1
- package/lib/browser/chat/chat-model.d.ts +2 -2
- package/lib/browser/chat/chat-model.d.ts.map +1 -1
- package/lib/browser/chat/chat-model.js +21 -9
- package/lib/browser/chat/chat-model.js.map +1 -1
- package/lib/browser/chat/chat-proxy.service.d.ts +1 -0
- package/lib/browser/chat/chat-proxy.service.d.ts.map +1 -1
- package/lib/browser/chat/chat-proxy.service.js +11 -0
- package/lib/browser/chat/chat-proxy.service.js.map +1 -1
- package/lib/browser/components/ChatEditor.d.ts +8 -0
- package/lib/browser/components/ChatEditor.d.ts.map +1 -1
- package/lib/browser/components/ChatEditor.js +8 -7
- package/lib/browser/components/ChatEditor.js.map +1 -1
- package/lib/browser/components/ChatReply.d.ts.map +1 -1
- package/lib/browser/components/ChatReply.js +33 -4
- package/lib/browser/components/ChatReply.js.map +1 -1
- package/lib/browser/components/ChatToolRender.d.ts +6 -0
- package/lib/browser/components/ChatToolRender.d.ts.map +1 -0
- package/lib/browser/components/ChatToolRender.js +24 -0
- package/lib/browser/components/ChatToolRender.js.map +1 -0
- package/lib/browser/components/components.module.less +32 -31
- package/lib/browser/contrib/intelligent-completions/index.d.ts +1 -5
- package/lib/browser/contrib/intelligent-completions/index.d.ts.map +1 -1
- package/lib/browser/contrib/intelligent-completions/index.js.map +1 -1
- package/lib/browser/contrib/intelligent-completions/intelligent-completions.controller.d.ts.map +1 -1
- package/lib/browser/contrib/intelligent-completions/intelligent-completions.controller.js +1 -2
- package/lib/browser/contrib/intelligent-completions/intelligent-completions.controller.js.map +1 -1
- package/lib/browser/contrib/intelligent-completions/source/base.d.ts +2 -1
- package/lib/browser/contrib/intelligent-completions/source/base.d.ts.map +1 -1
- package/lib/browser/contrib/intelligent-completions/source/base.js.map +1 -1
- package/lib/browser/contrib/intelligent-completions/source/line-change.source.d.ts +3 -2
- package/lib/browser/contrib/intelligent-completions/source/line-change.source.d.ts.map +1 -1
- package/lib/browser/contrib/intelligent-completions/source/line-change.source.js +21 -51
- package/lib/browser/contrib/intelligent-completions/source/line-change.source.js.map +1 -1
- package/lib/browser/index.d.ts +11 -3
- package/lib/browser/index.d.ts.map +1 -1
- package/lib/browser/index.js +39 -3
- package/lib/browser/index.js.map +1 -1
- package/lib/browser/mcp/mcp-server-proxy.service.d.ts +17 -0
- package/lib/browser/mcp/mcp-server-proxy.service.d.ts.map +1 -0
- package/lib/browser/mcp/mcp-server-proxy.service.js +36 -0
- package/lib/browser/mcp/mcp-server-proxy.service.js.map +1 -0
- package/lib/browser/mcp/mcp-server.feature.registry.d.ts +16 -0
- package/lib/browser/mcp/mcp-server.feature.registry.d.ts.map +1 -0
- package/lib/browser/mcp/mcp-server.feature.registry.js +45 -0
- package/lib/browser/mcp/mcp-server.feature.registry.js.map +1 -0
- package/lib/browser/mcp/tools/createNewFileWithText.d.ts +9 -0
- package/lib/browser/mcp/tools/createNewFileWithText.d.ts.map +1 -0
- package/lib/browser/mcp/tools/createNewFileWithText.js +84 -0
- package/lib/browser/mcp/tools/createNewFileWithText.js.map +1 -0
- package/lib/browser/mcp/tools/findFilesByNameSubstring.d.ts +9 -0
- package/lib/browser/mcp/tools/findFilesByNameSubstring.d.ts.map +1 -0
- package/lib/browser/mcp/tools/findFilesByNameSubstring.js +92 -0
- package/lib/browser/mcp/tools/findFilesByNameSubstring.js.map +1 -0
- package/lib/browser/mcp/tools/getCurrentFilePath.d.ts +8 -0
- package/lib/browser/mcp/tools/getCurrentFilePath.d.ts.map +1 -0
- package/lib/browser/mcp/tools/getCurrentFilePath.js +49 -0
- package/lib/browser/mcp/tools/getCurrentFilePath.js.map +1 -0
- package/lib/browser/mcp/tools/getDiagnosticsByPath.d.ts +10 -0
- package/lib/browser/mcp/tools/getDiagnosticsByPath.d.ts.map +1 -0
- package/lib/browser/mcp/tools/getDiagnosticsByPath.js +119 -0
- package/lib/browser/mcp/tools/getDiagnosticsByPath.js.map +1 -0
- package/lib/browser/mcp/tools/getFileTextByPath.d.ts +9 -0
- package/lib/browser/mcp/tools/getFileTextByPath.d.ts.map +1 -0
- package/lib/browser/mcp/tools/getFileTextByPath.js +97 -0
- package/lib/browser/mcp/tools/getFileTextByPath.js.map +1 -0
- package/lib/browser/mcp/tools/getOpenEditorFileDiagnostics.d.ts +11 -0
- package/lib/browser/mcp/tools/getOpenEditorFileDiagnostics.d.ts.map +1 -0
- package/lib/browser/mcp/tools/getOpenEditorFileDiagnostics.js +119 -0
- package/lib/browser/mcp/tools/getOpenEditorFileDiagnostics.js.map +1 -0
- package/lib/browser/mcp/tools/getOpenEditorFileText.d.ts +8 -0
- package/lib/browser/mcp/tools/getOpenEditorFileText.d.ts.map +1 -0
- package/lib/browser/mcp/tools/getOpenEditorFileText.js +50 -0
- package/lib/browser/mcp/tools/getOpenEditorFileText.js.map +1 -0
- package/lib/browser/mcp/tools/getSelectedText.d.ts +8 -0
- package/lib/browser/mcp/tools/getSelectedText.d.ts.map +1 -0
- package/lib/browser/mcp/tools/getSelectedText.js +57 -0
- package/lib/browser/mcp/tools/getSelectedText.js.map +1 -0
- package/lib/browser/preferences/schema.d.ts.map +1 -1
- package/lib/browser/preferences/schema.js +0 -4
- package/lib/browser/preferences/schema.js.map +1 -1
- package/lib/browser/types.d.ts +31 -0
- package/lib/browser/types.d.ts.map +1 -1
- package/lib/browser/types.js +4 -1
- package/lib/browser/types.js.map +1 -1
- package/lib/common/index.d.ts +5 -0
- package/lib/common/index.d.ts.map +1 -1
- package/lib/common/index.js +4 -1
- package/lib/common/index.js.map +1 -1
- package/lib/common/mcp-server-manager.d.ts +39 -0
- package/lib/common/mcp-server-manager.d.ts.map +1 -0
- package/lib/common/mcp-server-manager.js +6 -0
- package/lib/common/mcp-server-manager.js.map +1 -0
- package/lib/common/tool-invocation-registry.d.ts +67 -0
- package/lib/common/tool-invocation-registry.d.ts.map +1 -0
- package/lib/common/tool-invocation-registry.js +68 -0
- package/lib/common/tool-invocation-registry.js.map +1 -0
- package/lib/common/types.d.ts +14 -0
- package/lib/common/types.d.ts.map +1 -1
- package/lib/node/anthropic/anthropic-language-model.d.ts +13 -0
- package/lib/node/anthropic/anthropic-language-model.d.ts.map +1 -0
- package/lib/node/anthropic/anthropic-language-model.js +79 -0
- package/lib/node/anthropic/anthropic-language-model.js.map +1 -0
- package/lib/node/index.d.ts.map +1 -1
- package/lib/node/index.js +21 -0
- package/lib/node/index.js.map +1 -1
- package/lib/node/mcp/sumi-mcp-server.d.ts +84 -0
- package/lib/node/mcp/sumi-mcp-server.d.ts.map +1 -0
- package/lib/node/mcp/sumi-mcp-server.js +134 -0
- package/lib/node/mcp/sumi-mcp-server.js.map +1 -0
- package/lib/node/mcp-server-manager-impl.d.ts +20 -0
- package/lib/node/mcp-server-manager-impl.d.ts.map +1 -0
- package/lib/node/mcp-server-manager-impl.js +123 -0
- package/lib/node/mcp-server-manager-impl.js.map +1 -0
- package/lib/node/mcp-server.d.ts +205 -0
- package/lib/node/mcp-server.d.ts.map +1 -0
- package/lib/node/mcp-server.js +86 -0
- package/lib/node/mcp-server.js.map +1 -0
- package/lib/node/openai/openai-language-model.d.ts +12 -0
- package/lib/node/openai/openai-language-model.d.ts.map +1 -0
- package/lib/node/openai/openai-language-model.js +136 -0
- package/lib/node/openai/openai-language-model.js.map +1 -0
- package/package.json +26 -21
- package/src/browser/ai-core.contribution.ts +47 -4
- package/src/browser/chat/chat-model.ts +21 -9
- package/src/browser/chat/chat-proxy.service.ts +12 -0
- package/src/browser/components/ChatEditor.tsx +6 -4
- package/src/browser/components/ChatReply.tsx +40 -4
- package/src/browser/components/ChatToolRender.tsx +27 -0
- package/src/browser/components/components.module.less +32 -31
- package/src/browser/contrib/intelligent-completions/index.ts +2 -3
- package/src/browser/contrib/intelligent-completions/intelligent-completions.controller.ts +1 -2
- package/src/browser/contrib/intelligent-completions/source/base.ts +2 -0
- package/src/browser/contrib/intelligent-completions/source/line-change.source.ts +24 -79
- package/src/browser/index.ts +50 -4
- package/src/browser/mcp/mcp-server-proxy.service.ts +32 -0
- package/src/browser/mcp/mcp-server.feature.registry.ts +47 -0
- package/src/browser/mcp/tools/createNewFileWithText.ts +85 -0
- package/src/browser/mcp/tools/findFilesByNameSubstring.ts +93 -0
- package/src/browser/mcp/tools/getCurrentFilePath.ts +49 -0
- package/src/browser/mcp/tools/getDiagnosticsByPath.ts +123 -0
- package/src/browser/mcp/tools/getFileTextByPath.ts +97 -0
- package/src/browser/mcp/tools/getOpenEditorFileDiagnostics.ts +121 -0
- package/src/browser/mcp/tools/getOpenEditorFileText.ts +50 -0
- package/src/browser/mcp/tools/getSelectedText.ts +57 -0
- package/src/browser/preferences/schema.ts +0 -4
- package/src/browser/types.ts +39 -0
- package/src/common/index.ts +9 -0
- package/src/common/mcp-server-manager.ts +45 -0
- package/src/common/tool-invocation-registry.ts +124 -0
- package/src/common/types.ts +18 -0
- package/src/node/anthropic/anthropic-language-model.ts +96 -0
- package/src/node/index.ts +24 -0
- package/src/node/mcp/sumi-mcp-server.ts +161 -0
- package/src/node/mcp-server-manager-impl.ts +130 -0
- package/src/node/mcp-server.ts +118 -0
- package/src/node/openai/openai-language-model.ts +152 -0
- package/lib/browser/contrib/intelligent-completions/source/typing.source.d.ts +0 -9
- package/lib/browser/contrib/intelligent-completions/source/typing.source.d.ts.map +0 -1
- package/lib/browser/contrib/intelligent-completions/source/typing.source.js +0 -38
- package/lib/browser/contrib/intelligent-completions/source/typing.source.js.map +0 -1
- package/src/browser/contrib/intelligent-completions/source/typing.source.ts +0 -36
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ToolInvocationRegistryImpl = exports.ToolProvider = exports.ToolInvocationRegistry = exports.ToolRequest = exports.ToolParameterSchema = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const di_1 = require("@opensumi/di");
|
|
6
|
+
const zod_1 = require("zod");
|
|
7
|
+
exports.ToolParameterSchema = zod_1.z.object({
|
|
8
|
+
type: zod_1.z.enum(['string', 'number', 'boolean', 'object', 'array']),
|
|
9
|
+
description: zod_1.z.string().optional(),
|
|
10
|
+
enum: zod_1.z.array(zod_1.z.any()).optional(),
|
|
11
|
+
items: zod_1.z.lazy(() => exports.ToolParameterSchema).optional(),
|
|
12
|
+
properties: zod_1.z.record(zod_1.z.lazy(() => exports.ToolParameterSchema)).optional(),
|
|
13
|
+
required: zod_1.z.array(zod_1.z.string()).optional(),
|
|
14
|
+
});
|
|
15
|
+
var ToolRequest;
|
|
16
|
+
(function (ToolRequest) {
|
|
17
|
+
function isToolParameter(obj) {
|
|
18
|
+
return exports.ToolParameterSchema.safeParse(obj).success;
|
|
19
|
+
}
|
|
20
|
+
ToolRequest.isToolParameter = isToolParameter;
|
|
21
|
+
})(ToolRequest || (exports.ToolRequest = ToolRequest = {}));
|
|
22
|
+
exports.ToolInvocationRegistry = Symbol('ToolInvocationRegistry');
|
|
23
|
+
exports.ToolProvider = Symbol('ToolProvider');
|
|
24
|
+
let ToolInvocationRegistryImpl = class ToolInvocationRegistryImpl {
|
|
25
|
+
constructor() {
|
|
26
|
+
this.tools = new Map();
|
|
27
|
+
}
|
|
28
|
+
unregisterAllTools(providerName) {
|
|
29
|
+
const toolsToRemove = [];
|
|
30
|
+
for (const [id, tool] of this.tools.entries()) {
|
|
31
|
+
if (tool.providerName === providerName) {
|
|
32
|
+
toolsToRemove.push(id);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
toolsToRemove.forEach(id => this.tools.delete(id));
|
|
36
|
+
}
|
|
37
|
+
getAllFunctions() {
|
|
38
|
+
return Array.from(this.tools.values());
|
|
39
|
+
}
|
|
40
|
+
registerTool(tool) {
|
|
41
|
+
if (this.tools.has(tool.id)) {
|
|
42
|
+
console.warn(`Function with id ${tool.id} is already registered.`);
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
this.tools.set(tool.id, tool);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
getFunction(toolId) {
|
|
49
|
+
return this.tools.get(toolId);
|
|
50
|
+
}
|
|
51
|
+
getFunctions(...toolIds) {
|
|
52
|
+
const tools = toolIds.map(toolId => {
|
|
53
|
+
const tool = this.tools.get(toolId);
|
|
54
|
+
if (tool) {
|
|
55
|
+
return tool;
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
throw new Error(`Function with id ${toolId} does not exist.`);
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
return tools;
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
exports.ToolInvocationRegistryImpl = ToolInvocationRegistryImpl;
|
|
65
|
+
exports.ToolInvocationRegistryImpl = ToolInvocationRegistryImpl = tslib_1.__decorate([
|
|
66
|
+
(0, di_1.Injectable)()
|
|
67
|
+
], ToolInvocationRegistryImpl);
|
|
68
|
+
//# sourceMappingURL=tool-invocation-registry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tool-invocation-registry.js","sourceRoot":"","sources":["../../src/common/tool-invocation-registry.ts"],"names":[],"mappings":"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"}
|
package/lib/common/types.d.ts
CHANGED
|
@@ -17,4 +17,18 @@ export interface INearestCodeBlock {
|
|
|
17
17
|
offset: number;
|
|
18
18
|
type?: NearestCodeBlockType;
|
|
19
19
|
}
|
|
20
|
+
export interface IMCPServerProxyService {
|
|
21
|
+
$callMCPTool(name: string, args: any): Promise<{
|
|
22
|
+
content: {
|
|
23
|
+
type: string;
|
|
24
|
+
text: string;
|
|
25
|
+
}[];
|
|
26
|
+
isError?: boolean;
|
|
27
|
+
}>;
|
|
28
|
+
$getMCPTools(): Promise<{
|
|
29
|
+
name: string;
|
|
30
|
+
description: string;
|
|
31
|
+
inputSchema: any;
|
|
32
|
+
}[]>;
|
|
33
|
+
}
|
|
20
34
|
//# sourceMappingURL=types.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/common/types.ts"],"names":[],"mappings":"AAAA,oBAAY,oBAAoB;IAC9B,KAAK,UAAU;IACf,IAAI,SAAS;CACd;AAED,MAAM,WAAW,iBAAiB;IAChC,KAAK,EAAE;QACL,KAAK,EAAE;YACL,IAAI,EAAE,MAAM,CAAC;YACb,SAAS,EAAE,MAAM,CAAC;SACnB,CAAC;QACF,GAAG,EAAE;YACH,IAAI,EAAE,MAAM,CAAC;YACb,SAAS,EAAE,MAAM,CAAC;SACnB,CAAC;KACH,CAAC;IACF,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,oBAAoB,CAAC;CAC7B"}
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/common/types.ts"],"names":[],"mappings":"AAAA,oBAAY,oBAAoB;IAC9B,KAAK,UAAU;IACf,IAAI,SAAS;CACd;AAED,MAAM,WAAW,iBAAiB;IAChC,KAAK,EAAE;QACL,KAAK,EAAE;YACL,IAAI,EAAE,MAAM,CAAC;YACb,SAAS,EAAE,MAAM,CAAC;SACnB,CAAC;QACF,GAAG,EAAE;YACH,IAAI,EAAE,MAAM,CAAC;YACb,SAAS,EAAE,MAAM,CAAC;SACnB,CAAC;KACH,CAAC;IACF,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,oBAAoB,CAAC;CAC7B;AAGD,MAAM,WAAW,sBAAsB;IACrC,YAAY,CACV,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,GAAG,GACR,OAAO,CAAC;QACT,OAAO,EAAE;YAAE,IAAI,EAAE,MAAM,CAAC;YAAC,IAAI,EAAE,MAAM,CAAA;SAAE,EAAE,CAAC;QAC1C,OAAO,CAAC,EAAE,OAAO,CAAC;KACnB,CAAC,CAAC;IACH,YAAY,IAAI,OAAO,CACrB;QACE,IAAI,EAAE,MAAM,CAAC;QACb,WAAW,EAAE,MAAM,CAAC;QACpB,WAAW,EAAE,GAAG,CAAC;KAClB,EAAE,CACJ,CAAC;CACH"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { AnthropicProvider } from '@ai-sdk/anthropic';
|
|
2
|
+
import { ChatReadableStream } from '@opensumi/ide-core-node';
|
|
3
|
+
import { CancellationToken } from '@opensumi/ide-utils';
|
|
4
|
+
import { ToolRequest } from '../../common/tool-invocation-registry';
|
|
5
|
+
export declare const AnthropicModelIdentifier: unique symbol;
|
|
6
|
+
export declare class AnthropicModel {
|
|
7
|
+
private readonly toolInvocationRegistry;
|
|
8
|
+
protected initializeAnthropicProvider(): AnthropicProvider;
|
|
9
|
+
request(request: string, chatReadableStream: ChatReadableStream, cancellationToken?: CancellationToken): Promise<any>;
|
|
10
|
+
private convertToolRequestToAITool;
|
|
11
|
+
protected handleStreamingRequest(anthropic: AnthropicProvider, request: string, tools: ToolRequest[], chatReadableStream: ChatReadableStream, cancellationToken?: CancellationToken): Promise<any>;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=anthropic-language-model.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"anthropic-language-model.d.ts","sourceRoot":"","sources":["../../../src/node/anthropic/anthropic-language-model.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAmB,MAAM,mBAAmB,CAAC;AAIvE,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAExD,OAAO,EAAsD,WAAW,EAAE,MAAM,uCAAuC,CAAC;AAGxH,eAAO,MAAM,wBAAwB,eAAqC,CAAC;AAI3E,qBACa,cAAc;IAEzB,OAAO,CAAC,QAAQ,CAAC,sBAAsB,CAA6B;IAEpE,SAAS,CAAC,2BAA2B;IAU/B,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,iBAAiB,CAAC,EAAE,iBAAiB,GAAG,OAAO,CAAC,GAAG,CAAC;IAM3H,OAAO,CAAC,0BAA0B;cASlB,sBAAsB,CACpC,SAAS,EAAE,iBAAiB,EAC5B,OAAO,EAAE,MAAM,EACf,KAAK,EAAE,WAAW,EAAE,EACpB,kBAAkB,EAAE,kBAAkB,EACtC,iBAAiB,CAAC,EAAE,iBAAiB,GACpC,OAAO,CAAC,GAAG,CAAC;CA6ChB"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AnthropicModel = exports.AnthropicModelIdentifier = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const anthropic_1 = require("@ai-sdk/anthropic");
|
|
6
|
+
const ai_1 = require("ai");
|
|
7
|
+
const di_1 = require("@opensumi/di");
|
|
8
|
+
const tool_invocation_registry_1 = require("../../common/tool-invocation-registry");
|
|
9
|
+
exports.AnthropicModelIdentifier = Symbol('AnthropicModelIdentifier');
|
|
10
|
+
const apiKey = '';
|
|
11
|
+
let AnthropicModel = class AnthropicModel {
|
|
12
|
+
initializeAnthropicProvider() {
|
|
13
|
+
if (!apiKey) {
|
|
14
|
+
throw new Error('Please provide ANTHROPIC_API_KEY in preferences or via environment variable');
|
|
15
|
+
}
|
|
16
|
+
const anthropic = (0, anthropic_1.createAnthropic)({ apiKey });
|
|
17
|
+
return anthropic;
|
|
18
|
+
}
|
|
19
|
+
async request(request, chatReadableStream, cancellationToken) {
|
|
20
|
+
const anthropic = this.initializeAnthropicProvider();
|
|
21
|
+
const allFunctions = this.toolInvocationRegistry.getAllFunctions();
|
|
22
|
+
return this.handleStreamingRequest(anthropic, request, allFunctions, chatReadableStream, cancellationToken);
|
|
23
|
+
}
|
|
24
|
+
convertToolRequestToAITool(toolRequest) {
|
|
25
|
+
return (0, ai_1.tool)({
|
|
26
|
+
description: toolRequest.description || '',
|
|
27
|
+
// TODO 这里应该是 z.object 而不是 JSON Schema
|
|
28
|
+
parameters: (0, ai_1.jsonSchema)(toolRequest.parameters),
|
|
29
|
+
execute: async (args) => await toolRequest.handler(JSON.stringify(args)),
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
async handleStreamingRequest(anthropic, request, tools, chatReadableStream, cancellationToken) {
|
|
33
|
+
try {
|
|
34
|
+
const aiTools = Object.fromEntries(tools.map((tool) => [tool.name, this.convertToolRequestToAITool(tool)]));
|
|
35
|
+
const abortController = new AbortController();
|
|
36
|
+
if (cancellationToken) {
|
|
37
|
+
cancellationToken.onCancellationRequested(() => {
|
|
38
|
+
abortController.abort();
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
const stream = await (0, ai_1.streamText)({
|
|
42
|
+
model: anthropic('claude-3-5-sonnet-20241022'),
|
|
43
|
+
maxTokens: 4096,
|
|
44
|
+
tools: aiTools,
|
|
45
|
+
messages: [{ role: 'user', content: request }],
|
|
46
|
+
abortSignal: abortController.signal,
|
|
47
|
+
maxSteps: 5,
|
|
48
|
+
});
|
|
49
|
+
for await (const chunk of stream.fullStream) {
|
|
50
|
+
console.log(chunk);
|
|
51
|
+
if (chunk.type === 'text-delta') {
|
|
52
|
+
chatReadableStream.emitData({ kind: 'content', content: chunk.textDelta });
|
|
53
|
+
}
|
|
54
|
+
else if (chunk.type === 'tool-call') {
|
|
55
|
+
chatReadableStream.emitData({ kind: 'toolCall', content: {
|
|
56
|
+
id: chunk.toolCallId || Date.now().toString(),
|
|
57
|
+
type: 'function',
|
|
58
|
+
function: { name: chunk.toolName, arguments: JSON.stringify(chunk.args) },
|
|
59
|
+
} });
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
chatReadableStream.end();
|
|
63
|
+
}
|
|
64
|
+
catch (error) {
|
|
65
|
+
console.error('Error during streaming:', error);
|
|
66
|
+
chatReadableStream.emitError(error);
|
|
67
|
+
}
|
|
68
|
+
return chatReadableStream;
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
exports.AnthropicModel = AnthropicModel;
|
|
72
|
+
tslib_1.__decorate([
|
|
73
|
+
(0, di_1.Autowired)(tool_invocation_registry_1.ToolInvocationRegistry),
|
|
74
|
+
tslib_1.__metadata("design:type", tool_invocation_registry_1.ToolInvocationRegistryImpl)
|
|
75
|
+
], AnthropicModel.prototype, "toolInvocationRegistry", void 0);
|
|
76
|
+
exports.AnthropicModel = AnthropicModel = tslib_1.__decorate([
|
|
77
|
+
(0, di_1.Injectable)()
|
|
78
|
+
], AnthropicModel);
|
|
79
|
+
//# sourceMappingURL=anthropic-language-model.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"anthropic-language-model.js","sourceRoot":"","sources":["../../../src/node/anthropic/anthropic-language-model.ts"],"names":[],"mappings":";;;;AAAA,iDAAuE;AACvE,2BAAkD;AAElD,qCAAqD;AAIrD,oFAAwH;AAG3G,QAAA,wBAAwB,GAAG,MAAM,CAAC,0BAA0B,CAAC,CAAC;AAE3E,MAAM,MAAM,GAAG,EAAE,CAAC;AAGX,IAAM,cAAc,GAApB,MAAM,cAAc;IAIf,2BAA2B;QACnC,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,IAAI,KAAK,CAAC,6EAA6E,CAAC,CAAC;QACjG,CAAC;QAED,MAAM,SAAS,GAAG,IAAA,2BAAe,EAAC,EAAE,MAAM,EAAE,CAAC,CAAC;QAE9C,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,OAAe,EAAE,kBAAsC,EAAE,iBAAqC;QAC1G,MAAM,SAAS,GAAG,IAAI,CAAC,2BAA2B,EAAE,CAAC;QACrD,MAAM,YAAY,GAAG,IAAI,CAAC,sBAAsB,CAAC,eAAe,EAAE,CAAC;QACnE,OAAO,IAAI,CAAC,sBAAsB,CAAC,SAAS,EAAE,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,iBAAiB,CAAC,CAAC;IAC9G,CAAC;IAEO,0BAA0B,CAAC,WAAwB;QACzD,OAAO,IAAA,SAAI,EAAC;YACV,WAAW,EAAE,WAAW,CAAC,WAAW,IAAI,EAAE;YAC1C,sCAAsC;YACtC,UAAU,EAAE,IAAA,eAAU,EAAC,WAAW,CAAC,UAAU,CAAC;YAC9C,OAAO,EAAE,KAAK,EAAE,IAAS,EAAE,EAAE,CAAC,MAAM,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;SAC9E,CAAC,CAAC;IACL,CAAC;IAES,KAAK,CAAC,sBAAsB,CACpC,SAA4B,EAC5B,OAAe,EACf,KAAoB,EACpB,kBAAsC,EACtC,iBAAqC;QAGrC,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,MAAM,CAAC,WAAW,CAChC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,CAAC,CAAC,CACxE,CAAC;YAEF,MAAM,eAAe,GAAG,IAAI,eAAe,EAAE,CAAC;YAC9C,IAAI,iBAAiB,EAAE,CAAC;gBACtB,iBAAiB,CAAC,uBAAuB,CAAC,GAAG,EAAE;oBAC7C,eAAe,CAAC,KAAK,EAAE,CAAC;gBAC1B,CAAC,CAAC,CAAC;YACL,CAAC;YAED,MAAM,MAAM,GAAG,MAAM,IAAA,eAAU,EAAC;gBAC9B,KAAK,EAAE,SAAS,CAAC,4BAA4B,CAAC;gBAC9C,SAAS,EAAE,IAAI;gBACf,KAAK,EAAE,OAAO;gBACd,QAAQ,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC;gBAC9C,WAAW,EAAE,eAAe,CAAC,MAAM;gBACnC,QAAQ,EAAE,CAAC;aACZ,CAAC,CAAC;YAEH,IAAI,KAAK,EAAE,MAAM,KAAK,IAAI,MAAM,CAAC,UAAU,EAAE,CAAC;gBAC5C,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;gBACnB,IAAI,KAAK,CAAC,IAAI,KAAK,YAAY,EAAE,CAAC;oBAChC,kBAAkB,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,KAAK,CAAC,SAAS,EAAE,CAAC,CAAC;gBAC7E,CAAC;qBAAM,IAAI,KAAK,CAAC,IAAI,KAAK,WAAW,EAAE,CAAC;oBACtC,kBAAkB,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,OAAO,EAAE;4BACvD,EAAE,EAAE,KAAK,CAAC,UAAU,IAAI,IAAI,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE;4BAC7C,IAAI,EAAE,UAAU;4BAChB,QAAQ,EAAE,EAAE,IAAI,EAAE,KAAK,CAAC,QAAQ,EAAE,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE;yBAC1E,EAAC,CAAC,CAAC;gBACN,CAAC;YACH,CAAC;YAED,kBAAkB,CAAC,GAAG,EAAE,CAAC;QAC3B,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,yBAAyB,EAAE,KAAK,CAAC,CAAC;YAChD,kBAAkB,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACtC,CAAC;QAED,OAAO,kBAAkB,CAAC;IAC5B,CAAC;CAEF,CAAA;AAhFY,wCAAc;AAER;IADhB,IAAA,cAAS,EAAC,iDAAsB,CAAC;sCACO,qDAA0B;8DAAC;yBAFzD,cAAc;IAD1B,IAAA,eAAU,GAAE;GACA,cAAc,CAgF1B"}
|
package/lib/node/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/node/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,QAAQ,EAAE,MAAM,cAAc,CAAC;AAEpD,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/node/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,QAAQ,EAAE,MAAM,cAAc,CAAC;AAEpD,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AAWrD,qBACa,cAAe,SAAQ,UAAU;IAC5C,SAAS,EAAE,QAAQ,EAAE,CAiBnB;IAEF,YAAY;;;QASV;CACH"}
|
package/lib/node/index.js
CHANGED
|
@@ -6,6 +6,11 @@ const di_1 = require("@opensumi/di");
|
|
|
6
6
|
const ide_core_common_1 = require("@opensumi/ide-core-common");
|
|
7
7
|
const ide_core_node_1 = require("@opensumi/ide-core-node");
|
|
8
8
|
const base_back_service_1 = require("@opensumi/ide-core-node/lib/ai-native/base-back.service");
|
|
9
|
+
const common_1 = require("../common");
|
|
10
|
+
const mcp_server_manager_1 = require("../common/mcp-server-manager");
|
|
11
|
+
const tool_invocation_registry_1 = require("../common/tool-invocation-registry");
|
|
12
|
+
const sumi_mcp_server_1 = require("./mcp/sumi-mcp-server");
|
|
13
|
+
const mcp_server_manager_impl_1 = require("./mcp-server-manager-impl");
|
|
9
14
|
let AINativeModule = class AINativeModule extends ide_core_node_1.NodeModule {
|
|
10
15
|
constructor() {
|
|
11
16
|
super(...arguments);
|
|
@@ -14,12 +19,28 @@ let AINativeModule = class AINativeModule extends ide_core_node_1.NodeModule {
|
|
|
14
19
|
token: ide_core_common_1.AIBackSerivceToken,
|
|
15
20
|
useClass: base_back_service_1.BaseAIBackService,
|
|
16
21
|
},
|
|
22
|
+
{
|
|
23
|
+
token: mcp_server_manager_1.MCPServerManager,
|
|
24
|
+
useClass: mcp_server_manager_impl_1.MCPServerManagerImpl,
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
token: tool_invocation_registry_1.ToolInvocationRegistry,
|
|
28
|
+
useClass: tool_invocation_registry_1.ToolInvocationRegistryImpl,
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
token: common_1.TokenMCPServerProxyService,
|
|
32
|
+
useClass: sumi_mcp_server_1.SumiMCPServerBackend,
|
|
33
|
+
},
|
|
17
34
|
];
|
|
18
35
|
this.backServices = [
|
|
19
36
|
{
|
|
20
37
|
servicePath: ide_core_common_1.AIBackSerivcePath,
|
|
21
38
|
token: ide_core_common_1.AIBackSerivceToken,
|
|
22
39
|
},
|
|
40
|
+
{
|
|
41
|
+
servicePath: common_1.SumiMCPServerProxyServicePath,
|
|
42
|
+
token: common_1.TokenMCPServerProxyService,
|
|
43
|
+
},
|
|
23
44
|
];
|
|
24
45
|
}
|
|
25
46
|
};
|
package/lib/node/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/node/index.ts"],"names":[],"mappings":";;;;AAAA,qCAAoD;AACpD,+DAAkF;AAClF,2DAAqD;AACrD,+FAA4F;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/node/index.ts"],"names":[],"mappings":";;;;AAAA,qCAAoD;AACpD,+DAAkF;AAClF,2DAAqD;AACrD,+FAA4F;AAE5F,sCAAuF;AACvF,qEAAgE;AAChE,iFAAwG;AAExG,2DAA6D;AAC7D,uEAAiE;AAI1D,IAAM,cAAc,GAApB,MAAM,cAAe,SAAQ,0BAAU;IAAvC;;QACL,cAAS,GAAe;YACtB;gBACE,KAAK,EAAE,oCAAkB;gBACzB,QAAQ,EAAE,qCAAiB;aAC5B;YACD;gBACE,KAAK,EAAE,qCAAgB;gBACvB,QAAQ,EAAE,8CAAoB;aAC/B;YACD;gBACE,KAAK,EAAE,iDAAsB;gBAC7B,QAAQ,EAAE,qDAA0B;aACrC;YACD;gBACE,KAAK,EAAE,mCAA0B;gBACjC,QAAQ,EAAE,sCAAoB;aAC/B;SACF,CAAC;QAEF,iBAAY,GAAG;YACb;gBACE,WAAW,EAAE,mCAAiB;gBAC9B,KAAK,EAAE,oCAAkB;aAC1B;YACD;gBACE,WAAW,EAAE,sCAA6B;gBAC1C,KAAK,EAAE,mCAA0B;aAClC;SACF,CAAC;IACJ,CAAC;CAAA,CAAA;AA9BY,wCAAc;yBAAd,cAAc;IAD1B,IAAA,eAAU,GAAE;GACA,cAAc,CA8B1B"}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { Client } from '@modelcontextprotocol/sdk/client/index.js';
|
|
2
|
+
import { Server } from '@modelcontextprotocol/sdk/server/index.js';
|
|
3
|
+
import { RPCService } from '@opensumi/ide-connection';
|
|
4
|
+
import { IMCPServerProxyService } from '../../common/types';
|
|
5
|
+
import { IMCPServer } from '../mcp-server';
|
|
6
|
+
export declare class SumiMCPServerBackend extends RPCService<IMCPServerProxyService> {
|
|
7
|
+
private readonly mcpServerManager;
|
|
8
|
+
private server;
|
|
9
|
+
getMCPTools(): Promise<{
|
|
10
|
+
name: string;
|
|
11
|
+
description: string;
|
|
12
|
+
inputSchema: any;
|
|
13
|
+
}[]>;
|
|
14
|
+
callMCPTool(name: string, args: any): Promise<{
|
|
15
|
+
content: {
|
|
16
|
+
type: string;
|
|
17
|
+
text: string;
|
|
18
|
+
}[];
|
|
19
|
+
isError?: boolean;
|
|
20
|
+
}>;
|
|
21
|
+
getServer(): Server<{
|
|
22
|
+
method: string;
|
|
23
|
+
params?: {
|
|
24
|
+
[x: string]: unknown;
|
|
25
|
+
_meta?: {
|
|
26
|
+
[x: string]: unknown;
|
|
27
|
+
progressToken?: string | number | undefined;
|
|
28
|
+
} | undefined;
|
|
29
|
+
} | undefined;
|
|
30
|
+
}, {
|
|
31
|
+
method: string;
|
|
32
|
+
params?: {
|
|
33
|
+
[x: string]: unknown;
|
|
34
|
+
_meta?: {
|
|
35
|
+
[x: string]: unknown;
|
|
36
|
+
} | undefined;
|
|
37
|
+
} | undefined;
|
|
38
|
+
}, {
|
|
39
|
+
[x: string]: unknown;
|
|
40
|
+
_meta?: {
|
|
41
|
+
[x: string]: unknown;
|
|
42
|
+
} | undefined;
|
|
43
|
+
}> | undefined;
|
|
44
|
+
initBuiltinMCPServer(): void;
|
|
45
|
+
initExposedMCPServer(): Promise<Server<{
|
|
46
|
+
method: string;
|
|
47
|
+
params?: {
|
|
48
|
+
[x: string]: unknown;
|
|
49
|
+
_meta?: {
|
|
50
|
+
[x: string]: unknown;
|
|
51
|
+
progressToken?: string | number | undefined;
|
|
52
|
+
} | undefined;
|
|
53
|
+
} | undefined;
|
|
54
|
+
}, {
|
|
55
|
+
method: string;
|
|
56
|
+
params?: {
|
|
57
|
+
[x: string]: unknown;
|
|
58
|
+
_meta?: {
|
|
59
|
+
[x: string]: unknown;
|
|
60
|
+
} | undefined;
|
|
61
|
+
} | undefined;
|
|
62
|
+
}, {
|
|
63
|
+
[x: string]: unknown;
|
|
64
|
+
_meta?: {
|
|
65
|
+
[x: string]: unknown;
|
|
66
|
+
} | undefined;
|
|
67
|
+
}>>;
|
|
68
|
+
}
|
|
69
|
+
export declare const TokenBuiltinMCPServer: unique symbol;
|
|
70
|
+
export declare class BuiltinMCPServer implements IMCPServer {
|
|
71
|
+
private readonly sumiMCPServer;
|
|
72
|
+
constructor(sumiMCPServer: SumiMCPServerBackend);
|
|
73
|
+
private started;
|
|
74
|
+
isStarted(): boolean;
|
|
75
|
+
getServerName(): string;
|
|
76
|
+
start(): Promise<void>;
|
|
77
|
+
callTool(toolName: string, arg_string: string): Promise<any>;
|
|
78
|
+
getTools(): ReturnType<Client['listTools']>;
|
|
79
|
+
update(_command: string, _args?: string[], _env?: {
|
|
80
|
+
[key: string]: string;
|
|
81
|
+
}): void;
|
|
82
|
+
stop(): void;
|
|
83
|
+
}
|
|
84
|
+
//# sourceMappingURL=sumi-mcp-server.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sumi-mcp-server.d.ts","sourceRoot":"","sources":["../../../src/node/mcp/sumi-mcp-server.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,MAAM,EAAE,MAAM,2CAA2C,CAAC;AACnE,OAAO,EAAE,MAAM,EAAE,MAAM,2CAA2C,CAAC;AAInE,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AAGtD,OAAO,EAAE,sBAAsB,EAAE,MAAM,oBAAoB,CAAC;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAQ3C,qBACa,oBAAqB,SAAQ,UAAU,CAAC,sBAAsB,CAAC;IAK1E,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAuB;IAExD,OAAO,CAAC,MAAM,CAAqB;IAE7B,WAAW;;;;;IAUX,WAAW,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG;;;;;;;IAOzC,SAAS;;;;;;;;;;;;;;;;;;;;;;;IAIT,oBAAoB;IAKd,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;CAoC3B;AAGD,eAAO,MAAM,qBAAqB,eAAkC,CAAC;AAErE,qBAAa,gBAAiB,YAAW,UAAU;IAG/C,OAAO,CAAC,QAAQ,CAAC,aAAa;gBAAb,aAAa,EAAE,oBAAoB;IAGtD,OAAO,CAAC,OAAO,CAAiB;IAEhC,SAAS,IAAI,OAAO;IAIpB,aAAa,IAAI,MAAM;IAIjB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAStB,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC;IAkB5D,QAAQ,IAAI,UAAU,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;IAQjD,MAAM,CAAC,QAAQ,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,EAAE,IAAI,CAAC,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAA;KAAE,GAAG,IAAI;IAIlF,IAAI,IAAI,IAAI;CAOb"}
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// 想要通过 MCP 的方式暴露 Opensumi 的 IDE 能力,就需要 Node.js 层打通 MCP 的通信
|
|
3
|
+
// 因为大部分 MCP 功能的实现在前端,因此需要再这里做前后端通信
|
|
4
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
5
|
+
exports.BuiltinMCPServer = exports.TokenBuiltinMCPServer = exports.SumiMCPServerBackend = void 0;
|
|
6
|
+
const tslib_1 = require("tslib");
|
|
7
|
+
const index_js_1 = require("@modelcontextprotocol/sdk/server/index.js");
|
|
8
|
+
const types_js_1 = require("@modelcontextprotocol/sdk/types.js");
|
|
9
|
+
const di_1 = require("@opensumi/di");
|
|
10
|
+
const ide_connection_1 = require("@opensumi/ide-connection");
|
|
11
|
+
const mcp_server_manager_1 = require("../../common/mcp-server-manager");
|
|
12
|
+
const mcp_server_manager_impl_1 = require("../mcp-server-manager-impl");
|
|
13
|
+
// 每个 BrowserTab 都对应了一个 SumiMCPServerBackend 实例
|
|
14
|
+
// SumiMCPServerBackend 需要做的事情:
|
|
15
|
+
// 维护 Browser 端工具的注册和调用
|
|
16
|
+
// 处理第三方 MCP Server 的注册和调用
|
|
17
|
+
let SumiMCPServerBackend = class SumiMCPServerBackend extends ide_connection_1.RPCService {
|
|
18
|
+
async getMCPTools() {
|
|
19
|
+
if (!this.client) {
|
|
20
|
+
throw new Error('SUMI MCP RPC Client not initialized');
|
|
21
|
+
}
|
|
22
|
+
// 获取 MCP 工具
|
|
23
|
+
const tools = await this.client.$getMCPTools();
|
|
24
|
+
console.log('[Node backend] SUMI MCP tools', tools);
|
|
25
|
+
return tools;
|
|
26
|
+
}
|
|
27
|
+
async callMCPTool(name, args) {
|
|
28
|
+
if (!this.client) {
|
|
29
|
+
throw new Error('SUMI MCP RPC Client not initialized');
|
|
30
|
+
}
|
|
31
|
+
return await this.client.$callMCPTool(name, args);
|
|
32
|
+
}
|
|
33
|
+
getServer() {
|
|
34
|
+
return this.server;
|
|
35
|
+
}
|
|
36
|
+
initBuiltinMCPServer() {
|
|
37
|
+
const builtinMCPServer = new BuiltinMCPServer(this);
|
|
38
|
+
this.mcpServerManager.initBuiltinServer(builtinMCPServer);
|
|
39
|
+
}
|
|
40
|
+
async initExposedMCPServer() {
|
|
41
|
+
// 初始化 MCP Server
|
|
42
|
+
this.server = new index_js_1.Server({
|
|
43
|
+
name: 'sumi-ide-mcp-server',
|
|
44
|
+
version: '0.2.0',
|
|
45
|
+
}, {
|
|
46
|
+
capabilities: {
|
|
47
|
+
tools: {},
|
|
48
|
+
},
|
|
49
|
+
});
|
|
50
|
+
// 设置工具列表请求处理器
|
|
51
|
+
this.server.setRequestHandler(types_js_1.ListToolsRequestSchema, async () => {
|
|
52
|
+
const tools = await this.getMCPTools();
|
|
53
|
+
return { tools };
|
|
54
|
+
});
|
|
55
|
+
// 设置工具调用请求处理器
|
|
56
|
+
this.server.setRequestHandler(types_js_1.CallToolRequestSchema, async (request) => {
|
|
57
|
+
try {
|
|
58
|
+
const { name, arguments: args } = request.params;
|
|
59
|
+
return await this.callMCPTool(name, args);
|
|
60
|
+
}
|
|
61
|
+
catch (error) {
|
|
62
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
63
|
+
return {
|
|
64
|
+
content: [{ type: 'text', text: `Error: ${errorMessage}` }],
|
|
65
|
+
isError: true,
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
return this.server;
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
exports.SumiMCPServerBackend = SumiMCPServerBackend;
|
|
73
|
+
tslib_1.__decorate([
|
|
74
|
+
(0, di_1.Autowired)(mcp_server_manager_1.MCPServerManager),
|
|
75
|
+
tslib_1.__metadata("design:type", mcp_server_manager_impl_1.MCPServerManagerImpl)
|
|
76
|
+
], SumiMCPServerBackend.prototype, "mcpServerManager", void 0);
|
|
77
|
+
exports.SumiMCPServerBackend = SumiMCPServerBackend = tslib_1.__decorate([
|
|
78
|
+
(0, di_1.Injectable)({ multiple: true })
|
|
79
|
+
], SumiMCPServerBackend);
|
|
80
|
+
exports.TokenBuiltinMCPServer = Symbol('TokenBuiltinMCPServer');
|
|
81
|
+
class BuiltinMCPServer {
|
|
82
|
+
constructor(sumiMCPServer) {
|
|
83
|
+
this.sumiMCPServer = sumiMCPServer;
|
|
84
|
+
this.started = true;
|
|
85
|
+
}
|
|
86
|
+
isStarted() {
|
|
87
|
+
return this.started;
|
|
88
|
+
}
|
|
89
|
+
getServerName() {
|
|
90
|
+
return 'sumi-builtin';
|
|
91
|
+
}
|
|
92
|
+
async start() {
|
|
93
|
+
if (this.started) {
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
// TODO 考虑 MCP Server 的对外暴露
|
|
97
|
+
// await this.sumiMCPServer.initMCPServer();
|
|
98
|
+
this.started = true;
|
|
99
|
+
}
|
|
100
|
+
async callTool(toolName, arg_string) {
|
|
101
|
+
if (!this.started) {
|
|
102
|
+
throw new Error('MCP Server not started');
|
|
103
|
+
}
|
|
104
|
+
let args;
|
|
105
|
+
try {
|
|
106
|
+
args = JSON.parse(arg_string);
|
|
107
|
+
}
|
|
108
|
+
catch (error) {
|
|
109
|
+
console.error(`Failed to parse arguments for calling tool "${toolName}" in Builtin MCP server.
|
|
110
|
+
Invalid JSON: ${arg_string}`, error);
|
|
111
|
+
throw error;
|
|
112
|
+
}
|
|
113
|
+
return this.sumiMCPServer.callMCPTool(toolName, args);
|
|
114
|
+
}
|
|
115
|
+
async getTools() {
|
|
116
|
+
if (!this.started) {
|
|
117
|
+
throw new Error('MCP Server not started');
|
|
118
|
+
}
|
|
119
|
+
const tools = await this.sumiMCPServer.getMCPTools();
|
|
120
|
+
return { tools };
|
|
121
|
+
}
|
|
122
|
+
update(_command, _args, _env) {
|
|
123
|
+
// No-op for builtin server as it doesn't need command/args/env updates
|
|
124
|
+
}
|
|
125
|
+
stop() {
|
|
126
|
+
if (!this.started) {
|
|
127
|
+
return;
|
|
128
|
+
}
|
|
129
|
+
// No explicit cleanup needed for in-memory server
|
|
130
|
+
this.started = false;
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
exports.BuiltinMCPServer = BuiltinMCPServer;
|
|
134
|
+
//# sourceMappingURL=sumi-mcp-server.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sumi-mcp-server.js","sourceRoot":"","sources":["../../../src/node/mcp/sumi-mcp-server.ts"],"names":[],"mappings":";AAAA,2DAA2D;AAC3D,mCAAmC;;;;AAGnC,wEAAmE;AACnE,iEAAmG;AAEnG,qCAAqD;AACrD,6DAAsD;AAEtD,wEAAmE;AAGnE,wEAAkE;AAElE,+CAA+C;AAC/C,+BAA+B;AAC/B,uBAAuB;AACvB,0BAA0B;AAGnB,IAAM,oBAAoB,GAA1B,MAAM,oBAAqB,SAAQ,2BAAkC;IAS1E,KAAK,CAAC,WAAW;QACf,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAC;QACzD,CAAC;QACD,YAAY;QACZ,MAAM,KAAK,GAAI,MAAM,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;QAChD,OAAO,CAAC,GAAG,CAAC,+BAA+B,EAAE,KAAK,CAAC,CAAC;QACpD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,IAAY,EAAE,IAAS;QACvC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAC;QACzD,CAAC;QACD,OAAO,MAAM,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IACpD,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,oBAAoB;QAClB,MAAM,gBAAgB,GAAG,IAAI,gBAAgB,CAAC,IAAI,CAAC,CAAC;QACpD,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,CAAC;IAC5D,CAAC;IAED,KAAK,CAAC,oBAAoB;QACxB,iBAAiB;QACjB,IAAI,CAAC,MAAM,GAAG,IAAI,iBAAM,CACtB;YACE,IAAI,EAAE,qBAAqB;YAC3B,OAAO,EAAE,OAAO;SACjB,EACD;YACE,YAAY,EAAE;gBACZ,KAAK,EAAE,EAAE;aACV;SACF,CACF,CAAC;QAEF,cAAc;QACd,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,iCAAsB,EAAE,KAAK,IAAI,EAAE;YAC/D,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,WAAW,EAAE,CAAC;YACvC,OAAO,EAAE,KAAK,EAAE,CAAC;QACnB,CAAC,CAAC,CAAC;QAEH,cAAc;QACd,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,gCAAqB,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE;YACrE,IAAI,CAAC;gBACH,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC;gBACjD,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YAC5C,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,MAAM,YAAY,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;gBAC5E,OAAO;oBACL,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,YAAY,EAAE,EAAE,CAAC;oBAC3D,OAAO,EAAE,IAAI;iBACd,CAAC;YACJ,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;CACF,CAAA;AAvEY,oDAAoB;AAKd;IADhB,IAAA,cAAS,EAAC,qCAAgB,CAAC;sCACO,8CAAoB;8DAAC;+BAL7C,oBAAoB;IADhC,IAAA,eAAU,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;GAClB,oBAAoB,CAuEhC;AAGY,QAAA,qBAAqB,GAAG,MAAM,CAAC,uBAAuB,CAAC,CAAC;AAErE,MAAa,gBAAgB;IAE3B,YACmB,aAAmC;QAAnC,kBAAa,GAAb,aAAa,CAAsB;QAG9C,YAAO,GAAY,IAAI,CAAC;IAF7B,CAAC;IAIJ,SAAS;QACP,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED,aAAa;QACX,OAAO,cAAc,CAAC;IACxB,CAAC;IAED,KAAK,CAAC,KAAK;QACT,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,OAAO;QACT,CAAC;QACD,2BAA2B;QAC3B,4CAA4C;QAC5C,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;IACtB,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,QAAgB,EAAE,UAAkB;QACjD,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;QAC5C,CAAC;QACD,IAAI,IAAI,CAAC;QACT,IAAI,CAAC;YACH,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QAChC,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CACX,+CAA+C,QAAQ;wBACvC,UAAU,EAAE,EAC5B,KAAK,CACN,CAAC;YACF,MAAM,KAAK,CAAC;QACd,CAAC;QACD,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;IACxD,CAAC;IAED,KAAK,CAAC,QAAQ;QACZ,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;QAC5C,CAAC;QACD,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC;QACrD,OAAO,EAAE,KAAK,EAAE,CAAC;IACnB,CAAC;IAED,MAAM,CAAC,QAAgB,EAAE,KAAgB,EAAE,IAAgC;QACzE,uEAAuE;IACzE,CAAC;IAED,IAAI;QACF,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,OAAO;QACT,CAAC;QACD,kDAAkD;QAClD,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;CACF;AA9DD,4CA8DC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { MCPServerDescription, MCPServerManager } from '../common/mcp-server-manager';
|
|
2
|
+
import { BuiltinMCPServer } from './mcp/sumi-mcp-server';
|
|
3
|
+
import { IMCPServer } from './mcp-server';
|
|
4
|
+
export declare class MCPServerManagerImpl implements MCPServerManager {
|
|
5
|
+
private readonly toolInvocationRegistry;
|
|
6
|
+
protected servers: Map<string, IMCPServer>;
|
|
7
|
+
stopServer(serverName: string): Promise<void>;
|
|
8
|
+
getStartedServers(): Promise<string[]>;
|
|
9
|
+
callTool(serverName: string, toolName: string, arg_string: string): ReturnType<IMCPServer['callTool']>;
|
|
10
|
+
startServer(serverName: string): Promise<void>;
|
|
11
|
+
getServerNames(): Promise<string[]>;
|
|
12
|
+
private convertToToolRequest;
|
|
13
|
+
collectTools(serverName: string): Promise<void>;
|
|
14
|
+
getTools(serverName: string): ReturnType<IMCPServer['getTools']>;
|
|
15
|
+
addOrUpdateServer(description: MCPServerDescription): void;
|
|
16
|
+
addOrUpdateServerDirectly(server: IMCPServer): void;
|
|
17
|
+
initBuiltinServer(builtinMCPServer: BuiltinMCPServer): void;
|
|
18
|
+
removeServer(name: string): void;
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=mcp-server-manager-impl.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mcp-server-manager-impl.d.ts","sourceRoot":"","sources":["../../src/node/mcp-server-manager-impl.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,oBAAoB,EAAE,gBAAgB,EAAW,MAAM,8BAA8B,CAAC;AAG/F,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AACzD,OAAO,EAAE,UAAU,EAAiB,MAAM,cAAc,CAAC;AAEzD,qBACa,oBAAqB,YAAW,gBAAgB;IAE3D,OAAO,CAAC,QAAQ,CAAC,sBAAsB,CAA6B;IAEpE,SAAS,CAAC,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,UAAU,CAAC,CAAa;IAEjD,UAAU,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAS7C,iBAAiB,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;IAU5C,QAAQ,CAAC,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,UAAU,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;IAQhG,WAAW,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ9C,cAAc,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;IAIzC,OAAO,CAAC,oBAAoB;IAuBf,YAAY,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAc/C,QAAQ,CAAC,UAAU,EAAE,MAAM,GAAG,UAAU,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;IAQ7E,iBAAiB,CAAC,WAAW,EAAE,oBAAoB,GAAG,IAAI;IAY1D,yBAAyB,CAAC,MAAM,EAAE,UAAU,GAAG,IAAI;IAInD,iBAAiB,CAAC,gBAAgB,EAAE,gBAAgB,GAAG,IAAI;IAK3D,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;CASjC"}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MCPServerManagerImpl = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const di_1 = require("@opensumi/di");
|
|
6
|
+
const tool_invocation_registry_1 = require("../common/tool-invocation-registry");
|
|
7
|
+
const mcp_server_1 = require("./mcp-server");
|
|
8
|
+
let MCPServerManagerImpl = class MCPServerManagerImpl {
|
|
9
|
+
constructor() {
|
|
10
|
+
this.servers = new Map();
|
|
11
|
+
}
|
|
12
|
+
async stopServer(serverName) {
|
|
13
|
+
const server = this.servers.get(serverName);
|
|
14
|
+
if (!server) {
|
|
15
|
+
throw new Error(`MCP server "${serverName}" not found.`);
|
|
16
|
+
}
|
|
17
|
+
server.stop();
|
|
18
|
+
console.log(`MCP server "${serverName}" stopped.`);
|
|
19
|
+
}
|
|
20
|
+
async getStartedServers() {
|
|
21
|
+
const startedServers = [];
|
|
22
|
+
for (const [name, server] of this.servers.entries()) {
|
|
23
|
+
if (server.isStarted()) {
|
|
24
|
+
startedServers.push(name);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
return startedServers;
|
|
28
|
+
}
|
|
29
|
+
callTool(serverName, toolName, arg_string) {
|
|
30
|
+
const server = this.servers.get(serverName);
|
|
31
|
+
if (!server) {
|
|
32
|
+
throw new Error(`MCP server "${toolName}" not found.`);
|
|
33
|
+
}
|
|
34
|
+
return server.callTool(toolName, arg_string);
|
|
35
|
+
}
|
|
36
|
+
async startServer(serverName) {
|
|
37
|
+
const server = this.servers.get(serverName);
|
|
38
|
+
if (!server) {
|
|
39
|
+
throw new Error(`MCP server "${serverName}" not found.`);
|
|
40
|
+
}
|
|
41
|
+
await server.start();
|
|
42
|
+
}
|
|
43
|
+
async getServerNames() {
|
|
44
|
+
return Array.from(this.servers.keys());
|
|
45
|
+
}
|
|
46
|
+
convertToToolRequest(tool, serverName) {
|
|
47
|
+
const id = `mcp_${serverName}_${tool.name}`;
|
|
48
|
+
return {
|
|
49
|
+
id,
|
|
50
|
+
name: id,
|
|
51
|
+
providerName: `mcp_${serverName}`,
|
|
52
|
+
parameters: tool.inputSchema,
|
|
53
|
+
description: tool.description,
|
|
54
|
+
handler: async (arg_string) => {
|
|
55
|
+
try {
|
|
56
|
+
const res = await this.callTool(serverName, tool.name, arg_string);
|
|
57
|
+
console.log(`[MCP: ${serverName}] ${tool.name} called with ${arg_string}`);
|
|
58
|
+
console.log(res);
|
|
59
|
+
return JSON.stringify(res);
|
|
60
|
+
}
|
|
61
|
+
catch (error) {
|
|
62
|
+
console.error(`Error in tool handler for ${tool.name} on MCP server ${serverName}:`, error);
|
|
63
|
+
throw error;
|
|
64
|
+
}
|
|
65
|
+
},
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
async collectTools(serverName) {
|
|
69
|
+
const server = this.servers.get(serverName);
|
|
70
|
+
if (!server) {
|
|
71
|
+
throw new Error(`MCP server "${serverName}" not found.`);
|
|
72
|
+
}
|
|
73
|
+
const { tools } = await server.getTools();
|
|
74
|
+
const toolRequests = tools.map((tool) => this.convertToToolRequest(tool, serverName));
|
|
75
|
+
for (const toolRequest of toolRequests) {
|
|
76
|
+
this.toolInvocationRegistry.registerTool(toolRequest);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
async getTools(serverName) {
|
|
80
|
+
const server = this.servers.get(serverName);
|
|
81
|
+
if (!server) {
|
|
82
|
+
throw new Error(`MCP server "${serverName}" not found.`);
|
|
83
|
+
}
|
|
84
|
+
return server.getTools();
|
|
85
|
+
}
|
|
86
|
+
addOrUpdateServer(description) {
|
|
87
|
+
const { name, command, args, env } = description;
|
|
88
|
+
const existingServer = this.servers.get(name);
|
|
89
|
+
if (existingServer) {
|
|
90
|
+
existingServer.update(command, args, env);
|
|
91
|
+
}
|
|
92
|
+
else {
|
|
93
|
+
const newServer = new mcp_server_1.MCPServerImpl(name, command, args, env);
|
|
94
|
+
this.servers.set(name, newServer);
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
addOrUpdateServerDirectly(server) {
|
|
98
|
+
this.servers.set(server.getServerName(), server);
|
|
99
|
+
}
|
|
100
|
+
initBuiltinServer(builtinMCPServer) {
|
|
101
|
+
this.addOrUpdateServerDirectly(builtinMCPServer);
|
|
102
|
+
this.collectTools(builtinMCPServer.getServerName());
|
|
103
|
+
}
|
|
104
|
+
removeServer(name) {
|
|
105
|
+
const server = this.servers.get(name);
|
|
106
|
+
if (server) {
|
|
107
|
+
server.stop();
|
|
108
|
+
this.servers.delete(name);
|
|
109
|
+
}
|
|
110
|
+
else {
|
|
111
|
+
console.warn(`MCP server "${name}" not found.`);
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
};
|
|
115
|
+
exports.MCPServerManagerImpl = MCPServerManagerImpl;
|
|
116
|
+
tslib_1.__decorate([
|
|
117
|
+
(0, di_1.Autowired)(tool_invocation_registry_1.ToolInvocationRegistry),
|
|
118
|
+
tslib_1.__metadata("design:type", tool_invocation_registry_1.ToolInvocationRegistryImpl)
|
|
119
|
+
], MCPServerManagerImpl.prototype, "toolInvocationRegistry", void 0);
|
|
120
|
+
exports.MCPServerManagerImpl = MCPServerManagerImpl = tslib_1.__decorate([
|
|
121
|
+
(0, di_1.Injectable)()
|
|
122
|
+
], MCPServerManagerImpl);
|
|
123
|
+
//# sourceMappingURL=mcp-server-manager-impl.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mcp-server-manager-impl.js","sourceRoot":"","sources":["../../src/node/mcp-server-manager-impl.ts"],"names":[],"mappings":"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"}
|