@manhq/localmcp 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (106) hide show
  1. package/README.md +239 -0
  2. package/README.vi.md +239 -0
  3. package/bin/localmcp.js +31 -0
  4. package/dist/cli.d.ts +2 -0
  5. package/dist/cli.d.ts.map +1 -0
  6. package/dist/cli.js +333 -0
  7. package/dist/cli.js.map +1 -0
  8. package/dist/index.d.ts +4 -0
  9. package/dist/index.d.ts.map +1 -0
  10. package/dist/index.js +102 -0
  11. package/dist/index.js.map +1 -0
  12. package/dist/services/atlassian/client.d.ts +4 -0
  13. package/dist/services/atlassian/client.d.ts.map +1 -0
  14. package/dist/services/atlassian/client.js +26 -0
  15. package/dist/services/atlassian/client.js.map +1 -0
  16. package/dist/services/atlassian/index.d.ts +3 -0
  17. package/dist/services/atlassian/index.d.ts.map +1 -0
  18. package/dist/services/atlassian/index.js +7 -0
  19. package/dist/services/atlassian/index.js.map +1 -0
  20. package/dist/services/atlassian/tools/confluence.d.ts +3 -0
  21. package/dist/services/atlassian/tools/confluence.d.ts.map +1 -0
  22. package/dist/services/atlassian/tools/confluence.js +222 -0
  23. package/dist/services/atlassian/tools/confluence.js.map +1 -0
  24. package/dist/services/atlassian/tools/jira.d.ts +3 -0
  25. package/dist/services/atlassian/tools/jira.d.ts.map +1 -0
  26. package/dist/services/atlassian/tools/jira.js +266 -0
  27. package/dist/services/atlassian/tools/jira.js.map +1 -0
  28. package/dist/services/atlassian/types.d.ts +74 -0
  29. package/dist/services/atlassian/types.d.ts.map +1 -0
  30. package/dist/services/atlassian/types.js +2 -0
  31. package/dist/services/atlassian/types.js.map +1 -0
  32. package/dist/services/figma/client.d.ts +3 -0
  33. package/dist/services/figma/client.d.ts.map +1 -0
  34. package/dist/services/figma/client.js +27 -0
  35. package/dist/services/figma/client.js.map +1 -0
  36. package/dist/services/figma/index.d.ts +3 -0
  37. package/dist/services/figma/index.d.ts.map +1 -0
  38. package/dist/services/figma/index.js +13 -0
  39. package/dist/services/figma/index.js.map +1 -0
  40. package/dist/services/figma/tools/comments.d.ts +3 -0
  41. package/dist/services/figma/tools/comments.d.ts.map +1 -0
  42. package/dist/services/figma/tools/comments.js +41 -0
  43. package/dist/services/figma/tools/comments.js.map +1 -0
  44. package/dist/services/figma/tools/components.d.ts +3 -0
  45. package/dist/services/figma/tools/components.d.ts.map +1 -0
  46. package/dist/services/figma/tools/components.js +101 -0
  47. package/dist/services/figma/tools/components.js.map +1 -0
  48. package/dist/services/figma/tools/files.d.ts +3 -0
  49. package/dist/services/figma/tools/files.d.ts.map +1 -0
  50. package/dist/services/figma/tools/files.js +86 -0
  51. package/dist/services/figma/tools/files.js.map +1 -0
  52. package/dist/services/figma/tools/images.d.ts +3 -0
  53. package/dist/services/figma/tools/images.d.ts.map +1 -0
  54. package/dist/services/figma/tools/images.js +67 -0
  55. package/dist/services/figma/tools/images.js.map +1 -0
  56. package/dist/services/figma/tools/variables.d.ts +3 -0
  57. package/dist/services/figma/tools/variables.d.ts.map +1 -0
  58. package/dist/services/figma/tools/variables.js +44 -0
  59. package/dist/services/figma/tools/variables.js.map +1 -0
  60. package/dist/services/figma/types.d.ts +65 -0
  61. package/dist/services/figma/types.d.ts.map +1 -0
  62. package/dist/services/figma/types.js +2 -0
  63. package/dist/services/figma/types.js.map +1 -0
  64. package/dist/services/google-chat/auth.d.ts +2 -0
  65. package/dist/services/google-chat/auth.d.ts.map +1 -0
  66. package/dist/services/google-chat/auth.js +18 -0
  67. package/dist/services/google-chat/auth.js.map +1 -0
  68. package/dist/services/google-chat/client.d.ts +3 -0
  69. package/dist/services/google-chat/client.d.ts.map +1 -0
  70. package/dist/services/google-chat/client.js +14 -0
  71. package/dist/services/google-chat/client.js.map +1 -0
  72. package/dist/services/google-chat/index.d.ts +3 -0
  73. package/dist/services/google-chat/index.d.ts.map +1 -0
  74. package/dist/services/google-chat/index.js +5 -0
  75. package/dist/services/google-chat/index.js.map +1 -0
  76. package/dist/services/google-chat/tools/messages.d.ts +3 -0
  77. package/dist/services/google-chat/tools/messages.d.ts.map +1 -0
  78. package/dist/services/google-chat/tools/messages.js +144 -0
  79. package/dist/services/google-chat/tools/messages.js.map +1 -0
  80. package/dist/services/google-chat/types.d.ts +31 -0
  81. package/dist/services/google-chat/types.d.ts.map +1 -0
  82. package/dist/services/google-chat/types.js +2 -0
  83. package/dist/services/google-chat/types.js.map +1 -0
  84. package/dist/shared/env.d.ts +18 -0
  85. package/dist/shared/env.d.ts.map +1 -0
  86. package/dist/shared/env.js +27 -0
  87. package/dist/shared/env.js.map +1 -0
  88. package/dist/shared/errors.d.ts +8 -0
  89. package/dist/shared/errors.d.ts.map +1 -0
  90. package/dist/shared/errors.js +38 -0
  91. package/dist/shared/errors.js.map +1 -0
  92. package/dist/shared/response.d.ts +7 -0
  93. package/dist/shared/response.d.ts.map +1 -0
  94. package/dist/shared/response.js +7 -0
  95. package/dist/shared/response.js.map +1 -0
  96. package/dist/shared/settings.d.ts +36 -0
  97. package/dist/shared/settings.d.ts.map +1 -0
  98. package/dist/shared/settings.js +104 -0
  99. package/dist/shared/settings.js.map +1 -0
  100. package/docs/atlassian.md +170 -0
  101. package/docs/figma.md +154 -0
  102. package/docs/google-chat.md +130 -0
  103. package/docs/vi/atlassian.md +170 -0
  104. package/docs/vi/figma.md +154 -0
  105. package/docs/vi/google-chat.md +130 -0
  106. package/package.json +53 -0
package/dist/cli.js ADDED
@@ -0,0 +1,333 @@
1
+ import { spawn } from "node:child_process";
2
+ import { existsSync, mkdirSync, readFileSync, writeFileSync } from "node:fs";
3
+ import { homedir } from "node:os";
4
+ import { dirname, join } from "node:path";
5
+ import { createInterface } from "node:readline/promises";
6
+ import { fileURLToPath } from "node:url";
7
+ import { ensureSettingsFile, getPort, getServiceStatuses, loadSettings, saveSettings, SERVICE_NAMES, SETTINGS_PATH, } from "./shared/settings.js";
8
+ const AGENTS = ["claude", "codex", "cursor", "vscode", "windsurf", "antigravity"];
9
+ const REGISTER_TARGETS = ["localmcp", ...SERVICE_NAMES];
10
+ export async function runCli(argv = process.argv.slice(2)) {
11
+ const [command, ...args] = argv;
12
+ switch (command) {
13
+ case undefined:
14
+ await import("./index.js").then(({ startServer }) => startServer());
15
+ return;
16
+ case "init":
17
+ handleInit();
18
+ return;
19
+ case "list":
20
+ handleList();
21
+ return;
22
+ case "config":
23
+ await handleConfig(args);
24
+ return;
25
+ case "register":
26
+ await handleRegister(args);
27
+ return;
28
+ case "inspect":
29
+ handleInspect(args);
30
+ return;
31
+ case "help":
32
+ case "--help":
33
+ case "-h":
34
+ printHelp();
35
+ return;
36
+ case "--version":
37
+ case "-v":
38
+ printVersion();
39
+ return;
40
+ default:
41
+ console.error(`Unknown command: ${command}`);
42
+ printHelp();
43
+ process.exitCode = 1;
44
+ }
45
+ }
46
+ if (process.argv[1] && fileURLToPath(import.meta.url) === process.argv[1]) {
47
+ runCli().catch((error) => {
48
+ console.error(error instanceof Error ? error.message : error);
49
+ process.exitCode = 1;
50
+ });
51
+ }
52
+ function handleInit() {
53
+ const created = ensureSettingsFile();
54
+ console.log(`${created ? "Created" : "Already exists"}: ${SETTINGS_PATH}`);
55
+ console.log("Next: localmcp config");
56
+ }
57
+ function handleList() {
58
+ const rows = getServiceStatuses().map((service) => ({
59
+ service: service.name,
60
+ status: service.enabled ? "enabled" : "missing config",
61
+ endpoint: service.endpoint,
62
+ missing: service.missing.join(", ") || "-",
63
+ }));
64
+ console.table(rows);
65
+ }
66
+ async function handleConfig(args) {
67
+ ensureSettingsFile();
68
+ const [serviceName, ...updates] = args;
69
+ if (!serviceName) {
70
+ openEditor(SETTINGS_PATH);
71
+ return;
72
+ }
73
+ if (!SERVICE_NAMES.includes(serviceName)) {
74
+ console.error(`Unknown service: ${serviceName}`);
75
+ console.error(`Available services: ${SERVICE_NAMES.join(", ")}`);
76
+ process.exitCode = 1;
77
+ return;
78
+ }
79
+ const service = serviceName;
80
+ if (updates.length > 0) {
81
+ updateServiceFromArgs(service, updates);
82
+ return;
83
+ }
84
+ await promptServiceConfig(service);
85
+ }
86
+ async function handleRegister(args) {
87
+ const agent = args[0]
88
+ ? validateChoice(args[0], AGENTS, "AI agent")
89
+ : await promptSelect("Select AI agent", AGENTS);
90
+ if (!agent)
91
+ return;
92
+ const serviceArg = getOption(args, "--service");
93
+ const targetName = serviceArg
94
+ ? validateChoice(serviceArg, REGISTER_TARGETS, "service")
95
+ : await promptSelect("Select service", REGISTER_TARGETS);
96
+ if (!targetName)
97
+ return;
98
+ const target = getRegistrationTarget(targetName);
99
+ const serverName = targetName;
100
+ if (agent === "claude") {
101
+ spawnAndInherit("claude", ["mcp", "add", "--transport", "http", serverName, target.url]);
102
+ return;
103
+ }
104
+ if (agent === "codex") {
105
+ spawnAndInherit("codex", ["mcp", "add", serverName, "--url", target.url]);
106
+ return;
107
+ }
108
+ registerJsonConfig(agent, serverName, target.url);
109
+ }
110
+ function handleInspect(_args) {
111
+ const target = getRegistrationTarget("localmcp");
112
+ const configPath = join(process.cwd(), ".localmcp-inspector.json");
113
+ writeFileSync(configPath, `${JSON.stringify({ mcpServers: { localmcp: { url: target.url } } }, null, 2)}\n`);
114
+ console.log(`Starting MCP Inspector for ${target.url}`);
115
+ console.log("If npx asks to install @modelcontextprotocol/inspector, approve it once.");
116
+ spawnAndInherit("npx", [
117
+ "@modelcontextprotocol/inspector",
118
+ "--config",
119
+ configPath,
120
+ "--server",
121
+ "localmcp",
122
+ ]);
123
+ }
124
+ function getRegistrationTarget(target) {
125
+ const port = getPort();
126
+ if (target === "localmcp")
127
+ return { url: `http://localhost:${port}/mcp` };
128
+ return { url: `http://localhost:${port}/mcp/${target}` };
129
+ }
130
+ function registerJsonConfig(agent, serverName, url) {
131
+ if (agent === "vscode") {
132
+ const path = join(process.cwd(), ".vscode", "mcp.json");
133
+ const config = readJson(path);
134
+ config.servers = { ...(config.servers ?? {}), [serverName]: { type: "http", url } };
135
+ writeJson(path, config);
136
+ console.log(`Registered ${serverName} in ${path}`);
137
+ return;
138
+ }
139
+ if (agent === "cursor") {
140
+ const path = join(process.cwd(), ".cursor", "mcp.json");
141
+ const config = readJson(path);
142
+ config.mcpServers = { ...(config.mcpServers ?? {}), [serverName]: { url } };
143
+ writeJson(path, config);
144
+ console.log(`Registered ${serverName} in ${path}`);
145
+ return;
146
+ }
147
+ const path = agent === "windsurf"
148
+ ? join(homedir(), ".codeium", "windsurf", "mcp_config.json")
149
+ : join(homedir(), ".gemini", "config", "mcp_config.json");
150
+ const config = readJson(path);
151
+ config.mcpServers = { ...(config.mcpServers ?? {}), [serverName]: { serverUrl: url } };
152
+ writeJson(path, config);
153
+ console.log(`Registered ${serverName} in ${path}`);
154
+ }
155
+ async function promptServiceConfig(service) {
156
+ const settings = loadSettings();
157
+ settings.services ??= {};
158
+ const rl = createInterface({ input: process.stdin, output: process.stdout });
159
+ try {
160
+ if (service === "figma") {
161
+ const current = settings.services.figma ?? {};
162
+ settings.services.figma = {
163
+ host: await ask(rl, "FIGMA_HOST", current.host ?? "https://api.figma.com/v1"),
164
+ token: await ask(rl, "FIGMA_TOKEN", current.token),
165
+ };
166
+ }
167
+ if (service === "atlassian") {
168
+ const current = settings.services.atlassian ?? {};
169
+ settings.services.atlassian = {
170
+ host: await ask(rl, "ATLASSIAN_HOST", current.host ?? "https://yourcompany.atlassian.net"),
171
+ email: await ask(rl, "ATLASSIAN_EMAIL", current.email),
172
+ apiToken: await ask(rl, "ATLASSIAN_API_TOKEN", current.apiToken),
173
+ };
174
+ }
175
+ if (service === "google-chat") {
176
+ const current = settings.services["google-chat"] ?? {};
177
+ settings.services["google-chat"] = {
178
+ clientId: await ask(rl, "GCHAT_CLIENT_ID", current.clientId),
179
+ clientSecret: await ask(rl, "GCHAT_CLIENT_SECRET", current.clientSecret),
180
+ refreshToken: await ask(rl, "GCHAT_REFRESH_TOKEN", current.refreshToken),
181
+ };
182
+ }
183
+ }
184
+ finally {
185
+ rl.close();
186
+ }
187
+ saveSettings(settings);
188
+ console.log(`Updated ${service} in ${SETTINGS_PATH}`);
189
+ }
190
+ function updateServiceFromArgs(service, updates) {
191
+ const settings = loadSettings();
192
+ settings.services ??= {};
193
+ const parsed = parseUpdates(updates);
194
+ if (!parsed) {
195
+ process.exitCode = 1;
196
+ return;
197
+ }
198
+ if (service === "figma") {
199
+ settings.services.figma = {
200
+ ...(settings.services.figma ?? {}),
201
+ host: parsed.host ?? parsed.FIGMA_HOST ?? settings.services.figma?.host,
202
+ token: parsed.token ?? parsed.FIGMA_TOKEN ?? settings.services.figma?.token,
203
+ };
204
+ }
205
+ if (service === "atlassian") {
206
+ settings.services.atlassian = {
207
+ ...(settings.services.atlassian ?? {}),
208
+ host: parsed.host ?? parsed.ATLASSIAN_HOST ?? settings.services.atlassian?.host,
209
+ email: parsed.email ?? parsed.ATLASSIAN_EMAIL ?? settings.services.atlassian?.email,
210
+ apiToken: parsed.apiToken ??
211
+ parsed.token ??
212
+ parsed.ATLASSIAN_API_TOKEN ??
213
+ settings.services.atlassian?.apiToken,
214
+ };
215
+ }
216
+ if (service === "google-chat") {
217
+ settings.services["google-chat"] = {
218
+ ...(settings.services["google-chat"] ?? {}),
219
+ clientId: parsed.clientId ?? parsed.GCHAT_CLIENT_ID ?? settings.services["google-chat"]?.clientId,
220
+ clientSecret: parsed.clientSecret ??
221
+ parsed.GCHAT_CLIENT_SECRET ??
222
+ settings.services["google-chat"]?.clientSecret,
223
+ refreshToken: parsed.refreshToken ??
224
+ parsed.GCHAT_REFRESH_TOKEN ??
225
+ settings.services["google-chat"]?.refreshToken,
226
+ };
227
+ }
228
+ saveSettings(settings);
229
+ console.log(`Updated ${service} in ${SETTINGS_PATH}`);
230
+ }
231
+ function parseUpdates(updates) {
232
+ const parsed = {};
233
+ for (const update of updates) {
234
+ const separator = update.indexOf("=");
235
+ if (separator <= 0) {
236
+ console.error(`Invalid inline config: ${update}`);
237
+ console.error("Use key=value, for example: localmcp config figma token=figd_xxx");
238
+ return null;
239
+ }
240
+ parsed[update.slice(0, separator)] = update.slice(separator + 1);
241
+ }
242
+ return parsed;
243
+ }
244
+ function getOption(args, name) {
245
+ const index = args.indexOf(name);
246
+ return index >= 0 ? args[index + 1] : undefined;
247
+ }
248
+ function validateChoice(value, choices, label) {
249
+ if (choices.includes(value))
250
+ return value;
251
+ console.error(`Unknown ${label}: ${value}`);
252
+ console.error(`Available: ${choices.join(", ")}`);
253
+ process.exitCode = 1;
254
+ return null;
255
+ }
256
+ async function promptSelect(label, choices) {
257
+ const rl = createInterface({ input: process.stdin, output: process.stdout });
258
+ try {
259
+ console.log(label);
260
+ choices.forEach((choice, index) => {
261
+ console.log(` ${index + 1}. ${choice}`);
262
+ });
263
+ const answer = (await rl.question("> ")).trim();
264
+ const selectedIndex = Number(answer);
265
+ if (Number.isInteger(selectedIndex) && selectedIndex >= 1 && selectedIndex <= choices.length) {
266
+ return choices[selectedIndex - 1];
267
+ }
268
+ const selected = choices.find((choice) => choice === answer);
269
+ if (selected)
270
+ return selected;
271
+ console.error(`Invalid selection: ${answer}`);
272
+ process.exitCode = 1;
273
+ return null;
274
+ }
275
+ finally {
276
+ rl.close();
277
+ }
278
+ }
279
+ async function ask(rl, label, current) {
280
+ const suffix = current ? ` (${current})` : "";
281
+ const answer = await rl.question(`${label}${suffix}: `);
282
+ return answer.trim() || current || "";
283
+ }
284
+ function openEditor(path) {
285
+ const editor = process.env["EDITOR"] ?? process.env["VISUAL"] ?? "vim";
286
+ spawnAndInherit(editor, [path]);
287
+ }
288
+ function spawnAndInherit(command, args) {
289
+ const child = spawn(command, args, { stdio: "inherit" });
290
+ child.on("error", (error) => {
291
+ console.error(`Could not run ${command}: ${error.message}`);
292
+ process.exitCode = 1;
293
+ });
294
+ child.on("exit", (code) => {
295
+ process.exitCode = code ?? 0;
296
+ });
297
+ }
298
+ function readJson(path) {
299
+ if (!existsSync(path))
300
+ return {};
301
+ return JSON.parse(readFileSync(path, "utf8"));
302
+ }
303
+ function writeJson(path, value) {
304
+ mkdirSync(dirname(path), { recursive: true });
305
+ writeFileSync(path, `${JSON.stringify(value, null, 2)}\n`);
306
+ }
307
+ function printHelp() {
308
+ console.log(`localmcp
309
+
310
+ Usage:
311
+ localmcp Run the MCP server
312
+ localmcp init Create ~/localmcp/settings.json
313
+ localmcp list List configured services
314
+ localmcp config Open settings in vim or $EDITOR
315
+ localmcp config <service> Configure one service inline
316
+ localmcp register Select AI agent, then select service
317
+ localmcp register codex --service figma
318
+ localmcp inspect Open MCP Inspector
319
+ localmcp --version, -v Show version
320
+
321
+ Services:
322
+ ${SERVICE_NAMES.join(", ")}
323
+
324
+ AI agents:
325
+ ${AGENTS.join(", ")}
326
+ `);
327
+ }
328
+ function printVersion() {
329
+ const packagePath = join(dirname(fileURLToPath(import.meta.url)), "..", "package.json");
330
+ const pkg = JSON.parse(readFileSync(packagePath, "utf8"));
331
+ console.log(pkg.version ?? "0.0.0");
332
+ }
333
+ //# sourceMappingURL=cli.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ import express from "express";
2
+ export declare function createApp(): express.Express;
3
+ export declare function startServer(): void;
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,SAAS,CAAC;AAyE9B,wBAAgB,SAAS,IAAI,OAAO,CAAC,OAAO,CAgD3C;AAED,wBAAgB,WAAW,IAAI,IAAI,CAQlC"}
package/dist/index.js ADDED
@@ -0,0 +1,102 @@
1
+ import express from "express";
2
+ import { randomUUID } from "node:crypto";
3
+ import { fileURLToPath } from "node:url";
4
+ import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
5
+ import { StreamableHTTPServerTransport } from "@modelcontextprotocol/sdk/server/streamableHttp.js";
6
+ import { env } from "./shared/env.js";
7
+ import { registerFigmaTools } from "./services/figma/index.js";
8
+ import { registerAtlassianTools } from "./services/atlassian/index.js";
9
+ import { registerGChatTools } from "./services/google-chat/index.js";
10
+ const SERVICE_REGISTRY = {
11
+ figma: { register: registerFigmaTools, enabled: !!env.figma },
12
+ atlassian: { register: registerAtlassianTools, enabled: !!env.atlassian },
13
+ "google-chat": { register: registerGChatTools, enabled: !!env.gchat },
14
+ };
15
+ const activeServices = Object.entries(SERVICE_REGISTRY)
16
+ .filter(([, s]) => s.enabled)
17
+ .map(([name]) => name);
18
+ function createServiceServer(name) {
19
+ const server = new McpServer({ name, version: "1.0.0" });
20
+ SERVICE_REGISTRY[name].register(server);
21
+ return server;
22
+ }
23
+ function mountMcpHandler(app, path, getTransports, makeServer) {
24
+ app.all(path, async (req, res) => {
25
+ try {
26
+ const sessionId = req.headers["mcp-session-id"];
27
+ const transports = getTransports();
28
+ if (sessionId && transports.has(sessionId)) {
29
+ await transports.get(sessionId).handleRequest(req, res, req.body);
30
+ return;
31
+ }
32
+ if (req.method === "POST" && !sessionId) {
33
+ const transport = new StreamableHTTPServerTransport({
34
+ sessionIdGenerator: () => randomUUID(),
35
+ onsessioninitialized: (sid) => {
36
+ transports.set(sid, transport);
37
+ },
38
+ });
39
+ transport.onclose = () => {
40
+ if (transport.sessionId)
41
+ transports.delete(transport.sessionId);
42
+ };
43
+ await makeServer().connect(transport);
44
+ await transport.handleRequest(req, res, req.body);
45
+ return;
46
+ }
47
+ res.status(400).json({ error: "Bad request" });
48
+ }
49
+ catch (err) {
50
+ console.error(`[${path}] Error:`, err);
51
+ if (!res.headersSent)
52
+ res.status(500).json({ error: "Internal server error" });
53
+ }
54
+ });
55
+ }
56
+ export function createApp() {
57
+ const app = express();
58
+ app.use(express.json());
59
+ // One transport map per service path
60
+ const transportsByService = new Map();
61
+ for (const name of activeServices) {
62
+ transportsByService.set(name, new Map());
63
+ }
64
+ // Per-service endpoints: /mcp/figma, /mcp/atlassian, /mcp/google-chat
65
+ for (const name of activeServices) {
66
+ const service = name;
67
+ mountMcpHandler(app, `/mcp/${service}`, () => transportsByService.get(service), () => createServiceServer(service));
68
+ }
69
+ // Combined endpoint /mcp — all active services in one server
70
+ const combinedTransports = new Map();
71
+ mountMcpHandler(app, "/mcp", () => combinedTransports, () => {
72
+ const server = new McpServer({ name: "localmcp", version: "1.0.0" });
73
+ for (const name of activeServices) {
74
+ SERVICE_REGISTRY[name].register(server);
75
+ }
76
+ return server;
77
+ });
78
+ app.get("/health", (_req, res) => {
79
+ res.json({
80
+ status: "ok",
81
+ services: activeServices,
82
+ endpoints: {
83
+ combined: `/mcp`,
84
+ ...Object.fromEntries(activeServices.map((s) => [s, `/mcp/${s}`])),
85
+ },
86
+ });
87
+ });
88
+ return app;
89
+ }
90
+ export function startServer() {
91
+ createApp().listen(env.PORT, () => {
92
+ console.log(`Local MCP server running at http://localhost:${env.PORT}`);
93
+ console.log(`Combined endpoint : http://localhost:${env.PORT}/mcp`);
94
+ for (const s of activeServices) {
95
+ console.log(` /mcp/${s.padEnd(12)}: http://localhost:${env.PORT}/mcp/${s}`);
96
+ }
97
+ });
98
+ }
99
+ if (process.argv[1] && fileURLToPath(import.meta.url) === process.argv[1]) {
100
+ startServer();
101
+ }
102
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ import { AxiosInstance } from "axios";
2
+ export declare function getJiraClient(): AxiosInstance;
3
+ export declare function getConfluenceClient(): AxiosInstance;
4
+ //# sourceMappingURL=client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../../src/services/atlassian/client.ts"],"names":[],"mappings":"AAAA,OAAc,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AAkB7C,wBAAgB,aAAa,IAAI,aAAa,CAG7C;AAED,wBAAgB,mBAAmB,IAAI,aAAa,CAGnD"}
@@ -0,0 +1,26 @@
1
+ import axios from "axios";
2
+ import { env } from "../../shared/env.js";
3
+ function makeClient(baseURL) {
4
+ const credentials = Buffer.from(`${env.atlassian.EMAIL}:${env.atlassian.API_TOKEN}`).toString("base64");
5
+ return axios.create({
6
+ baseURL,
7
+ headers: {
8
+ Authorization: `Basic ${credentials}`,
9
+ Accept: "application/json",
10
+ "Content-Type": "application/json",
11
+ },
12
+ });
13
+ }
14
+ let _jira = null;
15
+ let _confluence = null;
16
+ export function getJiraClient() {
17
+ if (!_jira)
18
+ _jira = makeClient(`${env.atlassian.HOST}/rest/api/3`);
19
+ return _jira;
20
+ }
21
+ export function getConfluenceClient() {
22
+ if (!_confluence)
23
+ _confluence = makeClient(`${env.atlassian.HOST}/wiki`);
24
+ return _confluence;
25
+ }
26
+ //# sourceMappingURL=client.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"client.js","sourceRoot":"","sources":["../../../src/services/atlassian/client.ts"],"names":[],"mappings":"AAAA,OAAO,KAAwB,MAAM,OAAO,CAAC;AAC7C,OAAO,EAAE,GAAG,EAAE,MAAM,qBAAqB,CAAC;AAE1C,SAAS,UAAU,CAAC,OAAe;IACjC,MAAM,WAAW,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,GAAG,CAAC,SAAU,CAAC,KAAK,IAAI,GAAG,CAAC,SAAU,CAAC,SAAS,EAAE,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;IAC1G,OAAO,KAAK,CAAC,MAAM,CAAC;QAClB,OAAO;QACP,OAAO,EAAE;YACP,aAAa,EAAE,SAAS,WAAW,EAAE;YACrC,MAAM,EAAE,kBAAkB;YAC1B,cAAc,EAAE,kBAAkB;SACnC;KACF,CAAC,CAAC;AACL,CAAC;AAED,IAAI,KAAK,GAAyB,IAAI,CAAC;AACvC,IAAI,WAAW,GAAyB,IAAI,CAAC;AAE7C,MAAM,UAAU,aAAa;IAC3B,IAAI,CAAC,KAAK;QAAE,KAAK,GAAG,UAAU,CAAC,GAAG,GAAG,CAAC,SAAU,CAAC,IAAI,aAAa,CAAC,CAAC;IACpE,OAAO,KAAK,CAAC;AACf,CAAC;AAED,MAAM,UAAU,mBAAmB;IACjC,IAAI,CAAC,WAAW;QAAE,WAAW,GAAG,UAAU,CAAC,GAAG,GAAG,CAAC,SAAU,CAAC,IAAI,OAAO,CAAC,CAAC;IAC1E,OAAO,WAAW,CAAC;AACrB,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
2
+ export declare function registerAtlassianTools(server: McpServer): void;
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/atlassian/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAIpE,wBAAgB,sBAAsB,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CAG9D"}
@@ -0,0 +1,7 @@
1
+ import { registerJiraTools } from "./tools/jira.js";
2
+ import { registerConfluenceTools } from "./tools/confluence.js";
3
+ export function registerAtlassianTools(server) {
4
+ registerJiraTools(server);
5
+ registerConfluenceTools(server);
6
+ }
7
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/atlassian/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACpD,OAAO,EAAE,uBAAuB,EAAE,MAAM,uBAAuB,CAAC;AAEhE,MAAM,UAAU,sBAAsB,CAAC,MAAiB;IACtD,iBAAiB,CAAC,MAAM,CAAC,CAAC;IAC1B,uBAAuB,CAAC,MAAM,CAAC,CAAC;AAClC,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
2
+ export declare function registerConfluenceTools(server: McpServer): void;
3
+ //# sourceMappingURL=confluence.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"confluence.d.ts","sourceRoot":"","sources":["../../../../src/services/atlassian/tools/confluence.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAOpE,wBAAgB,uBAAuB,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CAqP/D"}