@ai-support-agent/cli 0.0.4-beta.9 → 0.0.5-beta.1
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/agent-runner.d.ts +4 -1
- package/dist/agent-runner.d.ts.map +1 -1
- package/dist/agent-runner.js +17 -5
- package/dist/agent-runner.js.map +1 -1
- package/dist/api-client.d.ts +5 -1
- package/dist/api-client.d.ts.map +1 -1
- package/dist/api-client.js +55 -63
- package/dist/api-client.js.map +1 -1
- package/dist/appsync-subscriber.d.ts.map +1 -1
- package/dist/appsync-subscriber.js +3 -1
- package/dist/appsync-subscriber.js.map +1 -1
- package/dist/auto-updater.d.ts.map +1 -1
- package/dist/auto-updater.js +7 -2
- package/dist/auto-updater.js.map +1 -1
- package/dist/aws-credential-builder.d.ts +11 -2
- package/dist/aws-credential-builder.d.ts.map +1 -1
- package/dist/aws-credential-builder.js +45 -6
- package/dist/aws-credential-builder.js.map +1 -1
- package/dist/commands/api-chat-executor.d.ts.map +1 -1
- package/dist/commands/api-chat-executor.js +11 -3
- package/dist/commands/api-chat-executor.js.map +1 -1
- package/dist/commands/chat-executor.d.ts +1 -1
- package/dist/commands/chat-executor.d.ts.map +1 -1
- package/dist/commands/chat-executor.js +40 -42
- package/dist/commands/chat-executor.js.map +1 -1
- package/dist/commands/claude-code-runner.d.ts +4 -2
- package/dist/commands/claude-code-runner.d.ts.map +1 -1
- package/dist/commands/claude-code-runner.js +8 -4
- package/dist/commands/claude-code-runner.js.map +1 -1
- package/dist/commands/index.d.ts +1 -0
- package/dist/commands/index.d.ts.map +1 -1
- package/dist/commands/index.js +1 -1
- package/dist/commands/index.js.map +1 -1
- package/dist/commands/shared-chat-utils.d.ts +9 -1
- package/dist/commands/shared-chat-utils.d.ts.map +1 -1
- package/dist/commands/shared-chat-utils.js +24 -0
- package/dist/commands/shared-chat-utils.js.map +1 -1
- package/dist/config-manager.d.ts +1 -0
- package/dist/config-manager.d.ts.map +1 -1
- package/dist/config-manager.js +1 -0
- package/dist/config-manager.js.map +1 -1
- package/dist/constants.d.ts +3 -0
- package/dist/constants.d.ts.map +1 -1
- package/dist/constants.js +6 -2
- package/dist/constants.js.map +1 -1
- package/dist/docker/docker-runner.d.ts +19 -0
- package/dist/docker/docker-runner.d.ts.map +1 -0
- package/dist/docker/docker-runner.js +221 -0
- package/dist/docker/docker-runner.js.map +1 -0
- package/dist/docker/dockerfile-path.d.ts +10 -0
- package/dist/docker/dockerfile-path.d.ts.map +1 -0
- package/dist/docker/dockerfile-path.js +25 -0
- package/dist/docker/dockerfile-path.js.map +1 -0
- package/dist/index.js +59 -0
- package/dist/index.js.map +1 -1
- package/dist/locales/en.json +25 -1
- package/dist/locales/ja.json +25 -1
- package/dist/locales/locales/en.json +25 -1
- package/dist/locales/locales/ja.json +25 -1
- package/dist/logger.d.ts +2 -0
- package/dist/logger.d.ts.map +1 -1
- package/dist/logger.js +20 -1
- package/dist/logger.js.map +1 -1
- package/dist/mcp/config-writer.d.ts +17 -0
- package/dist/mcp/config-writer.d.ts.map +1 -0
- package/dist/mcp/config-writer.js +63 -0
- package/dist/mcp/config-writer.js.map +1 -0
- package/dist/mcp/server.d.ts +11 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +55 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/mcp/tools/credentials.d.ts +14 -0
- package/dist/mcp/tools/credentials.d.ts.map +1 -0
- package/dist/mcp/tools/credentials.js +42 -0
- package/dist/mcp/tools/credentials.js.map +1 -0
- package/dist/mcp/tools/db-query.d.ts +13 -0
- package/dist/mcp/tools/db-query.d.ts.map +1 -0
- package/dist/mcp/tools/db-query.js +131 -0
- package/dist/mcp/tools/db-query.js.map +1 -0
- package/dist/mcp/tools/db-schemas.d.ts +5 -0
- package/dist/mcp/tools/db-schemas.d.ts.map +1 -0
- package/dist/mcp/tools/db-schemas.js +61 -0
- package/dist/mcp/tools/db-schemas.js.map +1 -0
- package/dist/mcp/tools/mcp-response.d.ts +15 -0
- package/dist/mcp/tools/mcp-response.d.ts.map +1 -0
- package/dist/mcp/tools/mcp-response.js +15 -0
- package/dist/mcp/tools/mcp-response.js.map +1 -0
- package/dist/mcp/tools/project-info.d.ts +5 -0
- package/dist/mcp/tools/project-info.d.ts.map +1 -0
- package/dist/mcp/tools/project-info.js +43 -0
- package/dist/mcp/tools/project-info.js.map +1 -0
- package/dist/project-agent.d.ts +4 -0
- package/dist/project-agent.d.ts.map +1 -1
- package/dist/project-agent.js +38 -2
- package/dist/project-agent.js.map +1 -1
- package/dist/project-dir.d.ts.map +1 -1
- package/dist/project-dir.js +5 -2
- package/dist/project-dir.js.map +1 -1
- package/dist/sentry.d.ts +14 -0
- package/dist/sentry.d.ts.map +1 -0
- package/dist/sentry.js +98 -0
- package/dist/sentry.js.map +1 -0
- package/dist/types.d.ts +33 -1
- package/dist/types.d.ts.map +1 -1
- package/dist/update-checker.d.ts +26 -5
- package/dist/update-checker.d.ts.map +1 -1
- package/dist/update-checker.js +148 -8
- package/dist/update-checker.js.map +1 -1
- package/docker/Dockerfile +39 -0
- package/package.json +7 -1
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getMcpConfigPath = getMcpConfigPath;
|
|
4
|
+
exports.buildMcpConfig = buildMcpConfig;
|
|
5
|
+
exports.writeMcpConfig = writeMcpConfig;
|
|
6
|
+
const fs_1 = require("fs");
|
|
7
|
+
const path_1 = require("path");
|
|
8
|
+
/**
|
|
9
|
+
* MCP 設定ファイルのパスを返す
|
|
10
|
+
*/
|
|
11
|
+
function getMcpConfigPath(projectDir) {
|
|
12
|
+
return (0, path_1.join)(projectDir, '.ai-support-agent', 'mcp', 'config.json');
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* MCP 設定 JSON を構築する
|
|
16
|
+
*
|
|
17
|
+
* token はファイルに書かない。環境変数参照にする。
|
|
18
|
+
*/
|
|
19
|
+
function buildMcpConfig(apiUrl, projectCode, mcpServerPath) {
|
|
20
|
+
return {
|
|
21
|
+
mcpServers: {
|
|
22
|
+
'ai-support-agent': {
|
|
23
|
+
command: 'node',
|
|
24
|
+
args: [mcpServerPath],
|
|
25
|
+
env: {
|
|
26
|
+
AI_SUPPORT_AGENT_API_URL: apiUrl,
|
|
27
|
+
AI_SUPPORT_AGENT_TOKEN: '${AI_SUPPORT_AGENT_TOKEN}',
|
|
28
|
+
AI_SUPPORT_AGENT_PROJECT_CODE: projectCode,
|
|
29
|
+
},
|
|
30
|
+
},
|
|
31
|
+
},
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* MCP 設定ファイルを書き出す
|
|
36
|
+
*
|
|
37
|
+
* 0o600 権限で作成し、token は環境変数参照にする。
|
|
38
|
+
*/
|
|
39
|
+
function writeMcpConfig(projectDir, apiUrl, token, projectCode, mcpServerPath) {
|
|
40
|
+
const configPath = getMcpConfigPath(projectDir);
|
|
41
|
+
const dir = (0, path_1.dirname)(configPath);
|
|
42
|
+
(0, fs_1.mkdirSync)(dir, { recursive: true, mode: 0o700 });
|
|
43
|
+
// 実際の設定: token を直接埋め込む(ファイルは 0o600 で保護)
|
|
44
|
+
const config = {
|
|
45
|
+
mcpServers: {
|
|
46
|
+
'ai-support-agent': {
|
|
47
|
+
command: 'node',
|
|
48
|
+
args: [mcpServerPath],
|
|
49
|
+
env: {
|
|
50
|
+
AI_SUPPORT_AGENT_API_URL: apiUrl,
|
|
51
|
+
AI_SUPPORT_AGENT_TOKEN: token,
|
|
52
|
+
AI_SUPPORT_AGENT_PROJECT_CODE: projectCode,
|
|
53
|
+
},
|
|
54
|
+
},
|
|
55
|
+
},
|
|
56
|
+
};
|
|
57
|
+
(0, fs_1.writeFileSync)(configPath, JSON.stringify(config, null, 2), {
|
|
58
|
+
mode: 0o600,
|
|
59
|
+
encoding: 'utf-8',
|
|
60
|
+
});
|
|
61
|
+
return configPath;
|
|
62
|
+
}
|
|
63
|
+
//# sourceMappingURL=config-writer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config-writer.js","sourceRoot":"","sources":["../../src/mcp/config-writer.ts"],"names":[],"mappings":";;AAMA,4CAEC;AAOD,wCAkBC;AAOD,wCAiCC;AAzED,2BAA6C;AAC7C,+BAAoC;AAEpC;;GAEG;AACH,SAAgB,gBAAgB,CAAC,UAAkB;IACjD,OAAO,IAAA,WAAI,EAAC,UAAU,EAAE,mBAAmB,EAAE,KAAK,EAAE,aAAa,CAAC,CAAA;AACpE,CAAC;AAED;;;;GAIG;AACH,SAAgB,cAAc,CAC5B,MAAc,EACd,WAAmB,EACnB,aAAqB;IAErB,OAAO;QACL,UAAU,EAAE;YACV,kBAAkB,EAAE;gBAClB,OAAO,EAAE,MAAM;gBACf,IAAI,EAAE,CAAC,aAAa,CAAC;gBACrB,GAAG,EAAE;oBACH,wBAAwB,EAAE,MAAM;oBAChC,sBAAsB,EAAE,2BAA2B;oBACnD,6BAA6B,EAAE,WAAW;iBAC3C;aACF;SACF;KACF,CAAA;AACH,CAAC;AAED;;;;GAIG;AACH,SAAgB,cAAc,CAC5B,UAAkB,EAClB,MAAc,EACd,KAAa,EACb,WAAmB,EACnB,aAAqB;IAErB,MAAM,UAAU,GAAG,gBAAgB,CAAC,UAAU,CAAC,CAAA;IAC/C,MAAM,GAAG,GAAG,IAAA,cAAO,EAAC,UAAU,CAAC,CAAA;IAE/B,IAAA,cAAS,EAAC,GAAG,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAA;IAEhD,wCAAwC;IACxC,MAAM,MAAM,GAAG;QACb,UAAU,EAAE;YACV,kBAAkB,EAAE;gBAClB,OAAO,EAAE,MAAM;gBACf,IAAI,EAAE,CAAC,aAAa,CAAC;gBACrB,GAAG,EAAE;oBACH,wBAAwB,EAAE,MAAM;oBAChC,sBAAsB,EAAE,KAAK;oBAC7B,6BAA6B,EAAE,WAAW;iBAC3C;aACF;SACF;KACF,CAAA;IAED,IAAA,kBAAa,EAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE;QACzD,IAAI,EAAE,KAAK;QACX,QAAQ,EAAE,OAAO;KAClB,CAAC,CAAA;IAEF,OAAO,UAAU,CAAA;AACnB,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';
|
|
2
|
+
import { ApiClient } from '../api-client';
|
|
3
|
+
/**
|
|
4
|
+
* MCP サーバーを作成する
|
|
5
|
+
*/
|
|
6
|
+
export declare function createMcpServer(apiClient: ApiClient, projectCode: string): McpServer;
|
|
7
|
+
/**
|
|
8
|
+
* MCP サーバーを stdio transport で起動する
|
|
9
|
+
*/
|
|
10
|
+
export declare function startMcpServer(): Promise<void>;
|
|
11
|
+
//# sourceMappingURL=server.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../src/mcp/server.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAA;AAGnE,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAA;AAMzC;;GAEG;AACH,wBAAgB,eAAe,CAAC,SAAS,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,GAAG,SAAS,CAYpF;AAED;;GAEG;AACH,wBAAsB,cAAc,IAAI,OAAO,CAAC,IAAI,CAAC,CAiBpD"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createMcpServer = createMcpServer;
|
|
4
|
+
exports.startMcpServer = startMcpServer;
|
|
5
|
+
const mcp_js_1 = require("@modelcontextprotocol/sdk/server/mcp.js");
|
|
6
|
+
const stdio_js_1 = require("@modelcontextprotocol/sdk/server/stdio.js");
|
|
7
|
+
const api_client_1 = require("../api-client");
|
|
8
|
+
const credentials_1 = require("./tools/credentials");
|
|
9
|
+
const db_query_1 = require("./tools/db-query");
|
|
10
|
+
const db_schemas_1 = require("./tools/db-schemas");
|
|
11
|
+
const project_info_1 = require("./tools/project-info");
|
|
12
|
+
/**
|
|
13
|
+
* MCP サーバーを作成する
|
|
14
|
+
*/
|
|
15
|
+
function createMcpServer(apiClient, projectCode) {
|
|
16
|
+
const server = new mcp_js_1.McpServer({
|
|
17
|
+
name: 'ai-support-agent',
|
|
18
|
+
version: '1.0.0',
|
|
19
|
+
});
|
|
20
|
+
(0, db_query_1.registerDbQueryTool)(server, apiClient);
|
|
21
|
+
(0, db_schemas_1.registerDbSchemasTool)(server, apiClient);
|
|
22
|
+
(0, credentials_1.registerCredentialsTool)(server, apiClient);
|
|
23
|
+
(0, project_info_1.registerProjectInfoTool)(server, apiClient, projectCode);
|
|
24
|
+
return server;
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* MCP サーバーを stdio transport で起動する
|
|
28
|
+
*/
|
|
29
|
+
async function startMcpServer() {
|
|
30
|
+
const apiUrl = process.env.AI_SUPPORT_AGENT_API_URL;
|
|
31
|
+
const token = process.env.AI_SUPPORT_AGENT_TOKEN;
|
|
32
|
+
const projectCode = process.env.AI_SUPPORT_AGENT_PROJECT_CODE;
|
|
33
|
+
if (!apiUrl || !token || !projectCode) {
|
|
34
|
+
const missing = [];
|
|
35
|
+
if (!apiUrl)
|
|
36
|
+
missing.push('AI_SUPPORT_AGENT_API_URL');
|
|
37
|
+
if (!token)
|
|
38
|
+
missing.push('AI_SUPPORT_AGENT_TOKEN');
|
|
39
|
+
if (!projectCode)
|
|
40
|
+
missing.push('AI_SUPPORT_AGENT_PROJECT_CODE');
|
|
41
|
+
throw new Error(`Missing required environment variables: ${missing.join(', ')}`);
|
|
42
|
+
}
|
|
43
|
+
const apiClient = new api_client_1.ApiClient(apiUrl, token);
|
|
44
|
+
const server = createMcpServer(apiClient, projectCode);
|
|
45
|
+
const transport = new stdio_js_1.StdioServerTransport();
|
|
46
|
+
await server.connect(transport);
|
|
47
|
+
}
|
|
48
|
+
// When executed directly
|
|
49
|
+
if (require.main === module) {
|
|
50
|
+
startMcpServer().catch((error) => {
|
|
51
|
+
process.stderr.write(`MCP server error: ${error}\n`);
|
|
52
|
+
process.exit(1);
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
//# sourceMappingURL=server.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"server.js","sourceRoot":"","sources":["../../src/mcp/server.ts"],"names":[],"mappings":";;AAYA,0CAYC;AAKD,wCAiBC;AA9CD,oEAAmE;AACnE,wEAAgF;AAEhF,8CAAyC;AACzC,qDAA6D;AAC7D,+CAAsD;AACtD,mDAA0D;AAC1D,uDAA8D;AAE9D;;GAEG;AACH,SAAgB,eAAe,CAAC,SAAoB,EAAE,WAAmB;IACvE,MAAM,MAAM,GAAG,IAAI,kBAAS,CAAC;QAC3B,IAAI,EAAE,kBAAkB;QACxB,OAAO,EAAE,OAAO;KACjB,CAAC,CAAA;IAEF,IAAA,8BAAmB,EAAC,MAAM,EAAE,SAAS,CAAC,CAAA;IACtC,IAAA,kCAAqB,EAAC,MAAM,EAAE,SAAS,CAAC,CAAA;IACxC,IAAA,qCAAuB,EAAC,MAAM,EAAE,SAAS,CAAC,CAAA;IAC1C,IAAA,sCAAuB,EAAC,MAAM,EAAE,SAAS,EAAE,WAAW,CAAC,CAAA;IAEvD,OAAO,MAAM,CAAA;AACf,CAAC;AAED;;GAEG;AACI,KAAK,UAAU,cAAc;IAClC,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,wBAAwB,CAAA;IACnD,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,sBAAsB,CAAA;IAChD,MAAM,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC,6BAA6B,CAAA;IAE7D,IAAI,CAAC,MAAM,IAAI,CAAC,KAAK,IAAI,CAAC,WAAW,EAAE,CAAC;QACtC,MAAM,OAAO,GAAG,EAAE,CAAA;QAClB,IAAI,CAAC,MAAM;YAAE,OAAO,CAAC,IAAI,CAAC,0BAA0B,CAAC,CAAA;QACrD,IAAI,CAAC,KAAK;YAAE,OAAO,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAA;QAClD,IAAI,CAAC,WAAW;YAAE,OAAO,CAAC,IAAI,CAAC,+BAA+B,CAAC,CAAA;QAC/D,MAAM,IAAI,KAAK,CAAC,2CAA2C,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;IAClF,CAAC;IAED,MAAM,SAAS,GAAG,IAAI,sBAAS,CAAC,MAAM,EAAE,KAAK,CAAC,CAAA;IAC9C,MAAM,MAAM,GAAG,eAAe,CAAC,SAAS,EAAE,WAAW,CAAC,CAAA;IACtD,MAAM,SAAS,GAAG,IAAI,+BAAoB,EAAE,CAAA;IAC5C,MAAM,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,CAAA;AACjC,CAAC;AAED,yBAAyB;AACzB,IAAI,OAAO,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;IAC5B,cAAc,EAAE,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE;QAC/B,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,qBAAqB,KAAK,IAAI,CAAC,CAAA;QACpD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IACjB,CAAC,CAAC,CAAA;AACJ,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';
|
|
2
|
+
import { ApiClient } from '../../api-client';
|
|
3
|
+
/**
|
|
4
|
+
* get_credentials ツールを MCP サーバーに登録する
|
|
5
|
+
*
|
|
6
|
+
* セキュリティ設計:
|
|
7
|
+
* - 認証情報はサーバーサイドで管理され、APIを通じてオンデマンドで取得する
|
|
8
|
+
* - クライアント側にはシークレットを永続化しない(メモリ内のみ)
|
|
9
|
+
* - API呼び出しにはBearerトークン認証が必要
|
|
10
|
+
* - AWS認証情報は一時的なSTS資格情報(有効期限あり)
|
|
11
|
+
* - DB認証情報はサーバー管理のSecureStringから取得
|
|
12
|
+
*/
|
|
13
|
+
export declare function registerCredentialsTool(server: McpServer, apiClient: ApiClient): void;
|
|
14
|
+
//# sourceMappingURL=credentials.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"credentials.d.ts","sourceRoot":"","sources":["../../../src/mcp/tools/credentials.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAA;AAGnE,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAA;AAG5C;;;;;;;;;GASG;AACH,wBAAgB,uBAAuB,CAAC,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,GAAG,IAAI,CA+BrF"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.registerCredentialsTool = registerCredentialsTool;
|
|
4
|
+
const zod_1 = require("zod");
|
|
5
|
+
const mcp_response_1 = require("./mcp-response");
|
|
6
|
+
/**
|
|
7
|
+
* get_credentials ツールを MCP サーバーに登録する
|
|
8
|
+
*
|
|
9
|
+
* セキュリティ設計:
|
|
10
|
+
* - 認証情報はサーバーサイドで管理され、APIを通じてオンデマンドで取得する
|
|
11
|
+
* - クライアント側にはシークレットを永続化しない(メモリ内のみ)
|
|
12
|
+
* - API呼び出しにはBearerトークン認証が必要
|
|
13
|
+
* - AWS認証情報は一時的なSTS資格情報(有効期限あり)
|
|
14
|
+
* - DB認証情報はサーバー管理のSecureStringから取得
|
|
15
|
+
*/
|
|
16
|
+
function registerCredentialsTool(server, apiClient) {
|
|
17
|
+
server.tool('get_credentials', 'Get credentials for a service (AWS or database).', {
|
|
18
|
+
type: zod_1.z.enum(['aws', 'db']).describe('Credential type'),
|
|
19
|
+
name: zod_1.z.string().describe('Identifier (AWS account ID or DB connection name)'),
|
|
20
|
+
}, async ({ type, name }) => {
|
|
21
|
+
try {
|
|
22
|
+
if (type === 'aws') {
|
|
23
|
+
const credentials = await apiClient.getAwsCredentials(name);
|
|
24
|
+
return (0, mcp_response_1.mcpTextResponse)(JSON.stringify({
|
|
25
|
+
accessKeyId: credentials.accessKeyId,
|
|
26
|
+
secretAccessKey: credentials.secretAccessKey,
|
|
27
|
+
sessionToken: credentials.sessionToken,
|
|
28
|
+
region: credentials.region,
|
|
29
|
+
}, null, 2));
|
|
30
|
+
}
|
|
31
|
+
if (type === 'db') {
|
|
32
|
+
const credentials = await apiClient.getDbCredentials(name);
|
|
33
|
+
return (0, mcp_response_1.mcpTextResponse)(JSON.stringify(credentials, null, 2));
|
|
34
|
+
}
|
|
35
|
+
return (0, mcp_response_1.mcpErrorResponse)(`Unknown credential type: ${type}`);
|
|
36
|
+
}
|
|
37
|
+
catch (error) {
|
|
38
|
+
return (0, mcp_response_1.mcpErrorResponse)((0, mcp_response_1.extractErrorMessage)(error));
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=credentials.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"credentials.js","sourceRoot":"","sources":["../../../src/mcp/tools/credentials.ts"],"names":[],"mappings":";;AAgBA,0DA+BC;AA9CD,6BAAuB;AAGvB,iDAAuF;AAEvF;;;;;;;;;GASG;AACH,SAAgB,uBAAuB,CAAC,MAAiB,EAAE,SAAoB;IAC7E,MAAM,CAAC,IAAI,CACT,iBAAiB,EACjB,kDAAkD,EAClD;QACE,IAAI,EAAE,OAAC,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,iBAAiB,CAAC;QACvD,IAAI,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,mDAAmD,CAAC;KAC/E,EACD,KAAK,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,EAAE;QACvB,IAAI,CAAC;YACH,IAAI,IAAI,KAAK,KAAK,EAAE,CAAC;gBACnB,MAAM,WAAW,GAAG,MAAM,SAAS,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAA;gBAC3D,OAAO,IAAA,8BAAe,EAAC,IAAI,CAAC,SAAS,CAAC;oBACpC,WAAW,EAAE,WAAW,CAAC,WAAW;oBACpC,eAAe,EAAE,WAAW,CAAC,eAAe;oBAC5C,YAAY,EAAE,WAAW,CAAC,YAAY;oBACtC,MAAM,EAAE,WAAW,CAAC,MAAM;iBAC3B,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAA;YACd,CAAC;YAED,IAAI,IAAI,KAAK,IAAI,EAAE,CAAC;gBAClB,MAAM,WAAW,GAAG,MAAM,SAAS,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAA;gBAC1D,OAAO,IAAA,8BAAe,EAAC,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAA;YAC9D,CAAC;YAED,OAAO,IAAA,+BAAgB,EAAC,4BAA4B,IAAI,EAAE,CAAC,CAAA;QAC7D,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,IAAA,+BAAgB,EAAC,IAAA,kCAAmB,EAAC,KAAK,CAAC,CAAC,CAAA;QACrD,CAAC;IACH,CAAC,CACF,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';
|
|
2
|
+
import { ApiClient } from '../../api-client';
|
|
3
|
+
import type { DbCredentials } from '../../types';
|
|
4
|
+
/** SQL文が SELECT のみかどうか検証する */
|
|
5
|
+
export declare function validateSelectOnly(sql: string): {
|
|
6
|
+
valid: boolean;
|
|
7
|
+
error?: string;
|
|
8
|
+
};
|
|
9
|
+
/** DB接続を作成してクエリを実行する */
|
|
10
|
+
export declare function executeQuery(credentials: DbCredentials, sql: string): Promise<unknown[]>;
|
|
11
|
+
/** db_query ツールを MCP サーバーに登録する */
|
|
12
|
+
export declare function registerDbQueryTool(server: McpServer, apiClient: ApiClient): void;
|
|
13
|
+
//# sourceMappingURL=db-query.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"db-query.d.ts","sourceRoot":"","sources":["../../../src/mcp/tools/db-query.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAA;AAGnE,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAA;AAC5C,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,aAAa,CAAA;AAGhD,8BAA8B;AAC9B,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,MAAM,GAAG;IAAE,KAAK,EAAE,OAAO,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,CAAA;CAAE,CAuBlF;AAED,wBAAwB;AACxB,wBAAsB,YAAY,CAChC,WAAW,EAAE,aAAa,EAC1B,GAAG,EAAE,MAAM,GACV,OAAO,CAAC,OAAO,EAAE,CAAC,CA0CpB;AAED,kCAAkC;AAClC,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,GAAG,IAAI,CA6BjF"}
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.validateSelectOnly = validateSelectOnly;
|
|
37
|
+
exports.executeQuery = executeQuery;
|
|
38
|
+
exports.registerDbQueryTool = registerDbQueryTool;
|
|
39
|
+
const zod_1 = require("zod");
|
|
40
|
+
const mcp_response_1 = require("./mcp-response");
|
|
41
|
+
/** SQL文が SELECT のみかどうか検証する */
|
|
42
|
+
function validateSelectOnly(sql) {
|
|
43
|
+
const trimmed = sql.trim();
|
|
44
|
+
if (!trimmed) {
|
|
45
|
+
return { valid: false, error: 'SQL query is empty' };
|
|
46
|
+
}
|
|
47
|
+
// 禁止キーワードをチェック(大文字小文字無視)
|
|
48
|
+
const forbidden = ['DROP', 'DELETE', 'UPDATE', 'INSERT', 'TRUNCATE', 'ALTER', 'CREATE', 'GRANT', 'REVOKE'];
|
|
49
|
+
const upper = trimmed.toUpperCase();
|
|
50
|
+
for (const keyword of forbidden) {
|
|
51
|
+
// 単語境界でマッチ(前後が非単語文字 or 文字列の先頭/末尾)
|
|
52
|
+
const regex = new RegExp(`(?<![A-Z_])${keyword}(?![A-Z_])`);
|
|
53
|
+
if (regex.test(upper)) {
|
|
54
|
+
return { valid: false, error: `Forbidden SQL operation: ${keyword}` };
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
// SELECT で始まることを確認(WITH ... SELECT も許可)
|
|
58
|
+
if (!upper.startsWith('SELECT') && !upper.startsWith('WITH') && !upper.startsWith('EXPLAIN')) {
|
|
59
|
+
return { valid: false, error: 'Only SELECT, WITH, and EXPLAIN statements are allowed' };
|
|
60
|
+
}
|
|
61
|
+
return { valid: true };
|
|
62
|
+
}
|
|
63
|
+
/** DB接続を作成してクエリを実行する */
|
|
64
|
+
async function executeQuery(credentials, sql) {
|
|
65
|
+
if (credentials.engine === 'mysql') {
|
|
66
|
+
const mysql2 = await Promise.resolve().then(() => __importStar(require('mysql2/promise')));
|
|
67
|
+
const connection = await mysql2.createConnection({
|
|
68
|
+
host: credentials.host,
|
|
69
|
+
port: credentials.port,
|
|
70
|
+
user: credentials.user,
|
|
71
|
+
password: credentials.password,
|
|
72
|
+
database: credentials.database,
|
|
73
|
+
connectTimeout: 10000,
|
|
74
|
+
});
|
|
75
|
+
try {
|
|
76
|
+
const [rows] = await connection.query(sql);
|
|
77
|
+
return rows;
|
|
78
|
+
}
|
|
79
|
+
finally {
|
|
80
|
+
await connection.end();
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
if (credentials.engine === 'postgresql') {
|
|
84
|
+
const { Client } = await Promise.resolve().then(() => __importStar(require('pg')));
|
|
85
|
+
const isLocalHost = credentials.host === 'localhost' || credentials.host === '127.0.0.1';
|
|
86
|
+
const useSsl = credentials.ssl !== undefined ? credentials.ssl : !isLocalHost;
|
|
87
|
+
const client = new Client({
|
|
88
|
+
host: credentials.host,
|
|
89
|
+
port: credentials.port,
|
|
90
|
+
user: credentials.user,
|
|
91
|
+
password: credentials.password,
|
|
92
|
+
database: credentials.database,
|
|
93
|
+
connectionTimeoutMillis: 10000,
|
|
94
|
+
ssl: useSsl ? { rejectUnauthorized: true } : false,
|
|
95
|
+
});
|
|
96
|
+
try {
|
|
97
|
+
await client.connect();
|
|
98
|
+
const result = await client.query(sql);
|
|
99
|
+
return result.rows;
|
|
100
|
+
}
|
|
101
|
+
finally {
|
|
102
|
+
await client.end();
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
throw new Error(`Unsupported database engine: ${credentials.engine}`);
|
|
106
|
+
}
|
|
107
|
+
/** db_query ツールを MCP サーバーに登録する */
|
|
108
|
+
function registerDbQueryTool(server, apiClient) {
|
|
109
|
+
server.tool('db_query', 'Execute a SELECT query on a project database. Only SELECT/WITH/EXPLAIN statements are allowed.', {
|
|
110
|
+
name: zod_1.z.string().describe('Database connection name (e.g. "MAIN", "READONLY")'),
|
|
111
|
+
sql: zod_1.z.string().describe('SQL query to execute (SELECT only)'),
|
|
112
|
+
}, async ({ name, sql }) => {
|
|
113
|
+
// Validate SQL
|
|
114
|
+
const validation = validateSelectOnly(sql);
|
|
115
|
+
if (!validation.valid) {
|
|
116
|
+
return (0, mcp_response_1.mcpErrorResponse)(validation.error);
|
|
117
|
+
}
|
|
118
|
+
try {
|
|
119
|
+
// Get credentials from API
|
|
120
|
+
const credentials = await apiClient.getDbCredentials(name);
|
|
121
|
+
// Execute query
|
|
122
|
+
const rows = await executeQuery(credentials, sql);
|
|
123
|
+
// Format result
|
|
124
|
+
return (0, mcp_response_1.mcpTextResponse)(JSON.stringify(rows, null, 2));
|
|
125
|
+
}
|
|
126
|
+
catch (error) {
|
|
127
|
+
return (0, mcp_response_1.mcpErrorResponse)((0, mcp_response_1.extractErrorMessage)(error));
|
|
128
|
+
}
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
//# sourceMappingURL=db-query.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"db-query.js","sourceRoot":"","sources":["../../../src/mcp/tools/db-query.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAQA,gDAuBC;AAGD,oCA6CC;AAGD,kDA6BC;AA9GD,6BAAuB;AAIvB,iDAAuF;AAEvF,8BAA8B;AAC9B,SAAgB,kBAAkB,CAAC,GAAW;IAC5C,MAAM,OAAO,GAAG,GAAG,CAAC,IAAI,EAAE,CAAA;IAC1B,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,oBAAoB,EAAE,CAAA;IACtD,CAAC;IAED,yBAAyB;IACzB,MAAM,SAAS,GAAG,CAAC,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,UAAU,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAA;IAC1G,MAAM,KAAK,GAAG,OAAO,CAAC,WAAW,EAAE,CAAA;IACnC,KAAK,MAAM,OAAO,IAAI,SAAS,EAAE,CAAC;QAChC,kCAAkC;QAClC,MAAM,KAAK,GAAG,IAAI,MAAM,CAAC,cAAc,OAAO,YAAY,CAAC,CAAA;QAC3D,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;YACtB,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,4BAA4B,OAAO,EAAE,EAAE,CAAA;QACvE,CAAC;IACH,CAAC;IAED,wCAAwC;IACxC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;QAC7F,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,uDAAuD,EAAE,CAAA;IACzF,CAAC;IAED,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,CAAA;AACxB,CAAC;AAED,wBAAwB;AACjB,KAAK,UAAU,YAAY,CAChC,WAA0B,EAC1B,GAAW;IAEX,IAAI,WAAW,CAAC,MAAM,KAAK,OAAO,EAAE,CAAC;QACnC,MAAM,MAAM,GAAG,wDAAa,gBAAgB,GAAC,CAAA;QAC7C,MAAM,UAAU,GAAG,MAAM,MAAM,CAAC,gBAAgB,CAAC;YAC/C,IAAI,EAAE,WAAW,CAAC,IAAI;YACtB,IAAI,EAAE,WAAW,CAAC,IAAI;YACtB,IAAI,EAAE,WAAW,CAAC,IAAI;YACtB,QAAQ,EAAE,WAAW,CAAC,QAAQ;YAC9B,QAAQ,EAAE,WAAW,CAAC,QAAQ;YAC9B,cAAc,EAAE,KAAK;SACtB,CAAC,CAAA;QACF,IAAI,CAAC;YACH,MAAM,CAAC,IAAI,CAAC,GAAG,MAAM,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;YAC1C,OAAO,IAAiB,CAAA;QAC1B,CAAC;gBAAS,CAAC;YACT,MAAM,UAAU,CAAC,GAAG,EAAE,CAAA;QACxB,CAAC;IACH,CAAC;IAED,IAAI,WAAW,CAAC,MAAM,KAAK,YAAY,EAAE,CAAC;QACxC,MAAM,EAAE,MAAM,EAAE,GAAG,wDAAa,IAAI,GAAC,CAAA;QACrC,MAAM,WAAW,GAAG,WAAW,CAAC,IAAI,KAAK,WAAW,IAAI,WAAW,CAAC,IAAI,KAAK,WAAW,CAAA;QACxF,MAAM,MAAM,GAAG,WAAW,CAAC,GAAG,KAAK,SAAS,CAAC,CAAC,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,WAAW,CAAA;QAC7E,MAAM,MAAM,GAAG,IAAI,MAAM,CAAC;YACxB,IAAI,EAAE,WAAW,CAAC,IAAI;YACtB,IAAI,EAAE,WAAW,CAAC,IAAI;YACtB,IAAI,EAAE,WAAW,CAAC,IAAI;YACtB,QAAQ,EAAE,WAAW,CAAC,QAAQ;YAC9B,QAAQ,EAAE,WAAW,CAAC,QAAQ;YAC9B,uBAAuB,EAAE,KAAK;YAC9B,GAAG,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,kBAAkB,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,KAAK;SACnD,CAAC,CAAA;QACF,IAAI,CAAC;YACH,MAAM,MAAM,CAAC,OAAO,EAAE,CAAA;YACtB,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;YACtC,OAAO,MAAM,CAAC,IAAI,CAAA;QACpB,CAAC;gBAAS,CAAC;YACT,MAAM,MAAM,CAAC,GAAG,EAAE,CAAA;QACpB,CAAC;IACH,CAAC;IAED,MAAM,IAAI,KAAK,CAAC,gCAAgC,WAAW,CAAC,MAAM,EAAE,CAAC,CAAA;AACvE,CAAC;AAED,kCAAkC;AAClC,SAAgB,mBAAmB,CAAC,MAAiB,EAAE,SAAoB;IACzE,MAAM,CAAC,IAAI,CACT,UAAU,EACV,gGAAgG,EAChG;QACE,IAAI,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,oDAAoD,CAAC;QAC/E,GAAG,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,oCAAoC,CAAC;KAC/D,EACD,KAAK,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,EAAE,EAAE;QACtB,eAAe;QACf,MAAM,UAAU,GAAG,kBAAkB,CAAC,GAAG,CAAC,CAAA;QAC1C,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;YACtB,OAAO,IAAA,+BAAgB,EAAC,UAAU,CAAC,KAAM,CAAC,CAAA;QAC5C,CAAC;QAED,IAAI,CAAC;YACH,2BAA2B;YAC3B,MAAM,WAAW,GAAG,MAAM,SAAS,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAA;YAE1D,gBAAgB;YAChB,MAAM,IAAI,GAAG,MAAM,YAAY,CAAC,WAAW,EAAE,GAAG,CAAC,CAAA;YAEjD,gBAAgB;YAChB,OAAO,IAAA,8BAAe,EAAC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAA;QACvD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,IAAA,+BAAgB,EAAC,IAAA,kCAAmB,EAAC,KAAK,CAAC,CAAC,CAAA;QACrD,CAAC;IACH,CAAC,CACF,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';
|
|
2
|
+
import { ApiClient } from '../../api-client';
|
|
3
|
+
/** get_db_schemas ツールを MCP サーバーに登録する */
|
|
4
|
+
export declare function registerDbSchemasTool(server: McpServer, apiClient: ApiClient): void;
|
|
5
|
+
//# sourceMappingURL=db-schemas.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"db-schemas.d.ts","sourceRoot":"","sources":["../../../src/mcp/tools/db-schemas.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAA;AAGnE,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAA;AA0C5C,wCAAwC;AACxC,wBAAgB,qBAAqB,CAAC,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,GAAG,IAAI,CAuBnF"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.registerDbSchemasTool = registerDbSchemasTool;
|
|
4
|
+
const zod_1 = require("zod");
|
|
5
|
+
const db_query_1 = require("./db-query");
|
|
6
|
+
const mcp_response_1 = require("./mcp-response");
|
|
7
|
+
const MYSQL_SCHEMA_QUERY = `
|
|
8
|
+
SELECT
|
|
9
|
+
TABLE_NAME,
|
|
10
|
+
COLUMN_NAME,
|
|
11
|
+
DATA_TYPE,
|
|
12
|
+
IS_NULLABLE,
|
|
13
|
+
COLUMN_KEY,
|
|
14
|
+
COLUMN_DEFAULT,
|
|
15
|
+
EXTRA
|
|
16
|
+
FROM INFORMATION_SCHEMA.COLUMNS
|
|
17
|
+
WHERE TABLE_SCHEMA = DATABASE()
|
|
18
|
+
ORDER BY TABLE_NAME, ORDINAL_POSITION
|
|
19
|
+
`;
|
|
20
|
+
const PG_SCHEMA_QUERY = `
|
|
21
|
+
SELECT
|
|
22
|
+
c.table_name,
|
|
23
|
+
c.column_name,
|
|
24
|
+
c.data_type,
|
|
25
|
+
c.is_nullable,
|
|
26
|
+
CASE
|
|
27
|
+
WHEN tc.constraint_type = 'PRIMARY KEY' THEN 'PRI'
|
|
28
|
+
WHEN tc.constraint_type = 'UNIQUE' THEN 'UNI'
|
|
29
|
+
ELSE ''
|
|
30
|
+
END AS column_key,
|
|
31
|
+
c.column_default
|
|
32
|
+
FROM information_schema.columns c
|
|
33
|
+
LEFT JOIN information_schema.key_column_usage kcu
|
|
34
|
+
ON c.table_name = kcu.table_name
|
|
35
|
+
AND c.column_name = kcu.column_name
|
|
36
|
+
AND c.table_schema = kcu.table_schema
|
|
37
|
+
LEFT JOIN information_schema.table_constraints tc
|
|
38
|
+
ON kcu.constraint_name = tc.constraint_name
|
|
39
|
+
AND kcu.table_schema = tc.table_schema
|
|
40
|
+
WHERE c.table_schema = 'public'
|
|
41
|
+
ORDER BY c.table_name, c.ordinal_position
|
|
42
|
+
`;
|
|
43
|
+
/** get_db_schemas ツールを MCP サーバーに登録する */
|
|
44
|
+
function registerDbSchemasTool(server, apiClient) {
|
|
45
|
+
server.tool('get_db_schemas', 'Get the schema (tables and columns) of a project database.', {
|
|
46
|
+
name: zod_1.z.string().describe('Database connection name (e.g. "MAIN", "READONLY")'),
|
|
47
|
+
}, async ({ name }) => {
|
|
48
|
+
try {
|
|
49
|
+
const credentials = await apiClient.getDbCredentials(name);
|
|
50
|
+
const query = credentials.engine === 'mysql'
|
|
51
|
+
? MYSQL_SCHEMA_QUERY
|
|
52
|
+
: PG_SCHEMA_QUERY;
|
|
53
|
+
const rows = await (0, db_query_1.executeQuery)(credentials, query);
|
|
54
|
+
return (0, mcp_response_1.mcpTextResponse)(JSON.stringify(rows, null, 2));
|
|
55
|
+
}
|
|
56
|
+
catch (error) {
|
|
57
|
+
return (0, mcp_response_1.mcpErrorResponse)((0, mcp_response_1.extractErrorMessage)(error));
|
|
58
|
+
}
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
//# sourceMappingURL=db-schemas.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"db-schemas.js","sourceRoot":"","sources":["../../../src/mcp/tools/db-schemas.ts"],"names":[],"mappings":";;AA8CA,sDAuBC;AApED,6BAAuB;AAGvB,yCAAyC;AACzC,iDAAuF;AAEvF,MAAM,kBAAkB,GAAG;;;;;;;;;;;;CAY1B,CAAA;AAED,MAAM,eAAe,GAAG;;;;;;;;;;;;;;;;;;;;;;CAsBvB,CAAA;AAED,wCAAwC;AACxC,SAAgB,qBAAqB,CAAC,MAAiB,EAAE,SAAoB;IAC3E,MAAM,CAAC,IAAI,CACT,gBAAgB,EAChB,4DAA4D,EAC5D;QACE,IAAI,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,oDAAoD,CAAC;KAChF,EACD,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE;QACjB,IAAI,CAAC;YACH,MAAM,WAAW,GAAG,MAAM,SAAS,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAA;YAE1D,MAAM,KAAK,GAAG,WAAW,CAAC,MAAM,KAAK,OAAO;gBAC1C,CAAC,CAAC,kBAAkB;gBACpB,CAAC,CAAC,eAAe,CAAA;YAEnB,MAAM,IAAI,GAAG,MAAM,IAAA,uBAAY,EAAC,WAAW,EAAE,KAAK,CAAC,CAAA;YAEnD,OAAO,IAAA,8BAAe,EAAC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAA;QACvD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,IAAA,+BAAgB,EAAC,IAAA,kCAAmB,EAAC,KAAK,CAAC,CAAC,CAAA;QACrD,CAAC;IACH,CAAC,CACF,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export declare function mcpTextResponse(text: string): {
|
|
2
|
+
content: {
|
|
3
|
+
type: "text";
|
|
4
|
+
text: string;
|
|
5
|
+
}[];
|
|
6
|
+
};
|
|
7
|
+
export declare function mcpErrorResponse(message: string): {
|
|
8
|
+
content: {
|
|
9
|
+
type: "text";
|
|
10
|
+
text: string;
|
|
11
|
+
}[];
|
|
12
|
+
isError: true;
|
|
13
|
+
};
|
|
14
|
+
export declare function extractErrorMessage(error: unknown): string;
|
|
15
|
+
//# sourceMappingURL=mcp-response.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mcp-response.d.ts","sourceRoot":"","sources":["../../../src/mcp/tools/mcp-response.ts"],"names":[],"mappings":"AAAA,wBAAgB,eAAe,CAAC,IAAI,EAAE,MAAM;;;;;EAE3C;AAED,wBAAgB,gBAAgB,CAAC,OAAO,EAAE,MAAM;;;;;;EAE/C;AAED,wBAAgB,mBAAmB,CAAC,KAAK,EAAE,OAAO,GAAG,MAAM,CAE1D"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.mcpTextResponse = mcpTextResponse;
|
|
4
|
+
exports.mcpErrorResponse = mcpErrorResponse;
|
|
5
|
+
exports.extractErrorMessage = extractErrorMessage;
|
|
6
|
+
function mcpTextResponse(text) {
|
|
7
|
+
return { content: [{ type: 'text', text }] };
|
|
8
|
+
}
|
|
9
|
+
function mcpErrorResponse(message) {
|
|
10
|
+
return { content: [{ type: 'text', text: `Error: ${message}` }], isError: true };
|
|
11
|
+
}
|
|
12
|
+
function extractErrorMessage(error) {
|
|
13
|
+
return error instanceof Error ? error.message : String(error);
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=mcp-response.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mcp-response.js","sourceRoot":"","sources":["../../../src/mcp/tools/mcp-response.ts"],"names":[],"mappings":";;AAAA,0CAEC;AAED,4CAEC;AAED,kDAEC;AAVD,SAAgB,eAAe,CAAC,IAAY;IAC1C,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAe,EAAE,IAAI,EAAE,CAAC,EAAE,CAAA;AACvD,CAAC;AAED,SAAgB,gBAAgB,CAAC,OAAe;IAC9C,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAe,EAAE,IAAI,EAAE,UAAU,OAAO,EAAE,EAAE,CAAC,EAAE,OAAO,EAAE,IAAa,EAAE,CAAA;AACpG,CAAC;AAED,SAAgB,mBAAmB,CAAC,KAAc;IAChD,OAAO,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;AAC/D,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';
|
|
2
|
+
import { ApiClient } from '../../api-client';
|
|
3
|
+
/** get_project_info ツールを MCP サーバーに登録する */
|
|
4
|
+
export declare function registerProjectInfoTool(server: McpServer, apiClient: ApiClient, projectCode: string): void;
|
|
5
|
+
//# sourceMappingURL=project-info.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"project-info.d.ts","sourceRoot":"","sources":["../../../src/mcp/tools/project-info.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAA;AAEnE,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAA;AAG5C,0CAA0C;AAC1C,wBAAgB,uBAAuB,CACrC,MAAM,EAAE,SAAS,EACjB,SAAS,EAAE,SAAS,EACpB,WAAW,EAAE,MAAM,GAClB,IAAI,CA8CN"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.registerProjectInfoTool = registerProjectInfoTool;
|
|
4
|
+
const mcp_response_1 = require("./mcp-response");
|
|
5
|
+
/** get_project_info ツールを MCP サーバーに登録する */
|
|
6
|
+
function registerProjectInfoTool(server, apiClient, projectCode) {
|
|
7
|
+
server.tool('get_project_info', 'Get project configuration information including databases, AWS accounts, and documentation sources.', {}, async () => {
|
|
8
|
+
try {
|
|
9
|
+
const config = await apiClient.getProjectConfig();
|
|
10
|
+
const info = {
|
|
11
|
+
project: config.project,
|
|
12
|
+
};
|
|
13
|
+
if (config.databases?.length) {
|
|
14
|
+
info.databases = config.databases.map((db) => ({
|
|
15
|
+
name: db.name,
|
|
16
|
+
engine: db.engine,
|
|
17
|
+
host: db.host,
|
|
18
|
+
port: db.port,
|
|
19
|
+
database: db.database,
|
|
20
|
+
writePermissions: db.writePermissions,
|
|
21
|
+
}));
|
|
22
|
+
}
|
|
23
|
+
if (config.aws?.accounts?.length) {
|
|
24
|
+
info.awsAccounts = config.aws.accounts.map((acc) => ({
|
|
25
|
+
id: acc.id,
|
|
26
|
+
name: acc.name,
|
|
27
|
+
region: acc.region,
|
|
28
|
+
accountId: acc.accountId,
|
|
29
|
+
isDefault: acc.isDefault,
|
|
30
|
+
}));
|
|
31
|
+
}
|
|
32
|
+
if (config.documentation?.sources?.length) {
|
|
33
|
+
info.documentation = config.documentation;
|
|
34
|
+
}
|
|
35
|
+
info.projectCode = projectCode;
|
|
36
|
+
return (0, mcp_response_1.mcpTextResponse)(JSON.stringify(info, null, 2));
|
|
37
|
+
}
|
|
38
|
+
catch (error) {
|
|
39
|
+
return (0, mcp_response_1.mcpErrorResponse)((0, mcp_response_1.extractErrorMessage)(error));
|
|
40
|
+
}
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=project-info.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"project-info.js","sourceRoot":"","sources":["../../../src/mcp/tools/project-info.ts"],"names":[],"mappings":";;AAMA,0DAkDC;AArDD,iDAAuF;AAEvF,0CAA0C;AAC1C,SAAgB,uBAAuB,CACrC,MAAiB,EACjB,SAAoB,EACpB,WAAmB;IAEnB,MAAM,CAAC,IAAI,CACT,kBAAkB,EAClB,qGAAqG,EACrG,EAAE,EACF,KAAK,IAAI,EAAE;QACT,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC,gBAAgB,EAAE,CAAA;YAEjD,MAAM,IAAI,GAA4B;gBACpC,OAAO,EAAE,MAAM,CAAC,OAAO;aACxB,CAAA;YAED,IAAI,MAAM,CAAC,SAAS,EAAE,MAAM,EAAE,CAAC;gBAC7B,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;oBAC7C,IAAI,EAAE,EAAE,CAAC,IAAI;oBACb,MAAM,EAAE,EAAE,CAAC,MAAM;oBACjB,IAAI,EAAE,EAAE,CAAC,IAAI;oBACb,IAAI,EAAE,EAAE,CAAC,IAAI;oBACb,QAAQ,EAAE,EAAE,CAAC,QAAQ;oBACrB,gBAAgB,EAAE,EAAE,CAAC,gBAAgB;iBACtC,CAAC,CAAC,CAAA;YACL,CAAC;YAED,IAAI,MAAM,CAAC,GAAG,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC;gBACjC,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;oBACnD,EAAE,EAAE,GAAG,CAAC,EAAE;oBACV,IAAI,EAAE,GAAG,CAAC,IAAI;oBACd,MAAM,EAAE,GAAG,CAAC,MAAM;oBAClB,SAAS,EAAE,GAAG,CAAC,SAAS;oBACxB,SAAS,EAAE,GAAG,CAAC,SAAS;iBACzB,CAAC,CAAC,CAAA;YACL,CAAC;YAED,IAAI,MAAM,CAAC,aAAa,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC;gBAC1C,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,aAAa,CAAA;YAC3C,CAAC;YAED,IAAI,CAAC,WAAW,GAAG,WAAW,CAAA;YAE9B,OAAO,IAAA,8BAAe,EAAC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAA;QACvD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,IAAA,+BAAgB,EAAC,IAAA,kCAAmB,EAAC,KAAK,CAAC,CAAC,CAAA;QACrD,CAAC;IACH,CAAC,CACF,CAAA;AACH,CAAC"}
|
package/dist/project-agent.d.ts
CHANGED
|
@@ -22,6 +22,10 @@ export declare class ProjectAgent {
|
|
|
22
22
|
private currentConfigHash;
|
|
23
23
|
private configSyncDebounceTimer;
|
|
24
24
|
private projectConfig;
|
|
25
|
+
private mcpConfigPath;
|
|
26
|
+
private readonly apiUrl;
|
|
27
|
+
private readonly token;
|
|
28
|
+
private readonly projectCode;
|
|
25
29
|
constructor(project: ProjectRegistration, agentId: string, options: ProjectAgentOptions, tenantCode?: string, localAgentChatMode?: AgentChatMode, defaultProjectDir?: string);
|
|
26
30
|
start(): void;
|
|
27
31
|
stop(): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"project-agent.d.ts","sourceRoot":"","sources":["../src/project-agent.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"project-agent.d.ts","sourceRoot":"","sources":["../src/project-agent.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAA;AAYxC,OAAO,KAAK,EAAE,aAAa,EAA4C,mBAAmB,EAAoB,MAAM,SAAS,CAAA;AAG7H,MAAM,WAAW,mBAAmB;IAClC,YAAY,EAAE,MAAM,CAAA;IACpB,iBAAiB,EAAE,MAAM,CAAA;CAC1B;AAED,qBAAa,YAAY;IAuBrB,OAAO,CAAC,QAAQ,CAAC,OAAO;IACxB,OAAO,CAAC,QAAQ,CAAC,OAAO;IAvB1B,OAAO,CAAC,cAAc,CAA8C;IACpE,OAAO,CAAC,SAAS,CAA8C;IAC/D,OAAO,CAAC,UAAU,CAAiC;IACnD,OAAO,CAAC,UAAU,CAAQ;IAC1B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAW;IAClC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAQ;IAC/B,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAQ;IACnC,OAAO,CAAC,YAAY,CAAiC;IACrD,OAAO,CAAC,kBAAkB,CAAsB;IAChD,OAAO,CAAC,cAAc,CAAuC;IAC7D,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAA2B;IAC9D,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAoB;IAC/C,OAAO,CAAC,iBAAiB,CAAgC;IACzD,OAAO,CAAC,uBAAuB,CAA6C;IAC5E,OAAO,CAAC,aAAa,CAA+C;IACpE,OAAO,CAAC,aAAa,CAAgC;IACrD,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAQ;IAC/B,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAQ;IAC9B,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAQ;gBAGlC,OAAO,EAAE,mBAAmB,EACX,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,mBAAmB,EAC7C,UAAU,CAAC,EAAE,MAAM,EACnB,kBAAkB,CAAC,EAAE,aAAa,EAClC,iBAAiB,CAAC,EAAE,MAAM;IAa5B,KAAK,IAAI,IAAI;IAMb,IAAI,IAAI,IAAI;IAOZ,SAAS,IAAI,SAAS;YAIR,gBAAgB;YA8ChB,qBAAqB;IAuBnC,OAAO,CAAC,gBAAgB;IA2BxB,OAAO,CAAC,cAAc;YAoCR,kBAAkB;YA2BlB,kBAAkB;IAQhC,OAAO,CAAC,kBAAkB;IASpB,iBAAiB,IAAI,OAAO,CAAC,IAAI,CAAC;IAYlC,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC;IAenC,OAAO,CAAC,kBAAkB;YAoDZ,cAAc;YAwCd,eAAe;YA8Bf,oBAAoB;CAkBnC"}
|