obsidian-native-mcp 1.0.2 → 1.0.3
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/.github/workflows/ci.yml +1 -0
- package/CHANGELOG.md +2 -2
- package/dist/cli/index.js +19 -2
- package/dist/cli/index.js.map +1 -1
- package/dist/mcp/http-transport.js +21 -3
- package/dist/mcp/http-transport.js.map +1 -1
- package/dist/mcp/protocol.js +32 -11
- package/dist/mcp/protocol.js.map +1 -1
- package/dist/mcp/server.js +16 -0
- package/dist/mcp/server.js.map +1 -1
- package/dist/mcp/stdio-transport.js +12 -4
- package/dist/mcp/stdio-transport.js.map +1 -1
- package/dist/plugin/main.js +103 -6
- package/dist/plugin/main.js.map +1 -1
- package/dist/plugin/manifest.json +1 -1
- package/dist/utils/log.js +34 -0
- package/dist/utils/log.js.map +1 -0
- package/dist/utils/vaults.js +14 -0
- package/dist/utils/vaults.js.map +1 -1
- package/manifest.json +1 -1
- package/package.json +2 -1
- package/src/cli/index.ts +24 -2
- package/src/mcp/http-transport.ts +24 -3
- package/src/mcp/protocol.ts +38 -12
- package/src/mcp/server.ts +17 -0
- package/src/mcp/stdio-transport.ts +16 -5
- package/src/plugin/main.ts +26 -2
- package/src/utils/log.ts +43 -0
- package/src/utils/vaults.ts +23 -0
- package/tests/http-transport.test.ts +111 -0
- package/tests/protocol.test.ts +36 -0
package/.github/workflows/ci.yml
CHANGED
package/CHANGELOG.md
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
## [1.0.
|
|
1
|
+
## [1.0.3](https://github.com/usrivastava92/obsidian-native-mcp/compare/v1.0.2...v1.0.3) (2026-05-14)
|
|
2
2
|
|
|
3
3
|
|
|
4
4
|
### Bug Fixes
|
|
5
5
|
|
|
6
|
-
*
|
|
6
|
+
* align MCP transports with opencode and add smoke coverage ([3d4a072](https://github.com/usrivastava92/obsidian-native-mcp/commit/3d4a07282331b7251a71ff13545fcf3ced644c99))
|
package/dist/cli/index.js
CHANGED
|
@@ -3,21 +3,38 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
4
|
const server_1 = require("../mcp/server");
|
|
5
5
|
const stdio_transport_1 = require("../mcp/stdio-transport");
|
|
6
|
+
const log_1 = require("../utils/log");
|
|
6
7
|
const vaults_1 = require("../utils/vaults");
|
|
8
|
+
const log = (0, log_1.createLogger)("cli");
|
|
7
9
|
async function main() {
|
|
8
10
|
const registry = new vaults_1.VaultRegistry();
|
|
9
11
|
if (process.argv.includes("--version") || process.argv.includes("-v")) {
|
|
10
12
|
console.log("0.2.0");
|
|
11
13
|
process.exit(0);
|
|
12
14
|
}
|
|
13
|
-
|
|
15
|
+
const vaults = registry.list();
|
|
16
|
+
const validation = registry.validate();
|
|
17
|
+
log.info("starting obsidian-native-mcp", {
|
|
18
|
+
transport: "stdio",
|
|
19
|
+
vaultCount: vaults.length,
|
|
20
|
+
source: registry.getSource(),
|
|
21
|
+
});
|
|
22
|
+
if (vaults.length === 0) {
|
|
23
|
+
log.warn("no vaults configured", {
|
|
24
|
+
hint: "Set OBSIDIAN_VAULT_PATHS or ~/.config/obsidian-native-mcp/vaults.json",
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
for (const vault of validation.missing) {
|
|
28
|
+
log.warn("configured vault path does not exist", { vault: vault.name, path: vault.path });
|
|
29
|
+
}
|
|
14
30
|
const server = (0, server_1.createServer)(registry);
|
|
15
31
|
const transport = new stdio_transport_1.StdioTransport();
|
|
16
32
|
transport.onRequest(async (msg) => server.handleRequest(msg));
|
|
17
33
|
transport.start();
|
|
34
|
+
log.info("stdio transport ready", { protocol: "jsonl" });
|
|
18
35
|
}
|
|
19
36
|
main().catch((err) => {
|
|
20
|
-
|
|
37
|
+
log.error("startup failed", { error: (0, log_1.formatError)(err) });
|
|
21
38
|
process.exit(1);
|
|
22
39
|
});
|
|
23
40
|
//# sourceMappingURL=index.js.map
|
package/dist/cli/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":";;;AACA,0CAA6C;AAC7C,4DAAwD;AACxD,4CAAgD;AAEhD,KAAK,UAAU,IAAI;IACjB,MAAM,QAAQ,GAAG,IAAI,sBAAa,EAAE,CAAC;IAErC,IAAI,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;QACtE,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QACrB,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IAED,OAAO,CAAC,KAAK,CAAC,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":";;;AACA,0CAA6C;AAC7C,4DAAwD;AACxD,sCAAyD;AACzD,4CAAgD;AAEhD,MAAM,GAAG,GAAG,IAAA,kBAAY,EAAC,KAAK,CAAC,CAAC;AAEhC,KAAK,UAAU,IAAI;IACjB,MAAM,QAAQ,GAAG,IAAI,sBAAa,EAAE,CAAC;IAErC,IAAI,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;QACtE,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QACrB,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IAED,MAAM,MAAM,GAAG,QAAQ,CAAC,IAAI,EAAE,CAAC;IAC/B,MAAM,UAAU,GAAG,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAEvC,GAAG,CAAC,IAAI,CAAC,8BAA8B,EAAE;QACvC,SAAS,EAAE,OAAO;QAClB,UAAU,EAAE,MAAM,CAAC,MAAM;QACzB,MAAM,EAAE,QAAQ,CAAC,SAAS,EAAE;KAC7B,CAAC,CAAC;IAEH,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACxB,GAAG,CAAC,IAAI,CAAC,sBAAsB,EAAE;YAC/B,IAAI,EAAE,uEAAuE;SAC9E,CAAC,CAAC;IACL,CAAC;IAED,KAAK,MAAM,KAAK,IAAI,UAAU,CAAC,OAAO,EAAE,CAAC;QACvC,GAAG,CAAC,IAAI,CAAC,sCAAsC,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;IAC5F,CAAC;IAED,MAAM,MAAM,GAAG,IAAA,qBAAY,EAAC,QAAQ,CAAC,CAAC;IACtC,MAAM,SAAS,GAAG,IAAI,gCAAc,EAAE,CAAC;IAEvC,SAAS,CAAC,SAAS,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC;IAC9D,SAAS,CAAC,KAAK,EAAE,CAAC;IAElB,GAAG,CAAC,IAAI,CAAC,uBAAuB,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC;AAC3D,CAAC;AAED,IAAI,EAAE,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE;IACnB,GAAG,CAAC,KAAK,CAAC,gBAAgB,EAAE,EAAE,KAAK,EAAE,IAAA,iBAAW,EAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IACzD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC,CAAC,CAAC"}
|
|
@@ -5,6 +5,8 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
exports.HttpTransport = void 0;
|
|
7
7
|
const http_1 = __importDefault(require("http"));
|
|
8
|
+
const log_1 = require("../utils/log");
|
|
9
|
+
const log = (0, log_1.createLogger)("http");
|
|
8
10
|
class HttpTransport {
|
|
9
11
|
requestHandler = null;
|
|
10
12
|
server = null;
|
|
@@ -23,16 +25,20 @@ class HttpTransport {
|
|
|
23
25
|
// Messages sent back via SSE response, not directly
|
|
24
26
|
}
|
|
25
27
|
start() {
|
|
26
|
-
return new Promise((resolve) => {
|
|
28
|
+
return new Promise((resolve, reject) => {
|
|
27
29
|
this.server = http_1.default.createServer((req, res) => {
|
|
28
30
|
this.handleRequest(req, res);
|
|
29
31
|
});
|
|
32
|
+
this.server.on("error", (err) => {
|
|
33
|
+
log.error("http transport failed", { error: (0, log_1.formatError)(err) });
|
|
34
|
+
reject(err);
|
|
35
|
+
});
|
|
30
36
|
this.server.listen(0, "127.0.0.1", () => {
|
|
31
37
|
const addr = this.server.address();
|
|
32
38
|
if (addr && typeof addr === "object") {
|
|
33
39
|
this.port = addr.port;
|
|
34
40
|
}
|
|
35
|
-
|
|
41
|
+
log.info("http transport ready", { url: this.url });
|
|
36
42
|
resolve();
|
|
37
43
|
});
|
|
38
44
|
});
|
|
@@ -62,6 +68,10 @@ class HttpTransport {
|
|
|
62
68
|
this.handleMessage(req, res);
|
|
63
69
|
}
|
|
64
70
|
else {
|
|
71
|
+
log.warn("received request for unknown route", {
|
|
72
|
+
method: req.method || "UNKNOWN",
|
|
73
|
+
path: url.pathname,
|
|
74
|
+
});
|
|
65
75
|
res.writeHead(404);
|
|
66
76
|
res.end("Not found");
|
|
67
77
|
}
|
|
@@ -75,15 +85,18 @@ class HttpTransport {
|
|
|
75
85
|
});
|
|
76
86
|
const messageUrl = `/message?session_id=${sessionId}`;
|
|
77
87
|
res.write(`event: endpoint\ndata: ${messageUrl}\n\n`);
|
|
88
|
+
log.info("sse session opened", { sessionId });
|
|
78
89
|
this.sessions.set(sessionId, res);
|
|
79
90
|
req.on("close", () => {
|
|
80
91
|
this.sessions.delete(sessionId);
|
|
92
|
+
log.info("sse session closed", { sessionId });
|
|
81
93
|
});
|
|
82
94
|
}
|
|
83
95
|
handleMessage(req, res) {
|
|
84
96
|
const url = new URL(req.url || "/", `http://${req.headers.host || "localhost"}`);
|
|
85
97
|
const sessionId = url.searchParams.get("session_id");
|
|
86
98
|
if (!sessionId || !this.sessions.has(sessionId)) {
|
|
99
|
+
log.warn("rejected message for unknown session", { sessionId: sessionId || null });
|
|
87
100
|
res.writeHead(400);
|
|
88
101
|
res.end("Invalid or missing session_id");
|
|
89
102
|
return;
|
|
@@ -96,6 +109,7 @@ class HttpTransport {
|
|
|
96
109
|
try {
|
|
97
110
|
const msg = JSON.parse(body);
|
|
98
111
|
if (msg.jsonrpc !== "2.0" || !("method" in msg) || !("id" in msg)) {
|
|
112
|
+
log.warn("rejected invalid json-rpc payload", { sessionId });
|
|
99
113
|
res.writeHead(400);
|
|
100
114
|
res.end("Invalid JSON-RPC message");
|
|
101
115
|
return;
|
|
@@ -110,7 +124,11 @@ class HttpTransport {
|
|
|
110
124
|
res.writeHead(202);
|
|
111
125
|
res.end();
|
|
112
126
|
}
|
|
113
|
-
catch {
|
|
127
|
+
catch (err) {
|
|
128
|
+
log.error("failed to handle http message", {
|
|
129
|
+
sessionId,
|
|
130
|
+
error: (0, log_1.formatError)(err),
|
|
131
|
+
});
|
|
114
132
|
res.writeHead(400);
|
|
115
133
|
res.end("Invalid JSON");
|
|
116
134
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"http-transport.js","sourceRoot":"","sources":["../../src/mcp/http-transport.ts"],"names":[],"mappings":";;;;;;AAAA,gDAAwB;
|
|
1
|
+
{"version":3,"file":"http-transport.js","sourceRoot":"","sources":["../../src/mcp/http-transport.ts"],"names":[],"mappings":"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"}
|
package/dist/mcp/protocol.js
CHANGED
|
@@ -5,7 +5,8 @@ exports.sendMessage = sendMessage;
|
|
|
5
5
|
exports.parseMessages = parseMessages;
|
|
6
6
|
function encodeMessage(message) {
|
|
7
7
|
const json = JSON.stringify(message);
|
|
8
|
-
const
|
|
8
|
+
const bodyLength = Buffer.byteLength(json, "utf8");
|
|
9
|
+
const header = `Content-Length: ${bodyLength}\r\n\r\n`;
|
|
9
10
|
const encoder = new TextEncoder();
|
|
10
11
|
const headerBytes = encoder.encode(header);
|
|
11
12
|
const bodyBytes = encoder.encode(json);
|
|
@@ -19,20 +20,40 @@ function sendMessage(message) {
|
|
|
19
20
|
}
|
|
20
21
|
function parseMessages(buffer) {
|
|
21
22
|
const messages = [];
|
|
22
|
-
let
|
|
23
|
+
let offset = 0;
|
|
23
24
|
while (true) {
|
|
24
|
-
const
|
|
25
|
-
if (
|
|
25
|
+
const headerEnd = buffer.indexOf("\r\n\r\n", offset, "utf8");
|
|
26
|
+
if (headerEnd === -1)
|
|
26
27
|
break;
|
|
27
|
-
const
|
|
28
|
-
const
|
|
29
|
-
const
|
|
30
|
-
if (
|
|
28
|
+
const headerText = buffer.slice(offset, headerEnd).toString("utf8");
|
|
29
|
+
const headers = headerText.split("\r\n");
|
|
30
|
+
const contentLengthHeader = headers.find((header) => header.toLowerCase().startsWith("content-length:"));
|
|
31
|
+
if (!contentLengthHeader)
|
|
31
32
|
break;
|
|
32
|
-
const
|
|
33
|
-
|
|
33
|
+
const contentLength = parseInt(contentLengthHeader.slice("Content-Length:".length).trim(), 10);
|
|
34
|
+
if (Number.isNaN(contentLength))
|
|
35
|
+
break;
|
|
36
|
+
const bodyStart = headerEnd + 4;
|
|
37
|
+
const bodyEnd = bodyStart + contentLength;
|
|
38
|
+
if (buffer.length < bodyEnd)
|
|
39
|
+
break;
|
|
40
|
+
const jsonStr = buffer.slice(bodyStart, bodyEnd).toString("utf8");
|
|
41
|
+
offset = bodyEnd;
|
|
34
42
|
messages.push(jsonStr);
|
|
35
43
|
}
|
|
36
|
-
|
|
44
|
+
if (messages.length > 0) {
|
|
45
|
+
return { messages, remaining: buffer.subarray(offset) };
|
|
46
|
+
}
|
|
47
|
+
while (true) {
|
|
48
|
+
const newlineIndex = buffer.indexOf("\n", offset, "utf8");
|
|
49
|
+
if (newlineIndex === -1)
|
|
50
|
+
break;
|
|
51
|
+
const line = buffer.slice(offset, newlineIndex).toString("utf8").trim();
|
|
52
|
+
offset = newlineIndex + 1;
|
|
53
|
+
if (!line)
|
|
54
|
+
continue;
|
|
55
|
+
messages.push(line);
|
|
56
|
+
}
|
|
57
|
+
return { messages, remaining: buffer.subarray(offset) };
|
|
37
58
|
}
|
|
38
59
|
//# sourceMappingURL=protocol.js.map
|
package/dist/mcp/protocol.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"protocol.js","sourceRoot":"","sources":["../../src/mcp/protocol.ts"],"names":[],"mappings":";;AAmCA,
|
|
1
|
+
{"version":3,"file":"protocol.js","sourceRoot":"","sources":["../../src/mcp/protocol.ts"],"names":[],"mappings":"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"}
|
package/dist/mcp/server.js
CHANGED
|
@@ -3,6 +3,8 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.createServer = createServer;
|
|
4
4
|
const tools_1 = require("../handlers/tools");
|
|
5
5
|
const prompts_1 = require("../handlers/prompts");
|
|
6
|
+
const log_1 = require("../utils/log");
|
|
7
|
+
const log = (0, log_1.createLogger)("server");
|
|
6
8
|
const vaultParam = {
|
|
7
9
|
vault: {
|
|
8
10
|
type: "string",
|
|
@@ -173,6 +175,10 @@ function createServer(registry) {
|
|
|
173
175
|
switch (method) {
|
|
174
176
|
case "initialize": {
|
|
175
177
|
const clientProtocol = params?.protocolVersion;
|
|
178
|
+
log.info("client initialized", {
|
|
179
|
+
clientProtocol: clientProtocol || "2024-11-05",
|
|
180
|
+
vaultCount: vaultList.length,
|
|
181
|
+
});
|
|
176
182
|
return {
|
|
177
183
|
jsonrpc: "2.0",
|
|
178
184
|
id,
|
|
@@ -205,6 +211,10 @@ function createServer(registry) {
|
|
|
205
211
|
return { jsonrpc: "2.0", id, result };
|
|
206
212
|
}
|
|
207
213
|
catch (err) {
|
|
214
|
+
log.error("tool call failed", {
|
|
215
|
+
tool: String(toolName),
|
|
216
|
+
error: (0, log_1.formatError)(err),
|
|
217
|
+
});
|
|
208
218
|
return {
|
|
209
219
|
jsonrpc: "2.0",
|
|
210
220
|
id,
|
|
@@ -219,6 +229,7 @@ function createServer(registry) {
|
|
|
219
229
|
return { jsonrpc: "2.0", id, result: { prompts: promptList } };
|
|
220
230
|
}
|
|
221
231
|
catch (err) {
|
|
232
|
+
log.error("prompt listing failed", { error: (0, log_1.formatError)(err) });
|
|
222
233
|
return {
|
|
223
234
|
jsonrpc: "2.0",
|
|
224
235
|
id,
|
|
@@ -233,6 +244,10 @@ function createServer(registry) {
|
|
|
233
244
|
return { jsonrpc: "2.0", id, result };
|
|
234
245
|
}
|
|
235
246
|
catch (err) {
|
|
247
|
+
log.error("prompt fetch failed", {
|
|
248
|
+
prompt: typeof params?.name === "string" ? params.name : "",
|
|
249
|
+
error: (0, log_1.formatError)(err),
|
|
250
|
+
});
|
|
236
251
|
return {
|
|
237
252
|
jsonrpc: "2.0",
|
|
238
253
|
id,
|
|
@@ -245,6 +260,7 @@ function createServer(registry) {
|
|
|
245
260
|
case "notifications/roots/list_changed":
|
|
246
261
|
return null;
|
|
247
262
|
default:
|
|
263
|
+
log.warn("method not found", { method });
|
|
248
264
|
return {
|
|
249
265
|
jsonrpc: "2.0",
|
|
250
266
|
id,
|
package/dist/mcp/server.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"server.js","sourceRoot":"","sources":["../../src/mcp/server.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"server.js","sourceRoot":"","sources":["../../src/mcp/server.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,18 +2,20 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.StdioTransport = void 0;
|
|
4
4
|
const protocol_1 = require("./protocol");
|
|
5
|
+
const log_1 = require("../utils/log");
|
|
6
|
+
const log = (0, log_1.createLogger)("stdio");
|
|
5
7
|
class StdioTransport {
|
|
6
8
|
requestHandler = null;
|
|
7
|
-
stdinBuffer = { buffer:
|
|
9
|
+
stdinBuffer = { buffer: Buffer.alloc(0) };
|
|
8
10
|
onRequest(handler) {
|
|
9
11
|
this.requestHandler = handler;
|
|
10
12
|
}
|
|
11
13
|
sendMessage(message) {
|
|
12
|
-
(
|
|
14
|
+
process.stdout.write(`${JSON.stringify(message)}\n`);
|
|
13
15
|
}
|
|
14
16
|
start() {
|
|
15
17
|
process.stdin.on("data", async (chunk) => {
|
|
16
|
-
this.stdinBuffer.buffer
|
|
18
|
+
this.stdinBuffer.buffer = Buffer.concat([this.stdinBuffer.buffer, chunk]);
|
|
17
19
|
const { messages, remaining } = (0, protocol_1.parseMessages)(this.stdinBuffer.buffer);
|
|
18
20
|
this.stdinBuffer.buffer = remaining;
|
|
19
21
|
for (const jsonStr of messages) {
|
|
@@ -28,10 +30,16 @@ class StdioTransport {
|
|
|
28
30
|
}
|
|
29
31
|
}
|
|
30
32
|
catch (err) {
|
|
31
|
-
|
|
33
|
+
log.error("failed to process stdio message", { error: (0, log_1.formatError)(err) });
|
|
32
34
|
}
|
|
33
35
|
}
|
|
34
36
|
});
|
|
37
|
+
process.stdin.on("error", (err) => {
|
|
38
|
+
log.error("stdin stream error", { error: (0, log_1.formatError)(err) });
|
|
39
|
+
});
|
|
40
|
+
process.stdout.on("error", (err) => {
|
|
41
|
+
log.error("stdout stream error", { error: (0, log_1.formatError)(err) });
|
|
42
|
+
});
|
|
35
43
|
}
|
|
36
44
|
close() {
|
|
37
45
|
process.stdin.removeAllListeners("data");
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"stdio-transport.js","sourceRoot":"","sources":["../../src/mcp/stdio-transport.ts"],"names":[],"mappings":";;;AACA,
|
|
1
|
+
{"version":3,"file":"stdio-transport.js","sourceRoot":"","sources":["../../src/mcp/stdio-transport.ts"],"names":[],"mappings":";;;AACA,yCAA2C;AAC3C,sCAAyD;AAEzD,MAAM,GAAG,GAAG,IAAA,kBAAY,EAAC,OAAO,CAAC,CAAC;AAElC,MAAa,cAAc;IACjB,cAAc,GACpB,IAAI,CAAC;IACC,WAAW,GAAwC,EAAE,MAAM,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;IAEvF,SAAS,CAAC,OAAqE;QAC7E,IAAI,CAAC,cAAc,GAAG,OAAO,CAAC;IAChC,CAAC;IAED,WAAW,CAAC,OAAwB;QAClC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACvD,CAAC;IAED,KAAK;QACH,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,MAAM,EAAE,KAAK,EAAE,KAAa,EAAE,EAAE;YAC/C,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC;YAE1E,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,IAAA,wBAAa,EAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;YACvE,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,SAAS,CAAC;YAEpC,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;gBAC/B,IAAI,CAAC;oBACH,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;oBAChC,IAAI,GAAG,CAAC,OAAO,KAAK,KAAK;wBAAE,SAAS;oBAEpC,IAAI,QAAQ,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,EAAE,CAAC;wBACnC,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC,GAAqB,CAAC,CAAC;wBACpE,IAAI,QAAQ;4BAAE,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;oBAC3C,CAAC;gBACH,CAAC;gBAAC,OAAO,GAAQ,EAAE,CAAC;oBAClB,GAAG,CAAC,KAAK,CAAC,iCAAiC,EAAE,EAAE,KAAK,EAAE,IAAA,iBAAW,EAAC,GAAG,CAAC,EAAE,CAAC,CAAC;gBAC5E,CAAC;YACH,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE;YAChC,GAAG,CAAC,KAAK,CAAC,oBAAoB,EAAE,EAAE,KAAK,EAAE,IAAA,iBAAW,EAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAC/D,CAAC,CAAC,CAAC;QAEH,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE;YACjC,GAAG,CAAC,KAAK,CAAC,qBAAqB,EAAE,EAAE,KAAK,EAAE,IAAA,iBAAW,EAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAChE,CAAC,CAAC,CAAC;IACL,CAAC;IAED,KAAK;QACH,OAAO,CAAC,KAAK,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;IAC3C,CAAC;CACF;AA/CD,wCA+CC"}
|