@sochdb/sochdb 0.4.2 → 0.4.4

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 (57) hide show
  1. package/README.md +356 -14
  2. package/_bin/aarch64-apple-darwin/libsochdb_storage.dylib +0 -0
  3. package/_bin/aarch64-apple-darwin/sochdb-bulk +0 -0
  4. package/_bin/aarch64-apple-darwin/sochdb-grpc-server +0 -0
  5. package/_bin/aarch64-apple-darwin/sochdb-server +0 -0
  6. package/_bin/x86_64-pc-windows-msvc/sochdb-bulk.exe +0 -0
  7. package/_bin/x86_64-pc-windows-msvc/sochdb-grpc-server.exe +0 -0
  8. package/_bin/x86_64-pc-windows-msvc/sochdb_storage.dll +0 -0
  9. package/_bin/x86_64-unknown-linux-gnu/libsochdb_storage.so +0 -0
  10. package/_bin/x86_64-unknown-linux-gnu/sochdb-bulk +0 -0
  11. package/_bin/x86_64-unknown-linux-gnu/sochdb-grpc-server +0 -0
  12. package/_bin/x86_64-unknown-linux-gnu/sochdb-server +0 -0
  13. package/dist/cjs/embedded/database.js +98 -4
  14. package/dist/cjs/embedded/ffi/bindings.js +46 -8
  15. package/dist/cjs/index.js +28 -6
  16. package/dist/cjs/mcp/client.js +115 -0
  17. package/dist/cjs/mcp/index.js +28 -0
  18. package/dist/cjs/mcp/server.js +242 -0
  19. package/dist/cjs/mcp/types.js +32 -0
  20. package/dist/cjs/namespace.js +147 -19
  21. package/dist/cjs/policy/index.js +26 -0
  22. package/dist/cjs/policy/service.js +394 -0
  23. package/dist/cjs/policy/types.js +8 -0
  24. package/dist/esm/embedded/database.js +98 -4
  25. package/dist/esm/embedded/ffi/bindings.js +48 -8
  26. package/dist/esm/index.js +28 -6
  27. package/dist/esm/mcp/client.js +116 -0
  28. package/dist/esm/mcp/index.js +28 -0
  29. package/dist/esm/mcp/server.js +244 -0
  30. package/dist/esm/mcp/types.js +34 -0
  31. package/dist/esm/namespace.js +150 -19
  32. package/dist/esm/policy/index.js +26 -0
  33. package/dist/esm/policy/service.js +396 -0
  34. package/dist/esm/policy/types.js +8 -0
  35. package/dist/types/embedded/database.d.ts +66 -1
  36. package/dist/types/embedded/database.d.ts.map +1 -1
  37. package/dist/types/embedded/ffi/bindings.d.ts +7 -0
  38. package/dist/types/embedded/ffi/bindings.d.ts.map +1 -1
  39. package/dist/types/index.d.ts +23 -5
  40. package/dist/types/index.d.ts.map +1 -1
  41. package/dist/types/mcp/client.d.ts +69 -0
  42. package/dist/types/mcp/client.d.ts.map +1 -0
  43. package/dist/types/mcp/index.d.ts +9 -0
  44. package/dist/types/mcp/index.d.ts.map +1 -0
  45. package/dist/types/mcp/server.d.ts +87 -0
  46. package/dist/types/mcp/server.d.ts.map +1 -0
  47. package/dist/types/mcp/types.d.ts +124 -0
  48. package/dist/types/mcp/types.d.ts.map +1 -0
  49. package/dist/types/namespace.d.ts +13 -0
  50. package/dist/types/namespace.d.ts.map +1 -1
  51. package/dist/types/policy/index.d.ts +8 -0
  52. package/dist/types/policy/index.d.ts.map +1 -0
  53. package/dist/types/policy/service.d.ts +115 -0
  54. package/dist/types/policy/service.d.ts.map +1 -0
  55. package/dist/types/policy/types.d.ts +102 -0
  56. package/dist/types/policy/types.d.ts.map +1 -0
  57. package/package.json +2 -2
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ /**
3
+ * MCP (Model Context Protocol) Module
4
+ *
5
+ * Provides MCP server and client implementations for LLM agent integration.
6
+ */
7
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
8
+ if (k2 === undefined) k2 = k;
9
+ var desc = Object.getOwnPropertyDescriptor(m, k);
10
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
11
+ desc = { enumerable: true, get: function() { return m[k]; } };
12
+ }
13
+ Object.defineProperty(o, k2, desc);
14
+ }) : (function(o, m, k, k2) {
15
+ if (k2 === undefined) k2 = k;
16
+ o[k2] = m[k];
17
+ }));
18
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
19
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
20
+ };
21
+ Object.defineProperty(exports, "__esModule", { value: true });
22
+ exports.McpClient = exports.McpServer = void 0;
23
+ __exportStar(require("./types"), exports);
24
+ var server_1 = require("./server");
25
+ Object.defineProperty(exports, "McpServer", { enumerable: true, get: function () { return server_1.McpServer; } });
26
+ var client_1 = require("./client");
27
+ Object.defineProperty(exports, "McpClient", { enumerable: true, get: function () { return client_1.McpClient; } });
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbWNwL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7OztHQUlHOzs7Ozs7Ozs7Ozs7Ozs7OztBQUVILDBDQUF3QjtBQUN4QixtQ0FBcUM7QUFBNUIsbUdBQUEsU0FBUyxPQUFBO0FBQ2xCLG1DQUFxQztBQUE1QixtR0FBQSxTQUFTLE9BQUEiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIE1DUCAoTW9kZWwgQ29udGV4dCBQcm90b2NvbCkgTW9kdWxlXG4gKiBcbiAqIFByb3ZpZGVzIE1DUCBzZXJ2ZXIgYW5kIGNsaWVudCBpbXBsZW1lbnRhdGlvbnMgZm9yIExMTSBhZ2VudCBpbnRlZ3JhdGlvbi5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3R5cGVzJztcbmV4cG9ydCB7IE1jcFNlcnZlciB9IGZyb20gJy4vc2VydmVyJztcbmV4cG9ydCB7IE1jcENsaWVudCB9IGZyb20gJy4vY2xpZW50JztcbiJdfQ==
@@ -0,0 +1,244 @@
1
+ "use strict";
2
+ /**
3
+ * MCP Server Implementation
4
+ *
5
+ * SochDB MCP Server for exposing database operations to LLM agents.
6
+ */
7
+ Object.defineProperty(exports, "__esModule", { value: true });
8
+ exports.McpServer = void 0;
9
+ /**
10
+ * MCP Server for SochDB
11
+ *
12
+ * Exposes database operations as MCP tools for LLM agents.
13
+ *
14
+ * @example
15
+ * ```typescript
16
+ * import { EmbeddedDatabase, McpServer } from '@sochdb/sochdb';
17
+ *
18
+ * const db = EmbeddedDatabase.open('./mydb');
19
+ * const server = new McpServer(db, {
20
+ * name: 'sochdb-mcp',
21
+ * version: '1.0.0',
22
+ * capabilities: { tools: true, resources: true }
23
+ * });
24
+ *
25
+ * // List available tools
26
+ * const tools = server.listTools();
27
+ *
28
+ * // Execute a tool call
29
+ * const result = await server.callTool({
30
+ * id: 'call_1',
31
+ * name: 'db_get',
32
+ * arguments: { key: 'user:123' }
33
+ * });
34
+ * ```
35
+ */
36
+ class McpServer {
37
+ db;
38
+ config;
39
+ tools = new Map();
40
+ prompts = new Map();
41
+ customToolHandlers = new Map();
42
+ constructor(db, config) {
43
+ this.db = db;
44
+ this.config = config;
45
+ this.registerBuiltinTools();
46
+ }
47
+ /**
48
+ * Register built-in database tools
49
+ */
50
+ registerBuiltinTools() {
51
+ // Key-Value operations
52
+ this.registerTool({
53
+ name: 'db_get',
54
+ description: 'Get a value from the database by key',
55
+ inputSchema: {
56
+ type: 'object',
57
+ properties: {
58
+ key: { type: 'string', description: 'The key to retrieve' },
59
+ },
60
+ required: ['key'],
61
+ },
62
+ }, async (args) => {
63
+ const value = await this.db.get(Buffer.from(args.key));
64
+ return value ? value.toString() : null;
65
+ });
66
+ this.registerTool({
67
+ name: 'db_put',
68
+ description: 'Store a value in the database',
69
+ inputSchema: {
70
+ type: 'object',
71
+ properties: {
72
+ key: { type: 'string', description: 'The key to store' },
73
+ value: { type: 'string', description: 'The value to store' },
74
+ },
75
+ required: ['key', 'value'],
76
+ },
77
+ }, async (args) => {
78
+ await this.db.put(Buffer.from(args.key), Buffer.from(args.value));
79
+ return { success: true };
80
+ });
81
+ this.registerTool({
82
+ name: 'db_delete',
83
+ description: 'Delete a key from the database',
84
+ inputSchema: {
85
+ type: 'object',
86
+ properties: {
87
+ key: { type: 'string', description: 'The key to delete' },
88
+ },
89
+ required: ['key'],
90
+ },
91
+ }, async (args) => {
92
+ await this.db.delete(Buffer.from(args.key));
93
+ return { success: true };
94
+ });
95
+ this.registerTool({
96
+ name: 'db_scan',
97
+ description: 'Scan keys with a prefix',
98
+ inputSchema: {
99
+ type: 'object',
100
+ properties: {
101
+ prefix: { type: 'string', description: 'The prefix to scan' },
102
+ limit: { type: 'number', description: 'Maximum results', default: 100 },
103
+ },
104
+ required: ['prefix'],
105
+ },
106
+ }, async (args) => {
107
+ const results = [];
108
+ const limit = args.limit || 100;
109
+ let count = 0;
110
+ for await (const [keyBuffer, valueBuffer] of this.db.scanPrefix(Buffer.from(args.prefix))) {
111
+ if (count >= limit)
112
+ break;
113
+ results.push({
114
+ key: keyBuffer.toString(),
115
+ value: valueBuffer.toString(),
116
+ });
117
+ count++;
118
+ }
119
+ return results;
120
+ });
121
+ this.registerTool({
122
+ name: 'db_stats',
123
+ description: 'Get database statistics',
124
+ inputSchema: {
125
+ type: 'object',
126
+ properties: {},
127
+ },
128
+ }, async () => {
129
+ const stats = await this.db.stats();
130
+ return {
131
+ memtableSizeBytes: stats.memtableSizeBytes.toString(),
132
+ walSizeBytes: stats.walSizeBytes.toString(),
133
+ activeTransactions: stats.activeTransactions,
134
+ };
135
+ });
136
+ }
137
+ /**
138
+ * Register a custom tool
139
+ */
140
+ registerTool(tool, handler) {
141
+ this.tools.set(tool.name, tool);
142
+ this.customToolHandlers.set(tool.name, handler);
143
+ }
144
+ /**
145
+ * Unregister a tool
146
+ */
147
+ unregisterTool(name) {
148
+ this.customToolHandlers.delete(name);
149
+ return this.tools.delete(name);
150
+ }
151
+ /**
152
+ * List all available tools
153
+ */
154
+ listTools() {
155
+ return Array.from(this.tools.values());
156
+ }
157
+ /**
158
+ * Call a tool
159
+ */
160
+ async callTool(call) {
161
+ const handler = this.customToolHandlers.get(call.name);
162
+ if (!handler) {
163
+ return {
164
+ id: call.id,
165
+ content: null,
166
+ isError: true,
167
+ errorMessage: `Tool not found: ${call.name}`,
168
+ };
169
+ }
170
+ try {
171
+ const content = await handler(call.arguments);
172
+ return {
173
+ id: call.id,
174
+ content,
175
+ isError: false,
176
+ };
177
+ }
178
+ catch (error) {
179
+ return {
180
+ id: call.id,
181
+ content: null,
182
+ isError: true,
183
+ errorMessage: error.message || 'Unknown error',
184
+ };
185
+ }
186
+ }
187
+ /**
188
+ * Register a prompt template
189
+ */
190
+ registerPrompt(prompt) {
191
+ this.prompts.set(prompt.name, prompt);
192
+ }
193
+ /**
194
+ * List all available prompts
195
+ */
196
+ listPrompts() {
197
+ return Array.from(this.prompts.values());
198
+ }
199
+ /**
200
+ * Get prompt messages
201
+ */
202
+ getPrompt(name, args) {
203
+ const prompt = this.prompts.get(name);
204
+ if (!prompt) {
205
+ return null;
206
+ }
207
+ // For now, return empty messages - actual implementation would render the prompt
208
+ return [];
209
+ }
210
+ /**
211
+ * List available resources
212
+ */
213
+ async listResources() {
214
+ // Return database stats as a resource
215
+ return [{
216
+ uri: 'sochdb://stats',
217
+ name: 'Database Statistics',
218
+ description: 'Current database statistics',
219
+ mimeType: 'application/json',
220
+ }];
221
+ }
222
+ /**
223
+ * Read a resource
224
+ */
225
+ async readResource(uri) {
226
+ if (uri === 'sochdb://stats') {
227
+ const stats = await this.db.stats();
228
+ return {
229
+ uri,
230
+ mimeType: 'application/json',
231
+ text: JSON.stringify(stats, (_, v) => typeof v === 'bigint' ? v.toString() : v),
232
+ };
233
+ }
234
+ return null;
235
+ }
236
+ /**
237
+ * Get server info
238
+ */
239
+ getServerInfo() {
240
+ return { ...this.config };
241
+ }
242
+ }
243
+ exports.McpServer = McpServer;
244
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VydmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL21jcC9zZXJ2ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7O0dBSUc7OztBQWlCSDs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0EwQkc7QUFDSCxNQUFhLFNBQVM7SUFDWixFQUFFLENBQW1CO0lBQ3JCLE1BQU0sQ0FBa0I7SUFDeEIsS0FBSyxHQUF5QixJQUFJLEdBQUcsRUFBRSxDQUFDO0lBQ3hDLE9BQU8sR0FBMkIsSUFBSSxHQUFHLEVBQUUsQ0FBQztJQUM1QyxrQkFBa0IsR0FBNkQsSUFBSSxHQUFHLEVBQUUsQ0FBQztJQUVqRyxZQUFZLEVBQW9CLEVBQUUsTUFBdUI7UUFDdkQsSUFBSSxDQUFDLEVBQUUsR0FBRyxFQUFFLENBQUM7UUFDYixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUNyQixJQUFJLENBQUMsb0JBQW9CLEVBQUUsQ0FBQztJQUM5QixDQUFDO0lBRUQ7O09BRUc7SUFDSyxvQkFBb0I7UUFDMUIsdUJBQXVCO1FBQ3ZCLElBQUksQ0FBQyxZQUFZLENBQUM7WUFDaEIsSUFBSSxFQUFFLFFBQVE7WUFDZCxXQUFXLEVBQUUsc0NBQXNDO1lBQ25ELFdBQVcsRUFBRTtnQkFDWCxJQUFJLEVBQUUsUUFBUTtnQkFDZCxVQUFVLEVBQUU7b0JBQ1YsR0FBRyxFQUFFLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRSxXQUFXLEVBQUUscUJBQXFCLEVBQUU7aUJBQzVEO2dCQUNELFFBQVEsRUFBRSxDQUFDLEtBQUssQ0FBQzthQUNsQjtTQUNGLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxFQUFFO1lBQ2hCLE1BQU0sS0FBSyxHQUFHLE1BQU0sSUFBSSxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztZQUN2RCxPQUFPLEtBQUssQ0FBQyxDQUFD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ZW50YXRpb25cbiAqIFxuICogU29jaERCIE1DUCBTZXJ2ZXIgZm9yIGV4cG9zaW5nIGRhdGFiYXNlIG9wZXJhdGlvbnMgdG8gTExNIGFnZW50cy5cbiAqL1xuXG5pbXBvcnQgeyBFbWJlZGRlZERhdGFiYXNlIH0gZnJvbSAnLi4vZW1iZWRkZWQnO1xuaW1wb3J0IHtcbiAgTWNwVG9vbCxcbiAgTWNwVG9vbENhbGwsXG4gIE1jcFRvb2xSZXN1bHQsXG4gIE1jcFJlc291cmNlLFxuICBNY3BSZXNvdXJjZUNvbnRlbnQsXG4gIE1jcFByb21wdCxcbiAgTWNwUHJvbXB0TWVzc2FnZSxcbiAgTWNwU2VydmVyQ29uZmlnLFxuICBNY3BTZXJ2ZXJDYXBhYmlsaXRpZXMsXG4gIE1jcEVycm9yLFxuICBNQ1BfRVJST1JfQ09ERVMsXG59IGZyb20gJy4vdHlwZXMnO1xuXG4vKipcbiAqIE1DUCBTZXJ2ZXIgZm9yIFNvY2hEQlxuICogXG4gKiBFeHBvc2VzIGRhdGFiYXNlIG9wZXJhdGlvbnMgYXMgTUNQIHRvb2xzIGZvciBMTE0gYWdlbnRzLlxuICogXG4gKiBAZXhhbXBsZVxuICogYGBgdHlwZXNjcmlwdFxuICogaW1wb3J0IHsgRW1iZWRkZWREYXRhYmFzZSwgTWNwU2VydmVyIH0gZnJvbSAnQHNvY2hkYi9zb2NoZGInO1xuICogXG4gKiBjb25zdCBkYiA9IEVtYmVkZGVkRGF0YWJhc2Uub3BlbignLi9teWRiJyk7XG4gKiBjb25zdCBzZXJ2ZXIgPSBuZXcgTWNwU2VydmVyKGRiLCB7XG4gKiAgIG5hbWU6ICdzb2NoZGItbWNwJyxcbiAqICAgdmVyc2lvbjogJzEuMC4wJyxcbiAqICAgY2FwYWJpbGl0aWVzOiB7IHRvb2xzOiB0cnVlLCByZXNvdXJjZXM6IHRydWUgfVxuICogfSk7XG4gKiBcbiAqIC8vIExpc3QgYXZhaWxhYmxlIHRvb2xzXG4gKiBjb25zdCB0b29scyA9IHNlcnZlci5saXN0VG9vbHMoKTtcbiAqIFxuICogLy8gRXhlY3V0ZSBhIHRvb2wgY2FsbFxuICogY29uc3QgcmVzdWx0ID0gYXdhaXQgc2VydmVyLmNhbGxUb29sKHtcbiAqICAgaWQ6ICdjYWxsXzEnLFxuICogICBuYW1lOiAnZGJfZ2V0JyxcbiAqICAgYXJndW1lbnRzOiB7IGtleTogJ3VzZXI6MTIzJyB9XG4gKiB9KTtcbiAqIGBgYFxuICovXG5leHBvcnQgY2xhc3MgTWNwU2VydmVyIHtcbiAgcHJpdmF0ZSBkYjogRW1iZWRkZWREYXRhYmFzZTtcbiAgcHJpdmF0ZSBjb25maWc6IE1jcFNlcnZlckNvbmZpZztcbiAgcHJpdmF0ZSB0b29sczogTWFwPHN0cmluZywgTWNwVG9vbD4gPSBuZXcgTWFwKCk7XG4gIHByaXZhdGUgcHJvbXB0czogTWFwPHN0cmluZywgTWNwUHJvbXB0PiA9IG5ldyBNYXAoKTtcbiAgcHJpdmF0ZSBjdXN0b21Ub29sSGFuZGxlcnM6IE1hcDxzdHJpbmcsIChhcmdzOiBSZWNvcmQ8c3RyaW5nLCBhbnk+KSA9PiBQcm9taXNlPGFueT4+ID0gbmV3IE1hcCgpO1xuXG4gIGNvbnN0cnVjdG9yKGRiOiBFbWJlZGRlZERhdGFiYXNlLCBjb25maWc6IE1jcFNlcnZlckNvbmZpZykge1xuICAgIHRoaXMuZGIgPSBkYjtcbiAgICB0aGlzLmNvbmZpZyA9IGNvbmZpZztcbiAgICB0aGlzLnJlZ2lzdGVyQnVpbHRpblRvb2xzKCk7XG4gIH1cblxuICAvKipcbiAgICogUmVnaXN0ZXIgYnVpbHQtaW4gZGF0YWJhc2UgdG9vbHNcbiAgICovXG4gIHByaXZhdGUgcmVnaXN0ZXJCdWlsdGluVG9vbHMoKTogdm9pZCB7XG4gICAgLy8gS2V5LVZhbHVlIG9wZXJhdGlvbnNcbiAgICB0aGlzLnJlZ2lzdGVyVG9vbCh7XG4gICAgICBuYW1lOiAnZGJfZ2V0JyxcbiAgICAgIGRlc2NyaXB0aW9uOiAnR2V0IGEgdmFsdWUgZnJvbSB0aGUgZGF0YWJhc2UgYnkga2V5JyxcbiAgICAgIGlucHV0U2NoZW1hOiB7XG4gICAgICAgIHR5cGU6ICdvYmplY3QnLFxuICAgICAgICBwcm9wZXJ0aWVzOiB7XG4gICAgICAgICAga2V5OiB7IHR5cGU6ICdzdHJpbmcnLCBkZXNjcmlwdGlvbjogJ1RoZSBrZXkgdG8gcmV0cmlldmUnIH0sXG4gICAgICAgIH0sXG4gICAgICAgIHJlcXVpcmVkOiBbJ2tleSddLFxuICAgICAgfSxcbiAgICB9LCBhc3luYyAoYXJncykgPT4ge1xuICAgICAgY29uc3QgdmFsdWUgPSBhd2FpdCB0aGlzLmRiLmdldChCdWZmZXIuZnJvbShhcmdzLmtleSkpO1xuICAgICAgcmV0dXJuIHZhbHVlID8gdmFsdWUudG9TdHJpbmcoKSA6IG51bGw7XG4gICAgfSk7XG5cbiAgICB0aGlzLnJlZ2lzdGVyVG9vbCh7XG4gICAgICBuYW1lOiAnZGJfcHV0JyxcbiAgICAgIGRlc2NyaXB0aW9uOiAnU3RvcmUgYSB2YWx1ZSBpbiB0aGUgZGF0YWJhc2UnLFxuICAgICAgaW5wdXRTY2hlbWE6IHtcbiAgICAgICAgdHlwZTogJ29iamVjdCcsXG4gICAgICAgIHByb3BlcnRpZXM6IHtcbiAgICAgICAgICBrZXk6IHsgdHlwZTogJ3N0cmluZycsIGRlc2NyaXB0aW9uOiAnVGhlIGtleSB0byBzdG9yZScgfSxcbiAgICAgICAgICB2YWx1ZTogeyB0eXBlOiAnc3RyaW5nJywgZGVzY3JpcHRpb246ICdUaGUgdmFsdWUgdG8gc3RvcmUnIH0sXG4gICAgICAgIH0sXG4gICAgICAgIHJlcXVpcmVkOiBbJ2tleScsICd2YWx1ZSddLFxuICAgICAgfSxcbiAgICB9LCBhc3luYyAoYXJncykgPT4ge1xuICAgICAgYXdhaXQgdGhpcy5kYi5wdXQoQnVmZmVyLmZyb20oYXJncy5rZXkpLCBCdWZmZXIuZnJvbShhcmdzLnZhbHVlKSk7XG4gICAgICByZXR1cm4geyBzdWNjZXNzOiB0cnVlIH07XG4gICAgfSk7XG5cbiAgICB0aGlzLnJlZ2lzdGVyVG9vbCh7XG4gICAgICBuYW1lOiAnZGJfZGVsZXRlJyxcbiAgICAgIGRlc2NyaXB0aW9uOiAnRGVsZXRlIGEga2V5IGZyb20gdGhlIGRhdGFiYXNlJyxcbiAgICAgIGlucHV0U2NoZW1hOiB7XG4gICAgICAgIHR5cGU6ICdvYmplY3QnLFxuICAgICAgICBwcm9wZXJ0aWVzOiB7XG4gICAgICAgICAga2V5OiB7IHR5cGU6ICdzdHJpbmcnLCBkZXNjcmlwdGlvbjogJ1RoZSBrZXkgdG8gZGVsZXRlJyB9LFxuICAgICAgICB9LFxuICAgICAgICByZXF1aXJlZDogWydrZXknXSxcbiAgICAgIH0sXG4gICAgfSwgYXN5bmMgKGFyZ3MpID0+IHtcbiAgICAgIGF3YWl0IHRoaXMuZGIuZGVsZXRlKEJ1ZmZlci5mcm9tKGFyZ3Mua2V5KSk7XG4gICAgICByZXR1cm4geyBzdWNjZXNzOiB0cnVlIH07XG4gICAgfSk7XG5cbiAgICB0aGlzLnJlZ2lzdGVyVG9vbCh7XG4gICAgICBuYW1lOiAnZGJfc2NhbicsXG4gICAgICBkZXNjcmlwdGlvbjogJ1NjYW4ga2V5cyB3aXRoIGEgcHJlZml4JyxcbiAgICAgIGlucHV0U2NoZW1hOiB7XG4gICAgICAgIHR5cGU6ICdvYmplY3QnLFxuICAgICAgICBwcm9wZXJ0aWVzOiB7XG4gICAgICAgICAgcHJlZml4OiB7IHR5cGU6ICdzdHJpbmcnLCBkZXNjcmlwdGlvbjogJ1RoZSBwcmVmaXggdG8gc2NhbicgfSxcbiAgICAgICAgICBsaW1pdDogeyB0eXBlOiAnbnVtYmVyJywgZGVzY3JpcHRpb246ICdNYXhpbXVtIHJlc3VsdHMnLCBkZWZhdWx0OiAxMDAgfSxcbiAgICAgICAgfSxcbiAgICAgICAgcmVxdWlyZWQ6IFsncHJlZml4J10sXG4gICAgICB9LFxuICAgIH0sIGFzeW5jIChhcmdzKSA9PiB7XG4gICAgICBjb25zdCByZXN1bHRzOiBBcnJheTx7IGtleTogc3RyaW5nOyB2YWx1ZTogc3RyaW5nIH0+ID0gW107XG4gICAgICBjb25zdCBsaW1pdCA9IGFyZ3MubGltaXQgfHwgMTAwO1xuICAgICAgbGV0IGNvdW50ID0gMDtcblxuICAgICAgZm9yIGF3YWl0IChjb25zdCBba2V5QnVmZmVyLCB2YWx1ZUJ1ZmZlcl0gb2YgdGhpcy5kYi5zY2FuUHJlZml4KEJ1ZmZlci5mcm9tKGFyZ3MucHJlZml4KSkpIHtcbiAgICAgICAgaWYgKGNvdW50ID49IGxpbWl0KSBicmVhaztcbiAgICAgICAgcmVzdWx0cy5wdXNoKHtcbiAgICAgICAgICBrZXk6IGtleUJ1ZmZlci50b1N0cmluZygpLFxuICAgICAgICAgIHZhbHVlOiB2YWx1ZUJ1ZmZlci50b1N0cmluZygpLFxuICAgICAgICB9KTtcbiAgICAgICAgY291bnQrKztcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHJlc3VsdHM7XG4gICAgfSk7XG5cbiAgICB0aGlzLnJlZ2lzdGVyVG9vbCh7XG4gICAgICBuYW1lOiAnZGJfc3RhdHMnLFxuICAgICAgZGVzY3JpcHRpb246ICdHZXQgZGF0YWJhc2Ugc3RhdGlzdGljcycsXG4gICAgICBpbnB1dFNjaGVtYToge1xuICAgICAgICB0eXBlOiAnb2JqZWN0JyxcbiAgICAgICAgcHJvcGVydGllczoge30sXG4gICAgICB9LFxuICAgIH0sIGFzeW5jICgpID0+IHtcbiAgICAgIGNvbnN0IHN0YXRzID0gYXdhaXQgdGhpcy5kYi5zdGF0cygpO1xuICAgICAgcmV0dXJuIHtcbiAgICAgICAgbWVtdGFibGVTaXplQnl0ZXM6IHN0YXRzLm1lbXRhYmxlU2l6ZUJ5dGVzLnRvU3RyaW5nKCksXG4gICAgICAgIHdhbFNpemVCeXRlczogc3RhdHMud2FsU2l6ZUJ5dGVzLnRvU3RyaW5nKCksXG4gICAgICAgIGFjdGl2ZVRyYW5zYWN0aW9uczogc3RhdHMuYWN0aXZlVHJhbnNhY3Rpb25zLFxuICAgICAgfTtcbiAgICB9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZWdpc3RlciBhIGN1c3RvbSB0b29sXG4gICAqL1xuICByZWdpc3RlclRvb2woXG4gICAgdG9vbDogTWNwVG9vbCxcbiAgICBoYW5kbGVyOiAoYXJnczogUmVjb3JkPHN0cmluZywgYW55PikgPT4gUHJvbWlzZTxhbnk+XG4gICk6IHZvaWQge1xuICAgIHRoaXMudG9vbHMuc2V0KHRvb2wubmFtZSwgdG9vbCk7XG4gICAgdGhpcy5jdXN0b21Ub29sSGFuZGxlcnMuc2V0KHRvb2wubmFtZSwgaGFuZGxlcik7XG4gIH1cblxuICAvKipcbiAgICogVW5yZWdpc3RlciBhIHRvb2xcbiAgICovXG4gIHVucmVnaXN0ZXJUb29sKG5hbWU6IHN0cmluZyk6IGJvb2xlYW4ge1xuICAgIHRoaXMuY3VzdG9tVG9vbEhhbmRsZXJzLmRlbGV0ZShuYW1lKTtcbiAgICByZXR1cm4gdGhpcy50b29scy5kZWxldGUobmFtZSk7XG4gIH1cblxuICAvKipcbiAgICogTGlzdCBhbGwgYXZhaWxhYmxlIHRvb2xzXG4gICAqL1xuICBsaXN0VG9vbHMoKTogTWNwVG9vbFtdIHtcbiAgICByZXR1cm4gQXJyYXkuZnJvbSh0aGlzLnRvb2xzLnZhbHVlcygpKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDYWxsIGEgdG9vbFxuICAgKi9cbiAgYXN5bmMgY2FsbFRvb2woY2FsbDogTWNwVG9vbENhbGwpOiBQcm9taXNlPE1jcFRvb2xSZXN1bHQ+IHtcbiAgICBjb25zdCBoYW5kbGVyID0gdGhpcy5jdXN0b21Ub29sSGFuZGxlcnMuZ2V0KGNhbGwubmFtZSk7XG4gICAgXG4gICAgaWYgKCFoYW5kbGVyKSB7XG4gICAgICByZXR1cm4ge1xuICAgICAgICBpZDogY2FsbC5pZCxcbiAgICAgICAgY29udGVudDogbnVsbCxcbiAgICAgICAgaXNFcnJvcjogdHJ1ZSxcbiAgICAgICAgZXJyb3JNZXNzYWdlOiBgVG9vbCBub3QgZm91bmQ6ICR7Y2FsbC5uYW1lfWAsXG4gICAgICB9O1xuICAgIH1cblxuICAgIHRyeSB7XG4gICAgICBjb25zdCBjb250ZW50ID0gYXdhaXQgaGFuZGxlcihjYWxsLmFyZ3VtZW50cyk7XG4gICAgICByZXR1cm4ge1xuICAgICAgICBpZDogY2FsbC5pZCxcbiAgICAgICAgY29udGVudCxcbiAgICAgICAgaXNFcnJvcjogZmFsc2UsXG4gICAgICB9O1xuICAgIH0gY2F0Y2ggKGVycm9yOiBhbnkpIHtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIGlkOiBjYWxsLmlkLFxuICAgICAgICBjb250ZW50OiBudWxsLFxuICAgICAgICBpc0Vycm9yOiB0cnVlLFxuICAgICAgICBlcnJvck1lc3NhZ2U6IGVycm9yLm1lc3NhZ2UgfHwgJ1Vua25vd24gZXJyb3InLFxuICAgICAgfTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogUmVnaXN0ZXIgYSBwcm9tcHQgdGVtcGxhdGVcbiAgICovXG4gIHJlZ2lzdGVyUHJvbXB0KHByb21wdDogTWNwUHJvbXB0KTogdm9pZCB7XG4gICAgdGhpcy5wcm9tcHRzLnNldChwcm9tcHQubmFtZSwgcHJvbXB0KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBMaXN0IGFsbCBhdmFpbGFibGUgcHJvbXB0c1xuICAgKi9cbiAgbGlzdFByb21wdHMoKTogTWNwUHJvbXB0W10ge1xuICAgIHJldHVybiBBcnJheS5mcm9tKHRoaXMucHJvbXB0cy52YWx1ZXMoKSk7XG4gIH1cblxuICAvKipcbiAgICogR2V0IHByb21wdCBtZXNzYWdlc1xuICAgKi9cbiAgZ2V0UHJvbXB0KG5hbWU6IHN0cmluZywgYXJncz86IFJlY29yZDxzdHJpbmcsIGFueT4pOiBNY3BQcm9tcHRNZXNzYWdlW10gfCBudWxsIHtcbiAgICBjb25zdCBwcm9tcHQgPSB0aGlzLnByb21wdHMuZ2V0KG5hbWUpO1xuICAgIGlmICghcHJvbXB0KSB7XG4gICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG5cbiAgICAvLyBGb3Igbm93LCByZXR1cm4gZW1wdHkgbWVzc2FnZXMgLSBhY3R1YWwgaW1wbGVtZW50YXRpb24gd291bGQgcmVuZGVyIHRoZSBwcm9tcHRcbiAgICByZXR1cm4gW107XG4gIH1cblxuICAvKipcbiAgICogTGlzdCBhdmFpbGFibGUgcmVzb3VyY2VzXG4gICAqL1xuICBhc3luYyBsaXN0UmVzb3VyY2VzKCk6IFByb21pc2U8TWNwUmVzb3VyY2VbXT4ge1xuICAgIC8vIFJldHVybiBkYXRhYmFzZSBzdGF0cyBhcyBhIHJlc291cmNlXG4gICAgcmV0dXJuIFt7XG4gICAgICB1cmk6ICdzb2NoZGI6Ly9zdGF0cycsXG4gICAgICBuYW1lOiAnRGF0YWJhc2UgU3RhdGlzdGljcycsXG4gICAgICBkZXNjcmlwdGlvbjogJ0N1cnJlbnQgZGF0YWJhc2Ugc3RhdGlzdGljcycsXG4gICAgICBtaW1lVHlwZTogJ2FwcGxpY2F0aW9uL2pzb24nLFxuICAgIH1dO1xuICB9XG5cbiAgLyoqXG4gICAqIFJlYWQgYSByZXNvdXJjZVxuICAgKi9cbiAgYXN5bmMgcmVhZFJlc291cmNlKHVyaTogc3RyaW5nKTogUHJvbWlzZTxNY3BSZXNvdXJjZUNvbnRlbnQgfCBudWxsPiB7XG4gICAgaWYgKHVyaSA9PT0gJ3NvY2hkYjovL3N0YXRzJykge1xuICAgICAgY29uc3Qgc3RhdHMgPSBhd2FpdCB0aGlzLmRiLnN0YXRzKCk7XG4gICAgICByZXR1cm4ge1xuICAgICAgICB1cmksXG4gICAgICAgIG1pbWVUeXBlOiAnYXBwbGljYXRpb24vanNvbicsXG4gICAgICAgIHRleHQ6IEpTT04uc3RyaW5naWZ5KHN0YXRzLCAoXywgdikgPT4gXG4gICAgICAgICAgdHlwZW9mIHYgPT09ICdiaWdpbnQnID8gdi50b1N0cmluZygpIDogdlxuICAgICAgICApLFxuICAgICAgfTtcbiAgICB9XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cblxuICAvKipcbiAgICogR2V0IHNlcnZlciBpbmZvXG4gICAqL1xuICBnZXRTZXJ2ZXJJbmZvKCk6IE1jcFNlcnZlckNvbmZpZyB7XG4gICAgcmV0dXJuIHsgLi4udGhpcy5jb25maWcgfTtcbiAgfVxufVxuIl19
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+ /**
3
+ * MCP (Model Context Protocol) Types
4
+ *
5
+ * Type definitions for Model Context Protocol integration with LLM agents.
6
+ */
7
+ Object.defineProperty(exports, "__esModule", { value: true });
8
+ exports.MCP_ERROR_CODES = exports.McpError = void 0;
9
+ /**
10
+ * MCP Error
11
+ */
12
+ class McpError extends Error {
13
+ code;
14
+ data;
15
+ constructor(message, code, data) {
16
+ super(message);
17
+ this.name = 'McpError';
18
+ this.code = code;
19
+ this.data = data;
20
+ }
21
+ }
22
+ exports.McpError = McpError;
23
+ // Error codes
24
+ exports.MCP_ERROR_CODES = {
25
+ PARSE_ERROR: -32700,
26
+ INVALID_REQUEST: -32600,
27
+ METHOD_NOT_FOUND: -32601,
28
+ INVALID_PARAMS: -32602,
29
+ INTERNAL_ERROR: -32603,
30
+ TOOL_NOT_FOUND: -32001,
31
+ RESOURCE_NOT_FOUND: -32002,
32
+ PROMPT_NOT_FOUND: -32003,
33
+ };
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbWNwL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7OztHQUlHOzs7QUFrSEg7O0dBRUc7QUFDSCxNQUFhLFFBQVMsU0FBUSxLQUFLO0lBQ2pDLElBQUksQ0FBUztJQUNiLElBQUksQ0FBTztJQUVYLFlBQVksT0FBZSxFQUFFLElBQVksRUFBRSxJQUFVO1FBQ25ELEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNmLElBQUksQ0FBQyxJQUFJLEdBQUcsVUFBVSxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO1FBQ2pCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO0lBQ25CLENBQUM7Q0FDRjtBQVZELDRCQVVDO0FBRUQsY0FBYztBQUNELFFBQUEsZUFBZSxHQUFHO0lBQzdCLFdBQVcsRUFBRSxDQUFDLEtBQUs7SUFDbkIsZUFBZSxFQUFFLENBQUMsS0FBSztJQUN2QixnQkFBZ0IsRUFBRSxDQUFDLEtBQUs7SUFDeEIsY0FBYyxFQUFFLENBQUMsS0FBSztJQUN0QixjQUFjLEVBQUUsQ0FBQyxLQUFLO0lBQ3RCLGNBQWMsRUFBRSxDQUFDLEtBQUs7SUFDdEIsa0JBQWtCLEVBQUUsQ0FBQyxLQUFLO0lBQzFCLGdCQUFnQixFQUFFLENBQUMsS0FBSztDQUNoQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBNQ1AgKE1vZGVsIENvbnRleHQgUHJvdG9jb2wpIFR5cGVzXG4gKiBcbiAqIFR5cGUgZGVmaW5pdGlvbnMgZm9yIE1vZGVsIENvbnRleHQgUHJvdG9jb2wgaW50ZWdyYXRpb24gd2l0aCBMTE0gYWdlbnRzLlxuICovXG5cbi8qKlxuICogTUNQIFRvb2wgZGVmaW5pdGlvblxuICovXG5leHBvcnQgaW50ZXJmYWNlIE1jcFRvb2wge1xuICBuYW1lOiBzdHJpbmc7XG4gIGRlc2NyaXB0aW9uOiBzdHJpbmc7XG4gIGlucHV0U2NoZW1hOiBSZWNvcmQ8c3RyaW5nLCBhbnk+O1xuICBvdXRwdXRTY2hlbWE/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+O1xufVxuXG4vKipcbiAqIE1DUCBUb29sIGNhbGwgcmVxdWVzdFxuICovXG5leHBvcnQgaW50ZXJmYWNlIE1jcFRvb2xDYWxsIHtcbiAgaWQ6IHN0cmluZztcbiAgbmFtZTogc3RyaW5nO1xuICBhcmd1bWVudHM6IFJlY29yZDxzdHJpbmcsIGFueT47XG59XG5cbi8qKlxuICogTUNQIFRvb2wgY2FsbCByZXN1bHRcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBNY3BUb29sUmVzdWx0IHtcbiAgaWQ6IHN0cmluZztcbiAgY29udGVudDogYW55O1xuICBpc0Vycm9yPzogYm9vbGVhbjtcbiAgZXJyb3JNZXNzYWdlPzogc3RyaW5nO1xufVxuXG4vKipcbiAqIE1DUCBSZXNvdXJjZSBkZWZpbml0aW9uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTWNwUmVzb3VyY2Uge1xuICB1cmk6IHN0cmluZztcbiAgbmFtZTogc3RyaW5nO1xuICBkZXNjcmlwdGlvbj86IHN0cmluZztcbiAgbWltZVR5cGU/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogTUNQIFJlc291cmNlIGNvbnRlbnRcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBNY3BSZXNvdXJjZUNvbnRlbnQge1xuICB1cmk6IHN0cmluZztcbiAgbWltZVR5cGU6IHN0cmluZztcbiAgdGV4dD86IHN0cmluZztcbiAgYmxvYj86IEJ1ZmZlcjtcbn1cblxuLyoqXG4gKiBNQ1AgUHJvbXB0IGRlZmluaXRpb25cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBNY3BQcm9tcHQge1xuICBuYW1lOiBzdHJpbmc7XG4gIGRlc2NyaXB0aW9uPzogc3RyaW5nO1xuICBhcmd1bWVudHM/OiBNY3BQcm9tcHRBcmd1bWVudFtdO1xufVxuXG4vKipcbiAqIE1DUCBQcm9tcHQgYXJndW1lbnRcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBNY3BQcm9tcHRBcmd1bWVudCB7XG4gIG5hbWU6IHN0cmluZztcbiAgZGVzY3JpcHRpb24/OiBzdHJpbmc7XG4gIHJlcXVpcmVkPzogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBNQ1AgUHJvbXB0IG1lc3NhZ2VcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBNY3BQcm9tcHRNZXNzYWdlIHtcbiAgcm9sZTogJ3VzZXInIHwgJ2Fzc2lzdGFudCcgfCAnc3lzdGVtJztcbiAgY29udGVudDogc3RyaW5nO1xufVxuXG4vKipcbiAqIE1DUCBTZXJ2ZXIgY2FwYWJpbGl0aWVzXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTWNwU2VydmVyQ2FwYWJpbGl0aWVzIHtcbiAgdG9vbHM/OiBib29sZWFuO1xuICByZXNvdXJjZXM/OiBib29sZWFuO1xuICBwcm9tcHRzPzogYm9vbGVhbjtcbiAgbG9nZ2luZz86IGJvb2xlYW47XG59XG5cbi8qKlxuICogTUNQIFNlcnZlciBjb25maWd1cmF0aW9uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTWNwU2VydmVyQ29uZmlnIHtcbiAgbmFtZTogc3RyaW5nO1xuICB2ZXJzaW9uOiBzdHJpbmc7XG4gIGNhcGFiaWxpdGllczogTWNwU2VydmVyQ2FwYWJpbGl0aWVzO1xufVxuXG4vKipcbiAqIE1DUCBDbGllbnQgY29uZmlndXJhdGlvblxuICovXG5leHBvcnQgaW50ZXJmYWNlIE1jcENsaWVudENvbmZpZyB7XG4gIHNlcnZlclVyaT86IHN0cmluZztcbiAgdHJhbnNwb3J0PzogJ3N0ZGlvJyB8ICdzc2UnIHwgJ3dlYnNvY2tldCc7XG4gIHRpbWVvdXQ/OiBudW1iZXI7XG59XG5cbi8qKlxuICogTUNQIFRyYW5zcG9ydCBpbnRlcmZhY2VcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBNY3BUcmFuc3BvcnQge1xuICBzZW5kKG1lc3NhZ2U6IGFueSk6IFByb21pc2U8dm9pZD47XG4gIHJlY2VpdmUoKTogQXN5bmNHZW5lcmF0b3I8YW55PjtcbiAgY2xvc2UoKTogUHJvbWlzZTx2b2lkPjtcbn1cblxuLyoqXG4gKiBNQ1AgRXJyb3JcbiAqL1xuZXhwb3J0IGNsYXNzIE1jcEVycm9yIGV4dGVuZHMgRXJyb3Ige1xuICBjb2RlOiBudW1iZXI7XG4gIGRhdGE/OiBhbnk7XG5cbiAgY29uc3RydWN0b3IobWVzc2FnZTogc3RyaW5nLCBjb2RlOiBudW1iZXIsIGRhdGE/OiBhbnkpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgICB0aGlzLm5hbWUgPSAnTWNwRXJyb3InO1xuICAgIHRoaXMuY29kZSA9IGNvZGU7XG4gICAgdGhpcy5kYXRhID0gZGF0YTtcbiAgfVxufVxuXG4vLyBFcnJvciBjb2Rlc1xuZXhwb3J0IGNvbnN0IE1DUF9FUlJPUl9DT0RFUyA9IHtcbiAgUEFSU0VfRVJST1I6IC0zMjcwMCxcbiAgSU5WQUxJRF9SRVFVRVNUOiAtMzI2MDAsXG4gIE1FVEhPRF9OT1RfRk9VTkQ6IC0zMjYwMSxcbiAgSU5WQUxJRF9QQVJBTVM6IC0zMjYwMixcbiAgSU5URVJOQUxfRVJST1I6IC0zMjYwMyxcbiAgVE9PTF9OT1RfRk9VTkQ6IC0zMjAwMSxcbiAgUkVTT1VSQ0VfTk9UX0ZPVU5EOiAtMzIwMDIsXG4gIFBST01QVF9OT1RfRk9VTkQ6IC0zMjAwMyxcbn0gYXMgY29uc3Q7XG4iXX0=