@o3r/mcp 13.2.0-rc.1 → 13.3.0-prerelease.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +10 -9
- package/src/cli/index.js +2 -2
- package/src/cli/index.js.map +1 -1
- package/src/mcp-server.d.ts.map +1 -1
- package/src/mcp-server.js +2 -0
- package/src/mcp-server.js.map +1 -1
- package/src/tools/find-repositories-using-otter.d.ts +7 -0
- package/src/tools/find-repositories-using-otter.d.ts.map +1 -0
- package/src/tools/find-repositories-using-otter.js +169 -0
- package/src/tools/find-repositories-using-otter.js.map +1 -0
- package/src/utils/logger.d.ts +10 -0
- package/src/utils/logger.d.ts.map +1 -0
- package/src/utils/logger.js +24 -0
- package/src/utils/logger.js.map +1 -0
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@o3r/mcp",
|
|
3
|
-
"version": "13.
|
|
3
|
+
"version": "13.3.0-prerelease.2",
|
|
4
4
|
"publishConfig": {
|
|
5
5
|
"access": "public"
|
|
6
6
|
},
|
|
@@ -23,6 +23,7 @@
|
|
|
23
23
|
},
|
|
24
24
|
"dependencies": {
|
|
25
25
|
"@modelcontextprotocol/sdk": "~1.19.0",
|
|
26
|
+
"@octokit/rest": "^22.0.0",
|
|
26
27
|
"tslib": "^2.6.2",
|
|
27
28
|
"zod": "~3.25.76"
|
|
28
29
|
},
|
|
@@ -38,17 +39,17 @@
|
|
|
38
39
|
"@nx/eslint-plugin": "~21.6.0",
|
|
39
40
|
"@nx/jest": "~21.6.0",
|
|
40
41
|
"@nx/js": "~21.6.0",
|
|
41
|
-
"@o3r/build-helpers": "^13.
|
|
42
|
-
"@o3r/eslint-config": "^13.
|
|
43
|
-
"@o3r/eslint-plugin": "^13.
|
|
44
|
-
"@o3r/test-helpers": "^13.
|
|
45
|
-
"@stylistic/eslint-plugin": "~5.
|
|
42
|
+
"@o3r/build-helpers": "^13.3.0-prerelease.2",
|
|
43
|
+
"@o3r/eslint-config": "^13.3.0-prerelease.2",
|
|
44
|
+
"@o3r/eslint-plugin": "^13.3.0-prerelease.2",
|
|
45
|
+
"@o3r/test-helpers": "^13.3.0-prerelease.2",
|
|
46
|
+
"@stylistic/eslint-plugin": "~5.4.0",
|
|
46
47
|
"@types/jest": "~29.5.2",
|
|
47
48
|
"@types/node": "~22.18.0",
|
|
48
|
-
"@typescript-eslint/parser": "~8.
|
|
49
|
+
"@typescript-eslint/parser": "~8.45.0",
|
|
49
50
|
"angular-eslint": "~20.3.0",
|
|
50
51
|
"cpy-cli": "^6.0.0",
|
|
51
|
-
"eslint": "~9.
|
|
52
|
+
"eslint": "~9.37.0",
|
|
52
53
|
"eslint-import-resolver-node": "~0.3.9",
|
|
53
54
|
"eslint-import-resolver-typescript": "~4.4.0",
|
|
54
55
|
"eslint-plugin-import": "~2.32.0",
|
|
@@ -71,7 +72,7 @@
|
|
|
71
72
|
"ts-node": "~10.9.2",
|
|
72
73
|
"type-fest": "^4.30.1",
|
|
73
74
|
"typescript": "~5.9.2",
|
|
74
|
-
"typescript-eslint": "~8.
|
|
75
|
+
"typescript-eslint": "~8.45.0",
|
|
75
76
|
"zone.js": "~0.15.0"
|
|
76
77
|
},
|
|
77
78
|
"engines": {
|
package/src/cli/index.js
CHANGED
|
@@ -3,12 +3,12 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
4
|
const stdio_js_1 = require("@modelcontextprotocol/sdk/server/stdio.js");
|
|
5
5
|
const mcp_server_1 = require("../mcp-server");
|
|
6
|
+
const logger_1 = require("../utils/logger");
|
|
6
7
|
async function startMcpServer() {
|
|
7
8
|
const server = await (0, mcp_server_1.createMcpServer)();
|
|
8
9
|
const transport = new stdio_js_1.StdioServerTransport();
|
|
9
10
|
await server.connect(transport);
|
|
10
|
-
|
|
11
|
-
console.error('Server connected...');
|
|
11
|
+
logger_1.logger.info('Server connected...');
|
|
12
12
|
}
|
|
13
13
|
void startMcpServer();
|
|
14
14
|
//# sourceMappingURL=index.js.map
|
package/src/cli/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/cli/index.ts"],"names":[],"mappings":";;;AACA,wEAEmD;AACnD,8CAEuB;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/cli/index.ts"],"names":[],"mappings":";;;AACA,wEAEmD;AACnD,8CAEuB;AACvB,4CAEyB;AAEzB,KAAK,UAAU,cAAc;IAC3B,MAAM,MAAM,GAAG,MAAM,IAAA,4BAAe,GAAE,CAAC;IACvC,MAAM,SAAS,GAAG,IAAI,+BAAoB,EAAE,CAAC;IAC7C,MAAM,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IAChC,eAAM,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;AACrC,CAAC;AAED,KAAK,cAAc,EAAE,CAAC"}
|
package/src/mcp-server.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mcp-server.d.ts","sourceRoot":"","sources":["../../src/mcp-server.ts"],"names":[],"mappings":"AAMA,OAAO,EACL,SAAS,EACV,MAAM,yCAAyC,CAAC;
|
|
1
|
+
{"version":3,"file":"mcp-server.d.ts","sourceRoot":"","sources":["../../src/mcp-server.ts"],"names":[],"mappings":"AAMA,OAAO,EACL,SAAS,EACV,MAAM,yCAAyC,CAAC;AAcjD;;GAEG;AACH,wBAAsB,eAAe,IAAI,OAAO,CAAC,SAAS,CAAC,CAiB1D"}
|
package/src/mcp-server.js
CHANGED
|
@@ -7,6 +7,7 @@ const mcp_js_1 = require("@modelcontextprotocol/sdk/server/mcp.js");
|
|
|
7
7
|
const best_practices_1 = require("./instructions/best-practices");
|
|
8
8
|
const best_practices_2 = require("./tools/best-practices");
|
|
9
9
|
const create_monorepo_with_app_1 = require("./tools/create-monorepo-with-app");
|
|
10
|
+
const find_repositories_using_otter_1 = require("./tools/find-repositories-using-otter");
|
|
10
11
|
/**
|
|
11
12
|
* Create an MCP server instance.
|
|
12
13
|
*/
|
|
@@ -24,6 +25,7 @@ async function createMcpServer() {
|
|
|
24
25
|
await (0, best_practices_1.registerBestPracticesResources)(server, resourcesPath);
|
|
25
26
|
await (0, best_practices_2.registerBestPracticesTool)(server, resourcesPath);
|
|
26
27
|
await (0, create_monorepo_with_app_1.registerCreateMonorepoWithAppTool)(server, resourcesPath);
|
|
28
|
+
(0, find_repositories_using_otter_1.registerGetRepositoriesUsingOtterTool)(server);
|
|
27
29
|
return server;
|
|
28
30
|
}
|
|
29
31
|
//# sourceMappingURL=mcp-server.js.map
|
package/src/mcp-server.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mcp-server.js","sourceRoot":"","sources":["../../src/mcp-server.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"mcp-server.js","sourceRoot":"","sources":["../../src/mcp-server.ts"],"names":[],"mappings":";;AAyBA,0CAiBC;AA1CD,+CAE0B;AAC1B,yCAEmB;AACnB,oEAEiD;AACjD,kEAEuC;AACvC,2DAEgC;AAChC,+EAE0C;AAC1C,yFAE+C;AAE/C;;GAEG;AACI,KAAK,UAAU,eAAe;IACnC,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,IAAA,mBAAQ,EAAC,IAAA,gBAAI,EAAC,SAAS,EAAE,IAAI,EAAE,cAAc,CAAC,EAAE,MAAM,CAAC,CAAsC,CAAC;IACzI,MAAM,MAAM,GAAG,IAAI,kBAAS,CAAC;QAC3B,IAAI;QACJ,OAAO;QACP,YAAY,EAAE;YACZ,SAAS,EAAE,EAAE;YACb,KAAK,EAAE,EAAE;SACV;KACF,CAAC,CAAC;IACH,MAAM,aAAa,GAAG,IAAA,gBAAI,EAAC,SAAS,EAAE,IAAI,EAAE,WAAW,CAAC,CAAC;IAEzD,MAAM,IAAA,+CAA8B,EAAC,MAAM,EAAE,aAAa,CAAC,CAAC;IAC5D,MAAM,IAAA,0CAAyB,EAAC,MAAM,EAAE,aAAa,CAAC,CAAC;IACvD,MAAM,IAAA,4DAAiC,EAAC,MAAM,EAAE,aAAa,CAAC,CAAC;IAC/D,IAAA,qEAAqC,EAAC,MAAM,CAAC,CAAC;IAC9C,OAAO,MAAM,CAAC;AAChB,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';
|
|
2
|
+
/**
|
|
3
|
+
* Register the get repositories using otter tool.
|
|
4
|
+
* @param server
|
|
5
|
+
*/
|
|
6
|
+
export declare function registerGetRepositoriesUsingOtterTool(server: McpServer): void;
|
|
7
|
+
//# sourceMappingURL=find-repositories-using-otter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"find-repositories-using-otter.d.ts","sourceRoot":"","sources":["../../../src/tools/find-repositories-using-otter.ts"],"names":[],"mappings":"AAWA,OAAO,KAAK,EACV,SAAS,EACV,MAAM,yCAAyC,CAAC;AAgIjD;;;GAGG;AACH,wBAAgB,qCAAqC,CAAC,MAAM,EAAE,SAAS,QA0CtE"}
|
|
@@ -0,0 +1,169 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.registerGetRepositoriesUsingOtterTool = registerGetRepositoriesUsingOtterTool;
|
|
4
|
+
const node_fs_1 = require("node:fs");
|
|
5
|
+
const promises_1 = require("node:fs/promises");
|
|
6
|
+
const node_path_1 = require("node:path");
|
|
7
|
+
const rest_1 = require("@octokit/rest");
|
|
8
|
+
const logger_1 = require("../utils/logger");
|
|
9
|
+
async function listOrgRepos(octokit) {
|
|
10
|
+
const repos = (await octokit.paginate(octokit.repos.listForOrg, {
|
|
11
|
+
org: process.env.O3R_MCP_GITHUB_ORG,
|
|
12
|
+
per_page: 100,
|
|
13
|
+
type: 'all',
|
|
14
|
+
sort: 'updated' // Prioritize recently updated repositories
|
|
15
|
+
})).filter((repo) => !repo.archived && !repo.fork);
|
|
16
|
+
logger_1.logger.info(`Found ${repos.length} repositories in the organization ${process.env.O3R_MCP_GITHUB_ORG}`);
|
|
17
|
+
return repos;
|
|
18
|
+
}
|
|
19
|
+
function findPackageJsonFiles(octokit) {
|
|
20
|
+
return async (repository) => {
|
|
21
|
+
const owner = process.env.O3R_MCP_GITHUB_ORG;
|
|
22
|
+
const repo = repository.name;
|
|
23
|
+
const { data: { commit: { sha } } } = await octokit.repos.getBranch({
|
|
24
|
+
owner,
|
|
25
|
+
repo,
|
|
26
|
+
branch: repository.default_branch || 'main'
|
|
27
|
+
});
|
|
28
|
+
const { data: { tree } } = await octokit.git.getTree({
|
|
29
|
+
owner,
|
|
30
|
+
repo,
|
|
31
|
+
tree_sha: sha
|
|
32
|
+
});
|
|
33
|
+
return tree.filter((t) => t.type === 'blob' && t.path.endsWith('package.json'));
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
const O3R_SCOPE_REGEX = /^@(o3r|ama-styling|ama-mfe|ama-sdk)\//gm;
|
|
37
|
+
function dependsOnOtter(octokit) {
|
|
38
|
+
return async (repository, packageJsonPath) => {
|
|
39
|
+
const owner = process.env.O3R_MCP_GITHUB_ORG;
|
|
40
|
+
const repo = repository.name;
|
|
41
|
+
const { data } = await octokit.repos.getContent({
|
|
42
|
+
owner,
|
|
43
|
+
repo,
|
|
44
|
+
path: packageJsonPath
|
|
45
|
+
});
|
|
46
|
+
if (Array.isArray(data) || data.type !== 'file') {
|
|
47
|
+
throw new Error('Unexpected content response structure');
|
|
48
|
+
}
|
|
49
|
+
const content = Buffer.from(data.content, 'base64').toString('utf8');
|
|
50
|
+
const packageJson = JSON.parse(content);
|
|
51
|
+
return [
|
|
52
|
+
...Object.keys(packageJson.devDependencies || {}),
|
|
53
|
+
...Object.keys(packageJson.dependencies || {})
|
|
54
|
+
].some((dep) => O3R_SCOPE_REGEX.test(dep));
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
async function findRepositoriesUsingOtter(octokit, reposUsingOtter) {
|
|
58
|
+
const cacheFolderPath = process.env.O3R_MCP_CACHE_PATH || '.cache/o3r/mcp';
|
|
59
|
+
const cachePath = (0, node_path_1.resolve)(cacheFolderPath, 'repos-using-otter.json');
|
|
60
|
+
let cachedRepos = {};
|
|
61
|
+
if (process.env.O3R_MCP_USE_CACHED_REPOS === 'false') {
|
|
62
|
+
logger_1.logger.info('Ignoring cached repositories as O3R_MCP_USE_CACHED_REPOS is set to false');
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
try {
|
|
66
|
+
cachedRepos = JSON.parse(await (0, promises_1.readFile)(cachePath, { encoding: 'utf8' }));
|
|
67
|
+
reposUsingOtter.push(...Object.entries(cachedRepos).filter(([, usesOtter]) => usesOtter).map(([repo]) => repo));
|
|
68
|
+
logger_1.logger.info(`Loaded ${Object.keys(cachedRepos).length} cached repositories, ${reposUsingOtter.length} of them using Otter dependencies.`);
|
|
69
|
+
}
|
|
70
|
+
catch (e) {
|
|
71
|
+
logger_1.logger.info('No cache file found, starting fresh search for repositories using Otter dependencies.', e);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
const repositories = (await listOrgRepos(octokit)).filter((r) => !cachedRepos[r.full_name]);
|
|
75
|
+
const findPackageJsonFilesInRepo = findPackageJsonFiles(octokit);
|
|
76
|
+
const dependsOnOtterInRepo = dependsOnOtter(octokit);
|
|
77
|
+
await Promise.allSettled(repositories.map(async (repository) => {
|
|
78
|
+
logger_1.logger.debug(`Checking repository ${repository.full_name}...`);
|
|
79
|
+
const packageJsonFiles = [];
|
|
80
|
+
try {
|
|
81
|
+
packageJsonFiles.push(...await findPackageJsonFilesInRepo(repository));
|
|
82
|
+
}
|
|
83
|
+
catch (e) {
|
|
84
|
+
logger_1.logger.warn(`Failed to list package.json files in repository ${repository.full_name}`, e);
|
|
85
|
+
}
|
|
86
|
+
if (packageJsonFiles.length === 0) {
|
|
87
|
+
logger_1.logger.info(`No package.json files found in repository ${repository.full_name}`);
|
|
88
|
+
cachedRepos[repository.full_name] = false;
|
|
89
|
+
return;
|
|
90
|
+
}
|
|
91
|
+
try {
|
|
92
|
+
await Promise.any(packageJsonFiles.map(async (packageJsonFile) => {
|
|
93
|
+
let depFound = false;
|
|
94
|
+
try {
|
|
95
|
+
depFound = await dependsOnOtterInRepo(repository, packageJsonFile.path);
|
|
96
|
+
}
|
|
97
|
+
catch (e) {
|
|
98
|
+
logger_1.logger.error(`Failed to check package.json file at ${packageJsonFile.path} in repository ${repository.full_name}`, e);
|
|
99
|
+
}
|
|
100
|
+
if (depFound) {
|
|
101
|
+
reposUsingOtter.push(repository.full_name);
|
|
102
|
+
logger_1.logger.info(`Repository ${repository.full_name} uses Otter dependencies`);
|
|
103
|
+
cachedRepos[repository.full_name] = true;
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
throw new Error('No Otter dependencies found in this package.json');
|
|
107
|
+
}
|
|
108
|
+
}));
|
|
109
|
+
}
|
|
110
|
+
catch { }
|
|
111
|
+
cachedRepos[repository.full_name] ||= false;
|
|
112
|
+
}));
|
|
113
|
+
logger_1.logger.info(`Found ${reposUsingOtter.length} repositories using Otter dependencies in the organization ${process.env.O3R_MCP_GITHUB_ORG}`);
|
|
114
|
+
if (process.env.O3R_MCP_USE_CACHED_REPOS === 'false') {
|
|
115
|
+
logger_1.logger.info('Not updating cache as O3R_MCP_USE_CACHED_REPOS is set to false');
|
|
116
|
+
}
|
|
117
|
+
else {
|
|
118
|
+
if (!(0, node_fs_1.existsSync)(cacheFolderPath)) {
|
|
119
|
+
await (0, promises_1.mkdir)(cacheFolderPath, { recursive: true });
|
|
120
|
+
}
|
|
121
|
+
try {
|
|
122
|
+
await (0, promises_1.writeFile)(cachePath, JSON.stringify(cachedRepos, Object.keys(cachedRepos).sort()));
|
|
123
|
+
}
|
|
124
|
+
catch (e) {
|
|
125
|
+
logger_1.logger.error('Failed to update cache', e);
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* Register the get repositories using otter tool.
|
|
131
|
+
* @param server
|
|
132
|
+
*/
|
|
133
|
+
function registerGetRepositoriesUsingOtterTool(server) {
|
|
134
|
+
if (!process.env.O3R_MCP_GITHUB_TOKEN) {
|
|
135
|
+
logger_1.logger.error('Missing O3R_MCP_GITHUB_TOKEN environment variable for search_code_example tool');
|
|
136
|
+
return;
|
|
137
|
+
}
|
|
138
|
+
if (!process.env.O3R_MCP_GITHUB_ORG) {
|
|
139
|
+
logger_1.logger.error('Missing O3R_MCP_GITHUB_ORG environment variable');
|
|
140
|
+
return;
|
|
141
|
+
}
|
|
142
|
+
const octokit = new rest_1.Octokit({ auth: process.env.O3R_MCP_GITHUB_TOKEN });
|
|
143
|
+
let isLookingForRepos = true;
|
|
144
|
+
const reposUsingOtter = [];
|
|
145
|
+
findRepositoriesUsingOtter(octokit, reposUsingOtter).catch((e) => {
|
|
146
|
+
logger_1.logger.error('Error finding repositories using Otter:', e);
|
|
147
|
+
});
|
|
148
|
+
isLookingForRepos = false;
|
|
149
|
+
server.registerTool('get_repositories_using_otter', {
|
|
150
|
+
title: 'Get repositories using Otter dependencies',
|
|
151
|
+
description: 'List all repositories in the specified GitHub organization that use Otter dependencies (@o3r/* or @ama-*/*) in their package.json files.',
|
|
152
|
+
annotations: {
|
|
153
|
+
readOnlyHint: true,
|
|
154
|
+
openWorldHint: false
|
|
155
|
+
}
|
|
156
|
+
}, () => ({
|
|
157
|
+
content: [
|
|
158
|
+
{
|
|
159
|
+
type: 'text',
|
|
160
|
+
text: (isLookingForRepos ? 'I did not finish to look for repositories. For the moment:\n' : '')
|
|
161
|
+
+ reposUsingOtter.length
|
|
162
|
+
? `The following repositories in the organization ${process.env.O3R_MCP_GITHUB_ORG} use Otter dependencies:\n`
|
|
163
|
+
+ reposUsingOtter.sort().map((repo) => `- ${repo}`).join('\n')
|
|
164
|
+
: `No repositories in the organization ${process.env.O3R_MCP_GITHUB_ORG} were found to use Otter dependencies.`
|
|
165
|
+
}
|
|
166
|
+
]
|
|
167
|
+
}));
|
|
168
|
+
}
|
|
169
|
+
//# sourceMappingURL=find-repositories-using-otter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"find-repositories-using-otter.js","sourceRoot":"","sources":["../../../src/tools/find-repositories-using-otter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Logger for MCP server
|
|
3
|
+
*/
|
|
4
|
+
export declare const logger: {
|
|
5
|
+
error: (m: string, meta?: any) => boolean;
|
|
6
|
+
warn: (m: string, meta?: any) => boolean;
|
|
7
|
+
info: (m: string, meta?: any) => boolean;
|
|
8
|
+
debug: (m: string, meta?: any) => boolean;
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=logger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../../src/utils/logger.ts"],"names":[],"mappings":"AAgBA;;GAEG;AACH,eAAO,MAAM,MAAM;eACN,MAAM,SAAS,GAAG;cACnB,MAAM,SAAS,GAAG;cAClB,MAAM,SAAS,GAAG;eACjB,MAAM,SAAS,GAAG;CAC9B,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.logger = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* Logging as error as recommended by modelcontextprotocol.io (https://modelcontextprotocol.io/quickstart/server#quick-examples-2)
|
|
6
|
+
* @param level
|
|
7
|
+
* @param message
|
|
8
|
+
* @param meta Should be stringifyable
|
|
9
|
+
*/
|
|
10
|
+
const log = (level, message, meta) => process.stderr.write(JSON.stringify({
|
|
11
|
+
level,
|
|
12
|
+
message,
|
|
13
|
+
meta
|
|
14
|
+
}) + '\n');
|
|
15
|
+
/**
|
|
16
|
+
* Logger for MCP server
|
|
17
|
+
*/
|
|
18
|
+
exports.logger = {
|
|
19
|
+
error: (m, meta) => log('error', m, meta),
|
|
20
|
+
warn: (m, meta) => log('warn', m, meta),
|
|
21
|
+
info: (m, meta) => log('info', m, meta),
|
|
22
|
+
debug: (m, meta) => log('debug', m, meta)
|
|
23
|
+
};
|
|
24
|
+
//# sourceMappingURL=logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../../src/utils/logger.ts"],"names":[],"mappings":";;;AAEA;;;;;GAKG;AACH,MAAM,GAAG,GAAG,CAAC,KAAY,EAAE,OAAe,EAAE,IAAS,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAC5E,IAAI,CAAC,SAAS,CAAC;IACb,KAAK;IACL,OAAO;IACP,IAAI;CACL,CAAC,GAAG,IAAI,CACV,CAAC;AAEF;;GAEG;AACU,QAAA,MAAM,GAAG;IACpB,KAAK,EAAE,CAAC,CAAS,EAAE,IAAU,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,EAAE,IAAI,CAAC;IACvD,IAAI,EAAE,CAAC,CAAS,EAAE,IAAU,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,EAAE,IAAI,CAAC;IACrD,IAAI,EAAE,CAAC,CAAS,EAAE,IAAU,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,EAAE,IAAI,CAAC;IACrD,KAAK,EAAE,CAAC,CAAS,EAAE,IAAU,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,EAAE,IAAI,CAAC;CACxD,CAAC"}
|