@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,242 @@
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
+ constructor(db, config) {
38
+ this.tools = new Map();
39
+ this.prompts = new Map();
40
+ this.customToolHandlers = new Map();
41
+ this.db = db;
42
+ this.config = config;
43
+ this.registerBuiltinTools();
44
+ }
45
+ /**
46
+ * Register built-in database tools
47
+ */
48
+ registerBuiltinTools() {
49
+ // Key-Value operations
50
+ this.registerTool({
51
+ name: 'db_get',
52
+ description: 'Get a value from the database by key',
53
+ inputSchema: {
54
+ type: 'object',
55
+ properties: {
56
+ key: { type: 'string', description: 'The key to retrieve' },
57
+ },
58
+ required: ['key'],
59
+ },
60
+ }, async (args) => {
61
+ const value = await this.db.get(Buffer.from(args.key));
62
+ return value ? value.toString() : null;
63
+ });
64
+ this.registerTool({
65
+ name: 'db_put',
66
+ description: 'Store a value in the database',
67
+ inputSchema: {
68
+ type: 'object',
69
+ properties: {
70
+ key: { type: 'string', description: 'The key to store' },
71
+ value: { type: 'string', description: 'The value to store' },
72
+ },
73
+ required: ['key', 'value'],
74
+ },
75
+ }, async (args) => {
76
+ await this.db.put(Buffer.from(args.key), Buffer.from(args.value));
77
+ return { success: true };
78
+ });
79
+ this.registerTool({
80
+ name: 'db_delete',
81
+ description: 'Delete a key from the database',
82
+ inputSchema: {
83
+ type: 'object',
84
+ properties: {
85
+ key: { type: 'string', description: 'The key to delete' },
86
+ },
87
+ required: ['key'],
88
+ },
89
+ }, async (args) => {
90
+ await this.db.delete(Buffer.from(args.key));
91
+ return { success: true };
92
+ });
93
+ this.registerTool({
94
+ name: 'db_scan',
95
+ description: 'Scan keys with a prefix',
96
+ inputSchema: {
97
+ type: 'object',
98
+ properties: {
99
+ prefix: { type: 'string', description: 'The prefix to scan' },
100
+ limit: { type: 'number', description: 'Maximum results', default: 100 },
101
+ },
102
+ required: ['prefix'],
103
+ },
104
+ }, async (args) => {
105
+ const results = [];
106
+ const limit = args.limit || 100;
107
+ let count = 0;
108
+ for await (const [keyBuffer, valueBuffer] of this.db.scanPrefix(Buffer.from(args.prefix))) {
109
+ if (count >= limit)
110
+ break;
111
+ results.push({
112
+ key: keyBuffer.toString(),
113
+ value: valueBuffer.toString(),
114
+ });
115
+ count++;
116
+ }
117
+ return results;
118
+ });
119
+ this.registerTool({
120
+ name: 'db_stats',
121
+ description: 'Get database statistics',
122
+ inputSchema: {
123
+ type: 'object',
124
+ properties: {},
125
+ },
126
+ }, async () => {
127
+ const stats = await this.db.stats();
128
+ return {
129
+ memtableSizeBytes: stats.memtableSizeBytes.toString(),
130
+ walSizeBytes: stats.walSizeBytes.toString(),
131
+ activeTransactions: stats.activeTransactions,
132
+ };
133
+ });
134
+ }
135
+ /**
136
+ * Register a custom tool
137
+ */
138
+ registerTool(tool, handler) {
139
+ this.tools.set(tool.name, tool);
140
+ this.customToolHandlers.set(tool.name, handler);
141
+ }
142
+ /**
143
+ * Unregister a tool
144
+ */
145
+ unregisterTool(name) {
146
+ this.customToolHandlers.delete(name);
147
+ return this.tools.delete(name);
148
+ }
149
+ /**
150
+ * List all available tools
151
+ */
152
+ listTools() {
153
+ return Array.from(this.tools.values());
154
+ }
155
+ /**
156
+ * Call a tool
157
+ */
158
+ async callTool(call) {
159
+ const handler = this.customToolHandlers.get(call.name);
160
+ if (!handler) {
161
+ return {
162
+ id: call.id,
163
+ content: null,
164
+ isError: true,
165
+ errorMessage: `Tool not found: ${call.name}`,
166
+ };
167
+ }
168
+ try {
169
+ const content = await handler(call.arguments);
170
+ return {
171
+ id: call.id,
172
+ content,
173
+ isError: false,
174
+ };
175
+ }
176
+ catch (error) {
177
+ return {
178
+ id: call.id,
179
+ content: null,
180
+ isError: true,
181
+ errorMessage: error.message || 'Unknown error',
182
+ };
183
+ }
184
+ }
185
+ /**
186
+ * Register a prompt template
187
+ */
188
+ registerPrompt(prompt) {
189
+ this.prompts.set(prompt.name, prompt);
190
+ }
191
+ /**
192
+ * List all available prompts
193
+ */
194
+ listPrompts() {
195
+ return Array.from(this.prompts.values());
196
+ }
197
+ /**
198
+ * Get prompt messages
199
+ */
200
+ getPrompt(name, args) {
201
+ const prompt = this.prompts.get(name);
202
+ if (!prompt) {
203
+ return null;
204
+ }
205
+ // For now, return empty messages - actual implementation would render the prompt
206
+ return [];
207
+ }
208
+ /**
209
+ * List available resources
210
+ */
211
+ async listResources() {
212
+ // Return database stats as a resource
213
+ return [{
214
+ uri: 'sochdb://stats',
215
+ name: 'Database Statistics',
216
+ description: 'Current database statistics',
217
+ mimeType: 'application/json',
218
+ }];
219
+ }
220
+ /**
221
+ * Read a resource
222
+ */
223
+ async readResource(uri) {
224
+ if (uri === 'sochdb://stats') {
225
+ const stats = await this.db.stats();
226
+ return {
227
+ uri,
228
+ mimeType: 'application/json',
229
+ text: JSON.stringify(stats, (_, v) => typeof v === 'bigint' ? v.toString() : v),
230
+ };
231
+ }
232
+ return null;
233
+ }
234
+ /**
235
+ * Get server info
236
+ */
237
+ getServerInfo() {
238
+ return { ...this.config };
239
+ }
240
+ }
241
+ exports.McpServer = McpServer;
242
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VydmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL21jcC9zZXJ2ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7O0dBSUc7OztBQWlCSDs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0EwQkc7QUFDSCxNQUFhLFNBQVM7SUFPcEIsWUFBWSxFQUFvQixFQUFFLE1BQXVCO1FBSmpELFVBQUssR0FBeUIsSUFBSSxHQUFHLEVBQUUsQ0FBQztRQUN4QyxZQUFPLEdBQTJCLElBQUksR0FBRyxFQUFFLENBQUM7UUFDNUMsdUJBQWtCLEdBQTZELElBQUksR0FBRyxFQUFFLENBQUM7UUFHL0YsSUFBSSxDQUFDLEVBQUUsR0FBRyxFQUFFLENBQUM7UUFDYixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUNyQixJQUFJLENBQUMsb0JBQW9CLEVBQUUsQ0FBQztJQUM5QixDQUFDO0lBRUQ7O09BRUc7SUFDSyxvQkFBb0I7UUFDMUIsdUJBQXVCO1FBQ3ZCLElBQUksQ0FBQyxZQUFZLENBQUM7WUFDaEIsSUFBSSxFQUFFLFFBQVE7WUFDZCxXQUFXLEVBQUUsc0NBQXNDO1lBQ25ELFdBQVcsRUFBRTtnQkFDWCxJQUFJLEVBQUUsUUFBUTtnQkFDZCxVQUFVLEVBQUU7b0JBQ1YsR0FBRyxFQUFFLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRSxXQUFXLEVBQUUscUJBQXFCLEVBQUU7aUJBQzVEO2dCQUNELFFBQVEsRUFBRSxDQUFDLEtBQUssQ0FBQzthQUNsQjtTQUNGLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxFQUFFO1lBQ2hCLE1BQU0sS0FBSyxHQUFHLE1BQU0sSUFBSSxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztZQUN2RCxPQUFPLEtBQUssQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDLENB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QUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3RDLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNaLE9BQU8sSUFBSSxDQUFDO1FBQ2QsQ0FBQztRQUVELGlGQUFpRjtRQUNqRixPQUFPLEVBQUUsQ0FBQztJQUNaLENBQUM7SUFFRDs7T0FFRztJQUNILEtBQUssQ0FBQyxhQUFhO1FBQ2pCLHNDQUFzQztRQUN0QyxPQUFPLENBQUM7Z0JBQ04sR0FBRyxFQUFFLGdCQUFnQjtnQkFDckIsSUFBSSxFQUFFLHFCQUFxQjtnQkFDM0IsV0FBVyxFQUFFLDZCQUE2QjtnQkFDMUMsUUFBUSxFQUFFLGtCQUFrQjthQUM3QixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQ7O09BRUc7SUFDSCxLQUFLLENBQUMsWUFBWSxDQUFDLEdBQVc7UUFDNUIsSUFBSSxHQUFHLEtBQUssZ0JBQWdCLEVBQUUsQ0FBQztZQUM3QixNQUFNLEtBQUssR0FBRyxNQUFNLElBQUksQ0FBQyxFQUFFLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDcEMsT0FBTztnQkFDTCxHQUFHO2dCQUNILFFBQVEsRUFBRSxrQkFBa0I7Z0JBQzVCLElBQUksRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUNuQyxPQUFPLENBQUMsS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUN6QzthQUNGLENBQUM7UUFDSixDQUFDO1FBQ0QsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQ7O09BRUc7SUFDSCxhQUFhO1FBQ1gsT0FBTyxFQUFFLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO0lBQzVCLENBQUM7Q0FDRjtBQXRPRCw4QkFzT0MiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIE1DUCBTZXJ2ZXIgSW1wbGVtZW50YXRpb25cbiAqIFxuICogU29jaERCIE1DUCBTZXJ2ZXIgZm9yIGV4cG9zaW5nIGRhdGFiYXNlIG9wZXJhdGlvbnMgdG8gTExNIGFnZW50cy5cbiAqL1xuXG5pbXBvcnQgeyBFbWJlZGRlZERhdGFiYXNlIH0gZnJvbSAnLi4vZW1iZWRkZWQnO1xuaW1wb3J0IHtcbiAgTWNwVG9vbCxcbiAgTWNwVG9vbENhbGwsXG4gIE1jcFRvb2xSZXN1bHQsXG4gIE1jcFJlc291cmNlLFxuICBNY3BSZXNvdXJjZUNvbnRlbnQsXG4gIE1jcFByb21wdCxcbiAgTWNwUHJvbXB0TWVzc2FnZSxcbiAgTWNwU2VydmVyQ29uZmlnLFxuICBNY3BTZXJ2ZXJDYXBhYmlsaXRpZXMsXG4gIE1jcEVycm9yLFxuICBNQ1BfRVJST1JfQ09ERVMsXG59IGZyb20gJy4vdHlwZXMnO1xuXG4vKipcbiAqIE1DUCBTZXJ2ZXIgZm9yIFNvY2hEQlxuICogXG4gKiBFeHBvc2VzIGRhdGFiYXNlIG9wZXJhdGlvbnMgYXMgTUNQIHRvb2xzIGZvciBMTE0gYWdlbnRzLlxuICogXG4gKiBAZXhhbXBsZVxuICogYGBgdHlwZXNjcmlwdFxuICogaW1wb3J0IHsgRW1iZWRkZWREYXRhYmFzZSwgTWNwU2VydmVyIH0gZnJvbSAnQHNvY2hkYi9zb2NoZGInO1xuICogXG4gKiBjb25zdCBkYiA9IEVtYmVkZGVkRGF0YWJhc2Uub3BlbignLi9teWRiJyk7XG4gKiBjb25zdCBzZXJ2ZXIgPSBuZXcgTWNwU2VydmVyKGRiLCB7XG4gKiAgIG5hbWU6ICdzb2NoZGItbWNwJyxcbiAqICAgdmVyc2lvbjogJzEuMC4wJyxcbiAqICAgY2FwYWJpbGl0aWVzOiB7IHRvb2xzOiB0cnVlLCByZXNvdXJjZXM6IHRydWUgfVxuICogfSk7XG4gKiBcbiAqIC8vIExpc3QgYXZhaWxhYmxlIHRvb2xzXG4gKiBjb25zdCB0b29scyA9IHNlcnZlci5saXN0VG9vbHMoKTtcbiAqIFxuICogLy8gRXhlY3V0ZSBhIHRvb2wgY2FsbFxuICogY29uc3QgcmVzdWx0ID0gYXdhaXQgc2VydmVyLmNhbGxUb29sKHtcbiAqICAgaWQ6ICdjYWxsXzEnLFxuICogICBuYW1lOiAnZGJfZ2V0JyxcbiAqICAgYXJndW1lbnRzOiB7IGtleTogJ3VzZXI6MTIzJyB9XG4gKiB9KTtcbiAqIGBgYFxuICovXG5leHBvcnQgY2xhc3MgTWNwU2VydmVyIHtcbiAgcHJpdmF0ZSBkYjogRW1iZWRkZWREYXRhYmFzZTtcbiAgcHJpdmF0ZSBjb25maWc6IE1jcFNlcnZlckNvbmZpZztcbiAgcHJpdmF0ZSB0b29sczogTWFwPHN0cmluZywgTWNwVG9vbD4gPSBuZXcgTWFwKCk7XG4gIHByaXZhdGUgcHJvbXB0czogTWFwPHN0cmluZywgTWNwUHJvbXB0PiA9IG5ldyBNYXAoKTtcbiAgcHJpdmF0ZSBjdXN0b21Ub29sSGFuZGxlcnM6IE1hcDxzdHJpbmcsIChhcmdzOiBSZWNvcmQ8c3RyaW5nLCBhbnk+KSA9PiBQcm9taXNlPGFueT4+ID0gbmV3IE1hcCgpO1xuXG4gIGNvbnN0cnVjdG9yKGRiOiBFbWJlZGRlZERhdGFiYXNlLCBjb25maWc6IE1jcFNlcnZlckNvbmZpZykge1xuICAgIHRoaXMuZGIgPSBkYjtcbiAgICB0aGlzLmNvbmZpZyA9IGNvbmZpZztcbiAgICB0aGlzLnJlZ2lzdGVyQnVpbHRpblRvb2xzKCk7XG4gIH1cblxuICAvKipcbiAgICogUmVnaXN0ZXIgYnVpbHQtaW4gZGF0YWJhc2UgdG9vbHNcbiAgICovXG4gIHByaXZhdGUgcmVnaXN0ZXJCdWlsdGluVG9vbHMoKTogdm9pZCB7XG4gICAgLy8gS2V5LVZhbHVlIG9wZXJhdGlvbnNcbiAgICB0aGlzLnJlZ2lzdGVyVG9vbCh7XG4gICAgICBuYW1lOiAnZGJfZ2V0JyxcbiAgICAgIGRlc2NyaXB0aW9uOiAnR2V0IGEgdmFsdWUgZnJvbSB0aGUgZGF0YWJhc2UgYnkga2V5JyxcbiAgICAgIGlucHV0U2NoZW1hOiB7XG4gICAgICAgIHR5cGU6ICdvYmplY3QnLFxuICAgICAgICBwcm9wZXJ0aWVzOiB7XG4gICAgICAgICAga2V5OiB7IHR5cGU6ICdzdHJpbmcnLCBkZXNjcmlwdGlvbjogJ1RoZSBrZXkgdG8gcmV0cmlldmUnIH0sXG4gICAgICAgIH0sXG4gICAgICAgIHJlcXVpcmVkOiBbJ2tleSddLFxuICAgICAgfSxcbiAgICB9LCBhc3luYyAoYXJncykgPT4ge1xuICAgICAgY29uc3QgdmFsdWUgPSBhd2FpdCB0aGlzLmRiLmdldChCdWZmZXIuZnJvbShhcmdzLmtleSkpO1xuICAgICAgcmV0dXJuIHZhbHVlID8gdmFsdWUudG9TdHJpbmcoKSA6IG51bGw7XG4gICAgfSk7XG5cbiAgICB0aGlzLnJlZ2lzdGVyVG9vbCh7XG4gICAgICBuYW1lOiAnZGJfcHV0JyxcbiAgICAgIGRlc2NyaXB0aW9uOiAnU3RvcmUgYSB2YWx1ZSBpbiB0aGUgZGF0YWJhc2UnLFxuICAgICAgaW5wdXRTY2hlbWE6IHtcbiAgICAgICAgdHlwZTogJ29iamVjdCcsXG4gICAgICAgIHByb3BlcnRpZXM6IHtcbiAgICAgICAgICBrZXk6IHsgdHlwZTogJ3N0cmluZycsIGRlc2NyaXB0aW9uOiAnVGhlIGtleSB0byBzdG9yZScgfSxcbiAgICAgICAgICB2YWx1ZTogeyB0eXBlOiAnc3RyaW5nJywgZGVzY3JpcHRpb246ICdUaGUgdmFsdWUgdG8gc3RvcmUnIH0sXG4gICAgICAgIH0sXG4gICAgICAgIHJlcXVpcmVkOiBbJ2tleScsICd2YWx1ZSddLFxuICAgICAgfSxcbiAgICB9LCBhc3luYyAoYXJncykgPT4ge1xuICAgICAgYXdhaXQgdGhpcy5kYi5wdXQoQnVmZmVyLmZyb20oYXJncy5rZXkpLCBCdWZmZXIuZnJvbShhcmdzLnZhbHVlKSk7XG4gICAgICByZXR1cm4geyBzdWNjZXNzOiB0cnVlIH07XG4gICAgfSk7XG5cbiAgICB0aGlzLnJlZ2lzdGVyVG9vbCh7XG4gICAgICBuYW1lOiAnZGJfZGVsZXRlJyxcbiAgICAgIGRlc2NyaXB0aW9uOiAnRGVsZXRlIGEga2V5IGZyb20gdGhlIGRhdGFiYXNlJyxcbiAgICAgIGlucHV0U2NoZW1hOiB7XG4gICAgICAgIHR5cGU6ICdvYmplY3QnLFxuICAgICAgICBwcm9wZXJ0aWVzOiB7XG4gICAgICAgICAga2V5OiB7IHR5cGU6ICdzdHJpbmcnLCBkZXNjcmlwdGlvbjogJ1RoZSBrZXkgdG8gZGVsZXRlJyB9LFxuICAgICAgICB9LFxuICAgICAgICByZXF1aXJlZDogWydrZXknXSxcbiAgICAgIH0sXG4gICAgfSwgYXN5bmMgKGFyZ3MpID0+IHtcbiAgICAgIGF3YWl0IHRoaXMuZGIuZGVsZXRlKEJ1ZmZlci5mcm9tKGFyZ3Mua2V5KSk7XG4gICAgICByZXR1cm4geyBzdWNjZXNzOiB0cnVlIH07XG4gICAgfSk7XG5cbiAgICB0aGlzLnJlZ2lzdGVyVG9vbCh7XG4gICAgICBuYW1lOiAnZGJfc2NhbicsXG4gICAgICBkZXNjcmlwdGlvbjogJ1NjYW4ga2V5cyB3aXRoIGEgcHJlZml4JyxcbiAgICAgIGlucHV0U2NoZW1hOiB7XG4gICAgICAgIHR5cGU6ICdvYmplY3QnLFxuICAgICAgICBwcm9wZXJ0aWVzOiB7XG4gICAgICAgICAgcHJlZml4OiB7IHR5cGU6ICdzdHJpbmcnLCBkZXNjcmlwdGlvbjogJ1RoZSBwcmVmaXggdG8gc2NhbicgfSxcbiAgICAgICAgICBsaW1pdDogeyB0eXBlOiAnbnVtYmVyJywgZGVzY3JpcHRpb246ICdNYXhpbXVtIHJlc3VsdHMnLCBkZWZhdWx0OiAxMDAgfSxcbiAgICAgICAgfSxcbiAgICAgICAgcmVxdWlyZWQ6IFsncHJlZml4J10sXG4gICAgICB9LFxuICAgIH0sIGFzeW5jIChhcmdzKSA9PiB7XG4gICAgICBjb25zdCByZXN1bHRzOiBBcnJheTx7IGtleTogc3RyaW5nOyB2YWx1ZTogc3RyaW5nIH0+ID0gW107XG4gICAgICBjb25zdCBsaW1pdCA9IGFyZ3MubGltaXQgfHwgMTAwO1xuICAgICAgbGV0IGNvdW50ID0gMDtcblxuICAgICAgZm9yIGF3YWl0IChjb25zdCBba2V5QnVmZmVyLCB2YWx1ZUJ1ZmZlcl0gb2YgdGhpcy5kYi5zY2FuUHJlZml4KEJ1ZmZlci5mcm9tKGFyZ3MucHJlZml4KSkpIHtcbiAgICAgICAgaWYgKGNvdW50ID49IGxpbWl0KSBicmVhaztcbiAgICAgICAgcmVzdWx0cy5wdXNoKHtcbiAgICAgICAgICBrZXk6IGtleUJ1ZmZlci50b1N0cmluZygpLFxuICAgICAgICAgIHZhbHVlOiB2YWx1ZUJ1ZmZlci50b1N0cmluZygpLFxuICAgICAgICB9KTtcbiAgICAgICAgY291bnQrKztcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHJlc3VsdHM7XG4gICAgfSk7XG5cbiAgICB0aGlzLnJlZ2lzdGVyVG9vbCh7XG4gICAgICBuYW1lOiAnZGJfc3RhdHMnLFxuICAgICAgZGVzY3JpcHRpb246ICdHZXQgZGF0YWJhc2Ugc3RhdGlzdGljcycsXG4gICAgICBpbnB1dFNjaGVtYToge1xuICAgICAgICB0eXBlOiAnb2JqZWN0JyxcbiAgICAgICAgcHJvcGVydGllczoge30sXG4gICAgICB9LFxuICAgIH0sIGFzeW5jICgpID0+IHtcbiAgICAgIGNvbnN0IHN0YXRzID0gYXdhaXQgdGhpcy5kYi5zdGF0cygpO1xuICAgICAgcmV0dXJuIHtcbiAgICAgICAgbWVtdGFibGVTaXplQnl0ZXM6IHN0YXRzLm1lbXRhYmxlU2l6ZUJ5dGVzLnRvU3RyaW5nKCksXG4gICAgICAgIHdhbFNpemVCeXRlczogc3RhdHMud2FsU2l6ZUJ5dGVzLnRvU3RyaW5nKCksXG4gICAgICAgIGFjdGl2ZVRyYW5zYWN0aW9uczogc3RhdHMuYWN0aXZlVHJhbnNhY3Rpb25zLFxuICAgICAgfTtcbiAgICB9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZWdpc3RlciBhIGN1c3RvbSB0b29sXG4gICAqL1xuICByZWdpc3RlclRvb2woXG4gICAgdG9vbDogTWNwVG9vbCxcbiAgICBoYW5kbGVyOiAoYXJnczogUmVjb3JkPHN0cmluZywgYW55PikgPT4gUHJvbWlzZTxhbnk+XG4gICk6IHZvaWQge1xuICAgIHRoaXMudG9vbHMuc2V0KHRvb2wubmFtZSwgdG9vbCk7XG4gICAgdGhpcy5jdXN0b21Ub29sSGFuZGxlcnMuc2V0KHRvb2wubmFtZSwgaGFuZGxlcik7XG4gIH1cblxuICAvKipcbiAgICogVW5yZWdpc3RlciBhIHRvb2xcbiAgICovXG4gIHVucmVnaXN0ZXJUb29sKG5hbWU6IHN0cmluZyk6IGJvb2xlYW4ge1xuICAgIHRoaXMuY3VzdG9tVG9vbEhhbmRsZXJzLmRlbGV0ZShuYW1lKTtcbiAgICByZXR1cm4gdGhpcy50b29scy5kZWxldGUobmFtZSk7XG4gIH1cblxuICAvKipcbiAgICogTGlzdCBhbGwgYXZhaWxhYmxlIHRvb2xzXG4gICAqL1xuICBsaXN0VG9vbHMoKTogTWNwVG9vbFtdIHtcbiAgICByZXR1cm4gQXJyYXkuZnJvbSh0aGlzLnRvb2xzLnZhbHVlcygpKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDYWxsIGEgdG9vbFxuICAgKi9cbiAgYXN5bmMgY2FsbFRvb2woY2FsbDogTWNwVG9vbENhbGwpOiBQcm9taXNlPE1jcFRvb2xSZXN1bHQ+IHtcbiAgICBjb25zdCBoYW5kbGVyID0gdGhpcy5jdXN0b21Ub29sSGFuZGxlcnMuZ2V0KGNhbGwubmFtZSk7XG4gICAgXG4gICAgaWYgKCFoYW5kbGVyKSB7XG4gICAgICByZXR1cm4ge1xuICAgICAgICBpZDogY2FsbC5pZCxcbiAgICAgICAgY29udGVudDogbnVsbCxcbiAgICAgICAgaXNFcnJvcjogdHJ1ZSxcbiAgICAgICAgZXJyb3JNZXNzYWdlOiBgVG9vbCBub3QgZm91bmQ6ICR7Y2FsbC5uYW1lfWAsXG4gICAgICB9O1xuICAgIH1cblxuICAgIHRyeSB7XG4gICAgICBjb25zdCBjb250ZW50ID0gYXdhaXQgaGFuZGxlcihjYWxsLmFyZ3VtZW50cyk7XG4gICAgICByZXR1cm4ge1xuICAgICAgICBpZDogY2FsbC5pZCxcbiAgICAgICAgY29udGVudCxcbiAgICAgICAgaXNFcnJvcjogZmFsc2UsXG4gICAgICB9O1xuICAgIH0gY2F0Y2ggKGVycm9yOiBhbnkpIHtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIGlkOiBjYWxsLmlkLFxuICAgICAgICBjb250ZW50OiBudWxsLFxuICAgICAgICBpc0Vycm9yOiB0cnVlLFxuICAgICAgICBlcnJvck1lc3NhZ2U6IGVycm9yLm1lc3NhZ2UgfHwgJ1Vua25vd24gZXJyb3InLFxuICAgICAgfTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogUmVnaXN0ZXIgYSBwcm9tcHQgdGVtcGxhdGVcbiAgICovXG4gIHJlZ2lzdGVyUHJvbXB0KHByb21wdDogTWNwUHJvbXB0KTogdm9pZCB7XG4gICAgdGhpcy5wcm9tcHRzLnNldChwcm9tcHQubmFtZSwgcHJvbXB0KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBMaXN0IGFsbCBhdmFpbGFibGUgcHJvbXB0c1xuICAgKi9cbiAgbGlzdFByb21wdHMoKTogTWNwUHJvbXB0W10ge1xuICAgIHJldHVybiBBcnJheS5mcm9tKHRoaXMucHJvbXB0cy52YWx1ZXMoKSk7XG4gIH1cblxuICAvKipcbiAgICogR2V0IHByb21wdCBtZXNzYWdlc1xuICAgKi9cbiAgZ2V0UHJvbXB0KG5hbWU6IHN0cmluZywgYXJncz86IFJlY29yZDxzdHJpbmcsIGFueT4pOiBNY3BQcm9tcHRNZXNzYWdlW10gfCBudWxsIHtcbiAgICBjb25zdCBwcm9tcHQgPSB0aGlzLnByb21wdHMuZ2V0KG5hbWUpO1xuICAgIGlmICghcHJvbXB0KSB7XG4gICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG5cbiAgICAvLyBGb3Igbm93LCByZXR1cm4gZW1wdHkgbWVzc2FnZXMgLSBhY3R1YWwgaW1wbGVtZW50YXRpb24gd291bGQgcmVuZGVyIHRoZSBwcm9tcHRcbiAgICByZXR1cm4gW107XG4gIH1cblxuICAvKipcbiAgICogTGlzdCBhdmFpbGFibGUgcmVzb3VyY2VzXG4gICAqL1xuICBhc3luYyBsaXN0UmVzb3VyY2VzKCk6IFByb21pc2U8TWNwUmVzb3VyY2VbXT4ge1xuICAgIC8vIFJldHVybiBkYXRhYmFzZSBzdGF0cyBhcyBhIHJlc291cmNlXG4gICAgcmV0dXJuIFt7XG4gICAgICB1cmk6ICdzb2NoZGI6Ly9zdGF0cycsXG4gICAgICBuYW1lOiAnRGF0YWJhc2UgU3RhdGlzdGljcycsXG4gICAgICBkZXNjcmlwdGlvbjogJ0N1cnJlbnQgZGF0YWJhc2Ugc3RhdGlzdGljcycsXG4gICAgICBtaW1lVHlwZTogJ2FwcGxpY2F0aW9uL2pzb24nLFxuICAgIH1dO1xuICB9XG5cbiAgLyoqXG4gICAqIFJlYWQgYSByZXNvdXJjZVxuICAgKi9cbiAgYXN5bmMgcmVhZFJlc291cmNlKHVyaTogc3RyaW5nKTogUHJvbWlzZTxNY3BSZXNvdXJjZUNvbnRlbnQgfCBudWxsPiB7XG4gICAgaWYgKHVyaSA9PT0gJ3NvY2hkYjovL3N0YXRzJykge1xuICAgICAgY29uc3Qgc3RhdHMgPSBhd2FpdCB0aGlzLmRiLnN0YXRzKCk7XG4gICAgICByZXR1cm4ge1xuICAgICAgICB1cmksXG4gICAgICAgIG1pbWVUeXBlOiAnYXBwbGljYXRpb24vanNvbicsXG4gICAgICAgIHRleHQ6IEpTT04uc3RyaW5naWZ5KHN0YXRzLCAoXywgdikgPT4gXG4gICAgICAgICAgdHlwZW9mIHYgPT09ICdiaWdpbnQnID8gdi50b1N0cmluZygpIDogdlxuICAgICAgICApLFxuICAgICAgfTtcbiAgICB9XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cblxuICAvKipcbiAgICogR2V0IHNlcnZlciBpbmZvXG4gICAqL1xuICBnZXRTZXJ2ZXJJbmZvKCk6IE1jcFNlcnZlckNvbmZpZyB7XG4gICAgcmV0dXJuIHsgLi4udGhpcy5jb25maWcgfTtcbiAgfVxufVxuIl19
@@ -0,0 +1,32 @@
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
+ constructor(message, code, data) {
14
+ super(message);
15
+ this.name = 'McpError';
16
+ this.code = code;
17
+ this.data = data;
18
+ }
19
+ }
20
+ exports.McpError = McpError;
21
+ // Error codes
22
+ exports.MCP_ERROR_CODES = {
23
+ PARSE_ERROR: -32700,
24
+ INVALID_REQUEST: -32600,
25
+ METHOD_NOT_FOUND: -32601,
26
+ INVALID_PARAMS: -32602,
27
+ INTERNAL_ERROR: -32603,
28
+ TOOL_NOT_FOUND: -32001,
29
+ RESOURCE_NOT_FOUND: -32002,
30
+ PROMPT_NOT_FOUND: -32003,
31
+ };
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbWNwL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7OztHQUlHOzs7QUFrSEg7O0dBRUc7QUFDSCxNQUFhLFFBQVMsU0FBUSxLQUFLO0lBSWpDLFlBQVksT0FBZSxFQUFFLElBQVksRUFBRSxJQUFVO1FBQ25ELEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNmLElBQUksQ0FBQyxJQUFJLEdBQUcsVUFBVSxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO1FBQ2pCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO0lBQ25CLENBQUM7Q0FDRjtBQVZELDRCQVVDO0FBRUQsY0FBYztBQUNELFFBQUEsZUFBZSxHQUFHO0lBQzdCLFdBQVcsRUFBRSxDQUFDLEtBQUs7SUFDbkIsZUFBZSxFQUFFLENBQUMsS0FBSztJQUN2QixnQkFBZ0IsRUFBRSxDQUFDLEtBQUs7SUFDeEIsY0FBYyxFQUFFLENBQUMsS0FBSztJQUN0QixjQUFjLEVBQUUsQ0FBQyxLQUFLO0lBQ3RCLGNBQWMsRUFBRSxDQUFDLEtBQUs7SUFDdEIsa0JBQWtCLEVBQUUsQ0FBQyxLQUFLO0lBQzFCLGdCQUFnQixFQUFFLENBQUMsS0FBSztDQUNoQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBNQ1AgKE1vZGVsIENvbnRleHQgUHJvdG9jb2wpIFR5cGVzXG4gKiBcbiAqIFR5cGUgZGVmaW5pdGlvbnMgZm9yIE1vZGVsIENvbnRleHQgUHJvdG9jb2wgaW50ZWdyYXRpb24gd2l0aCBMTE0gYWdlbnRzLlxuICovXG5cbi8qKlxuICogTUNQIFRvb2wgZGVmaW5pdGlvblxuICovXG5leHBvcnQgaW50ZXJmYWNlIE1jcFRvb2wge1xuICBuYW1lOiBzdHJpbmc7XG4gIGRlc2NyaXB0aW9uOiBzdHJpbmc7XG4gIGlucHV0U2NoZW1hOiBSZWNvcmQ8c3RyaW5nLCBhbnk+O1xuICBvdXRwdXRTY2hlbWE/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+O1xufVxuXG4vKipcbiAqIE1DUCBUb29sIGNhbGwgcmVxdWVzdFxuICovXG5leHBvcnQgaW50ZXJmYWNlIE1jcFRvb2xDYWxsIHtcbiAgaWQ6IHN0cmluZztcbiAgbmFtZTogc3RyaW5nO1xuICBhcmd1bWVudHM6IFJlY29yZDxzdHJpbmcsIGFueT47XG59XG5cbi8qKlxuICogTUNQIFRvb2wgY2FsbCByZXN1bHRcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBNY3BUb29sUmVzdWx0IHtcbiAgaWQ6IHN0cmluZztcbiAgY29udGVudDogYW55O1xuICBpc0Vycm9yPzogYm9vbGVhbjtcbiAgZXJyb3JNZXNzYWdlPzogc3RyaW5nO1xufVxuXG4vKipcbiAqIE1DUCBSZXNvdXJjZSBkZWZpbml0aW9uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTWNwUmVzb3VyY2Uge1xuICB1cmk6IHN0cmluZztcbiAgbmFtZTogc3RyaW5nO1xuICBkZXNjcmlwdGlvbj86IHN0cmluZztcbiAgbWltZVR5cGU/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogTUNQIFJlc291cmNlIGNvbnRlbnRcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBNY3BSZXNvdXJjZUNvbnRlbnQge1xuICB1cmk6IHN0cmluZztcbiAgbWltZVR5cGU6IHN0cmluZztcbiAgdGV4dD86IHN0cmluZztcbiAgYmxvYj86IEJ1ZmZlcjtcbn1cblxuLyoqXG4gKiBNQ1AgUHJvbXB0IGRlZmluaXRpb25cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBNY3BQcm9tcHQge1xuICBuYW1lOiBzdHJpbmc7XG4gIGRlc2NyaXB0aW9uPzogc3RyaW5nO1xuICBhcmd1bWVudHM/OiBNY3BQcm9tcHRBcmd1bWVudFtdO1xufVxuXG4vKipcbiAqIE1DUCBQcm9tcHQgYXJndW1lbnRcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBNY3BQcm9tcHRBcmd1bWVudCB7XG4gIG5hbWU6IHN0cmluZztcbiAgZGVzY3JpcHRpb24/OiBzdHJpbmc7XG4gIHJlcXVpcmVkPzogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBNQ1AgUHJvbXB0IG1lc3NhZ2VcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBNY3BQcm9tcHRNZXNzYWdlIHtcbiAgcm9sZTogJ3VzZXInIHwgJ2Fzc2lzdGFudCcgfCAnc3lzdGVtJztcbiAgY29udGVudDogc3RyaW5nO1xufVxuXG4vKipcbiAqIE1DUCBTZXJ2ZXIgY2FwYWJpbGl0aWVzXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTWNwU2VydmVyQ2FwYWJpbGl0aWVzIHtcbiAgdG9vbHM/OiBib29sZWFuO1xuICByZXNvdXJjZXM/OiBib29sZWFuO1xuICBwcm9tcHRzPzogYm9vbGVhbjtcbiAgbG9nZ2luZz86IGJvb2xlYW47XG59XG5cbi8qKlxuICogTUNQIFNlcnZlciBjb25maWd1cmF0aW9uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTWNwU2VydmVyQ29uZmlnIHtcbiAgbmFtZTogc3RyaW5nO1xuICB2ZXJzaW9uOiBzdHJpbmc7XG4gIGNhcGFiaWxpdGllczogTWNwU2VydmVyQ2FwYWJpbGl0aWVzO1xufVxuXG4vKipcbiAqIE1DUCBDbGllbnQgY29uZmlndXJhdGlvblxuICovXG5leHBvcnQgaW50ZXJmYWNlIE1jcENsaWVudENvbmZpZyB7XG4gIHNlcnZlclVyaT86IHN0cmluZztcbiAgdHJhbnNwb3J0PzogJ3N0ZGlvJyB8ICdzc2UnIHwgJ3dlYnNvY2tldCc7XG4gIHRpbWVvdXQ/OiBudW1iZXI7XG59XG5cbi8qKlxuICogTUNQIFRyYW5zcG9ydCBpbnRlcmZhY2VcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBNY3BUcmFuc3BvcnQge1xuICBzZW5kKG1lc3NhZ2U6IGFueSk6IFByb21pc2U8dm9pZD47XG4gIHJlY2VpdmUoKTogQXN5bmNHZW5lcmF0b3I8YW55PjtcbiAgY2xvc2UoKTogUHJvbWlzZTx2b2lkPjtcbn1cblxuLyoqXG4gKiBNQ1AgRXJyb3JcbiAqL1xuZXhwb3J0IGNsYXNzIE1jcEVycm9yIGV4dGVuZHMgRXJyb3Ige1xuICBjb2RlOiBudW1iZXI7XG4gIGRhdGE/OiBhbnk7XG5cbiAgY29uc3RydWN0b3IobWVzc2FnZTogc3RyaW5nLCBjb2RlOiBudW1iZXIsIGRhdGE/OiBhbnkpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgICB0aGlzLm5hbWUgPSAnTWNwRXJyb3InO1xuICAgIHRoaXMuY29kZSA9IGNvZGU7XG4gICAgdGhpcy5kYXRhID0gZGF0YTtcbiAgfVxufVxuXG4vLyBFcnJvciBjb2Rlc1xuZXhwb3J0IGNvbnN0IE1DUF9FUlJPUl9DT0RFUyA9IHtcbiAgUEFSU0VfRVJST1I6IC0zMjcwMCxcbiAgSU5WQUxJRF9SRVFVRVNUOiAtMzI2MDAsXG4gIE1FVEhPRF9OT1RfRk9VTkQ6IC0zMjYwMSxcbiAgSU5WQUxJRF9QQVJBTVM6IC0zMjYwMixcbiAgSU5URVJOQUxfRVJST1I6IC0zMjYwMyxcbiAgVE9PTF9OT1RfRk9VTkQ6IC0zMjAwMSxcbiAgUkVTT1VSQ0VfTk9UX0ZPVU5EOiAtMzIwMDIsXG4gIFBST01QVF9OT1RfRk9VTkQ6IC0zMjAwMyxcbn0gYXMgY29uc3Q7XG4iXX0=
@@ -58,15 +58,110 @@ var DistanceMetric;
58
58
  // ============================================================================
59
59
  // Collection Handle
60
60
  // ============================================================================
61
+ /**
62
+ * In-memory vector index for synchronous search
63
+ * Uses a simple but efficient approach for small-medium datasets
64
+ */
65
+ class VectorIndex {
66
+ constructor(dimension, metric = DistanceMetric.Cosine) {
67
+ this.vectors = new Map();
68
+ this.dimension = dimension;
69
+ this.metric = metric;
70
+ }
71
+ add(id, vector, metadata) {
72
+ if (vector.length !== this.dimension) {
73
+ throw new Error(`Vector dimension mismatch: expected ${this.dimension}, got ${vector.length}`);
74
+ }
75
+ this.vectors.set(id, { vector, metadata });
76
+ }
77
+ remove(id) {
78
+ this.vectors.delete(id);
79
+ }
80
+ search(queryVector, k, filter) {
81
+ const results = [];
82
+ for (const [id, data] of this.vectors) {
83
+ // Apply metadata filter if provided
84
+ if (filter && !this.matchesFilter(data.metadata, filter)) {
85
+ continue;
86
+ }
87
+ const score = this.calculateSimilarity(queryVector, data.vector);
88
+ results.push({
89
+ id,
90
+ score,
91
+ vector: data.vector,
92
+ metadata: data.metadata,
93
+ });
94
+ }
95
+ // Sort by score (higher is better for similarity)
96
+ results.sort((a, b) => b.score - a.score);
97
+ return results.slice(0, k);
98
+ }
99
+ size() {
100
+ return this.vectors.size;
101
+ }
102
+ calculateSimilarity(a, b) {
103
+ switch (this.metric) {
104
+ case DistanceMetric.Cosine:
105
+ return this.cosineSimilarity(a, b);
106
+ case DistanceMetric.Euclidean:
107
+ return 1 / (1 + this.euclideanDistance(a, b));
108
+ case DistanceMetric.DotProduct:
109
+ return this.dotProduct(a, b);
110
+ default:
111
+ return this.cosineSimilarity(a, b);
112
+ }
113
+ }
114
+ cosineSimilarity(a, b) {
115
+ let dotProduct = 0;
116
+ let normA = 0;
117
+ let normB = 0;
118
+ for (let i = 0; i < a.length; i++) {
119
+ dotProduct += a[i] * b[i];
120
+ normA += a[i] * a[i];
121
+ normB += b[i] * b[i];
122
+ }
123
+ if (normA === 0 || normB === 0)
124
+ return 0;
125
+ return dotProduct / (Math.sqrt(normA) * Math.sqrt(normB));
126
+ }
127
+ euclideanDistance(a, b) {
128
+ let sum = 0;
129
+ for (let i = 0; i < a.length; i++) {
130
+ const diff = a[i] - b[i];
131
+ sum += diff * diff;
132
+ }
133
+ return Math.sqrt(sum);
134
+ }
135
+ dotProduct(a, b) {
136
+ let sum = 0;
137
+ for (let i = 0; i < a.length; i++) {
138
+ sum += a[i] * b[i];
139
+ }
140
+ return sum;
141
+ }
142
+ matchesFilter(metadata, filter) {
143
+ if (!metadata)
144
+ return false;
145
+ for (const [key, value] of Object.entries(filter)) {
146
+ if (metadata[key] !== value) {
147
+ return false;
148
+ }
149
+ }
150
+ return true;
151
+ }
152
+ }
61
153
  class Collection {
62
154
  constructor(db, namespace, name, config) {
63
155
  this.db = db;
64
156
  this.namespace = namespace;
65
157
  this.name = name;
66
158
  this.config = config;
159
+ this._indexReady = false;
160
+ this.vectorIndex = new VectorIndex(config.dimension || 384, config.metric || DistanceMetric.Cosine);
67
161
  }
68
162
  /**
69
163
  * Insert a vector with optional metadata
164
+ * Vector is immediately indexed (synchronous)
70
165
  */
71
166
  async insert(vector, metadata, id) {
72
167
  if (this.config.dimension && vector.length !== this.config.dimension) {
@@ -79,11 +174,15 @@ class Collection {
79
174
  metadata: metadata || {},
80
175
  timestamp: Date.now(),
81
176
  };
177
+ // Store to database
82
178
  await this.db.put(Buffer.from(key), Buffer.from(JSON.stringify(data)));
179
+ // SYNCHRONOUSLY add to in-memory index
180
+ this.vectorIndex.add(vectorId, vector, metadata);
83
181
  return vectorId;
84
182
  }
85
183
  /**
86
184
  * Insert multiple vectors
185
+ * All vectors are indexed synchronously after insertion
87
186
  */
88
187
  async insertMany(vectors, metadatas, ids) {
89
188
  const resultIds = [];
@@ -95,26 +194,49 @@ class Collection {
95
194
  }
96
195
  return resultIds;
97
196
  }
197
+ /**
198
+ * Rebuild index from database (for recovery/startup)
199
+ */
200
+ async rebuildIndex() {
201
+ const prefix = this.vectorKeyPrefix();
202
+ let count = 0;
203
+ try {
204
+ for await (const [keyBuffer, valueBuffer] of this.db.scanPrefix(Buffer.from(prefix))) {
205
+ const key = keyBuffer.toString();
206
+ const id = key.replace(prefix, '');
207
+ const data = JSON.parse(valueBuffer.toString());
208
+ this.vectorIndex.add(id, data.vector, data.metadata);
209
+ count++;
210
+ }
211
+ }
212
+ catch (error) {
213
+ console.warn('[SochDB] Error rebuilding vector index:', error);
214
+ }
215
+ this._indexReady = true;
216
+ return count;
217
+ }
218
+ /**
219
+ * Check if index is ready (loaded from disk)
220
+ */
221
+ get isIndexReady() {
222
+ return this._indexReady || this.vectorIndex.size() > 0;
223
+ }
98
224
  /**
99
225
  * Search for similar vectors
226
+ * Uses synchronous in-memory index - no delay
100
227
  */
101
228
  async search(request) {
102
- // For now, implement basic linear search
103
- // In production, this would use HNSW index
104
- const results = [];
105
- const prefix = this.vectorKeyPrefix();
106
- // Scan all vectors in collection
107
- const allVectors = [];
108
- // TODO: Implement efficient scanning with range queries
109
- // For now, this is a placeholder that shows the API structure
110
- // Sort by similarity score
111
- allVectors.sort((a, b) => b.score - a.score);
112
- // Return top-k results
113
- return allVectors.slice(0, request.k).map(v => ({
114
- id: v.id,
115
- score: v.score,
116
- vector: request.includeMetadata ? v.vector : undefined,
117
- metadata: request.includeMetadata ? v.metadata : undefined,
229
+ // Auto-rebuild index if empty but there might be data
230
+ if (!this.isIndexReady && this.vectorIndex.size() === 0) {
231
+ await this.rebuildIndex();
232
+ }
233
+ const results = this.vectorIndex.search(request.queryVector, request.k, request.filter);
234
+ // Map results based on includeMetadata flag
235
+ return results.map(r => ({
236
+ id: r.id,
237
+ score: r.score,
238
+ vector: request.includeMetadata ? r.vector : undefined,
239
+ metadata: request.includeMetadata ? r.metadata : undefined,
118
240
  }));
119
241
  }
120
242
  /**
@@ -138,14 +260,20 @@ class Collection {
138
260
  async delete(id) {
139
261
  const key = this.vectorKey(id);
140
262
  await this.db.delete(Buffer.from(key));
263
+ // Remove from in-memory index
264
+ this.vectorIndex.remove(id);
141
265
  return true;
142
266
  }
143
267
  /**
144
268
  * Count vectors in collection
145
269
  */
146
270
  async count() {
147
- // TODO: Implement efficient counting
148
- return 0;
271
+ // If index is loaded, return from index
272
+ if (this.isIndexReady) {
273
+ return this.vectorIndex.size();
274
+ }
275
+ // Otherwise rebuild and count
276
+ return await this.rebuildIndex();
149
277
  }
150
278
  // Helper methods
151
279
  vectorKey(id) {
@@ -252,4 +380,4 @@ class Namespace {
252
380
  }
253
381
  }
254
382
  exports.Namespace = Namespace;
255
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmFtZXNwYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL25hbWVzcGFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7Ozs7Ozs7Ozs7OztHQWVHOzs7QUFFSCxxQ0FBc0Q7QUFhdEQsTUFBYSxzQkFBdUIsU0FBUSxvQkFBVztJQUNyRCxZQUFZLFNBQWlCO1FBQzNCLEtBQUssQ0FBQyx3QkFBd0IsU0FBUyxFQUFFLENBQUMsQ0FBQztRQUMzQyxJQUFJLENBQUMsSUFBSSxHQUFHLHdCQUF3QixDQUFDO0lBQ3ZDLENBQUM7Q0FDRjtBQUxELHdEQUtDO0FBRUQsTUFBYSxvQkFBcUIsU0FBUSxvQkFBVztJQUNuRCxZQUFZLFNBQWlCO1FBQzNCLEtBQUssQ0FBQyw2QkFBNkIsU0FBUyxFQUFFLENBQUMsQ0FBQztRQUNoRCxJQUFJLENBQUMsSUFBSSxHQUFHLHNCQUFzQixDQUFDO0lBQ3JDLENBQUM7Q0FDRjtBQUxELG9EQUtDO0FBRUQsTUFBYSx1QkFBd0IsU0FBUSxvQkFBVztJQUN0RCxZQUFZLFVBQWtCO1FBQzVCLEtBQUssQ0FBQyx5QkFBeUIsVUFBVSxFQUFFLENBQUMsQ0FBQztRQUM3QyxJQUFJLENBQUMsSUFBSSxHQUFHLHlCQUF5QixDQUFDO0lBQ3hDLENBQUM7Q0FDRjtBQUxELDBEQUtDO0FBRUQsTUFBYSxxQkFBc0IsU0FBUSxvQkFBVztJQUNwRCxZQUFZLFVBQWtCO1FBQzVCLEtBQUssQ0FBQyw4QkFBOEIsVUFBVSxFQUFFLENBQUMsQ0FBQztRQUNsRCxJQUFJLENBQUMsSUFBSSxHQUFHLHVCQUF1QixDQUFDO0lBQ3RDLENBQUM7Q0FDRjtBQUxELHNEQUtDO0FBRUQsK0VBQStFO0FBQy9FLDJCQUEyQjtBQUMzQiwrRUFBK0U7QUFFL0UsSUFBWSxjQUlYO0FBSkQsV0FBWSxjQUFjO0lBQ3hCLG1DQUFpQixDQUFBO0lBQ2pCLHlDQUF1QixDQUFBO0lBQ3ZCLG9DQUFrQixDQUFBO0FBQ3BCLENBQUMsRUFK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Q0FBQztJQUNILENBQUM7SUFFRDs7T0FFRztJQUNILEtBQUssQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFZO1FBQ2pDLE1BQU0sV0FBVyxHQUFHLGVBQWUsSUFBSSxDQUFDLElBQUksSUFBSSxJQUFJLFdBQVcsQ0FBQztRQUNoRSxNQUFNLE1BQU0sR0FBRyxlQUFlLElBQUksQ0FBQyxJQUFJLElBQUksSUFBSSxHQUFHLENBQUM7UUFFbkQsb0NBQW9DO1FBQ3BDLE1BQU0sSUFBSSxDQUFDLEVBQUUsQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDO1FBRS9DLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVEOztPQUVHO0lBQ0gsS0FBSyxDQUFDLGVBQWU7UUFDbkIsdURBQXVEO1FBQ3ZELE9BQU8sRUFBRSxDQUFDO0lBQ1osQ0FBQztJQUVELE9BQU87UUFDTCxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUM7SUFDbkIsQ0FBQztJQUVELFNBQVM7UUFDUCxPQUFPLEVBQUUsR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7SUFDNUIsQ0FBQztDQUNGO0FBMUZELDhCQTBGQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogU29jaERCIE5hbWVzcGFjZSBBUElcbiAqIFxuICogUHJvdmlkZXMgdHlwZS1zYWZlIG5hbWVzcGFjZSBpc29sYXRpb24gd2l0aCBmaXJzdC1jbGFzcyBuYW1lc3BhY2UgaGFuZGxlcy5cbiAqIFxuICogQGV4YW1wbGVcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIGltcG9ydCB7IERhdGFiYXNlIH0gZnJvbSAnQHNvY2hkYi9zb2NoZGInO1xuICogXG4gKiBjb25zdCBkYiA9IGF3YWl0IERhdGFiYXNlLm9wZW4oJy4vbXlkYicpO1xuICogY29uc3QgbnMgPSBhd2FpdCBkYi5jcmVhdGVOYW1lc3BhY2UoJ3RlbmFudF8xMjMnKTtcbiAqIGNvbnN0IGNvbGxlY3Rpb24gPSBhd2FpdCBucy5jcmVhdGVDb2xsZWN0aW9uKCdkb2N1bWVudHMnLCB7IGRpbWVuc2lvbjogMzg0IH0pO1xuICogYXdhaXQgY29sbGVjdGlvbi5pbnNlcnQoWzEuMCwgMi4wLCAuLi5dLCB7IHNvdXJjZTogJ3dlYicgfSk7XG4gKiBjb25zdCByZXN1bHRzID0gYXdhaXQgY29sbGVjdGlvbi5zZWFyY2gocXVlcnlWZWN0b3IsIDEwKTtcbiAqIGBgYFxuICovXG5cbmltcG9ydCB7IFNvY2hEQkVycm9yLCBEYXRhYmFzZUVycm9yIH0gZnJvbSAnLi9lcnJvcnMnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBOYW1lc3BhY2UgQ29uZmlndXJhdGlvblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG5leHBvcnQgaW50ZXJmYWNlIE5hbWVzcGFjZUNvbmZpZyB7XG4gIG5hbWU6IHN0cmluZztcbiAgZGlzcGxheU5hbWU/OiBzdHJpbmc7XG4gIGxhYmVscz86IFJlY29yZDxzdHJpbmcsIHN0cmluZz47XG4gIHJlYWRPbmx5PzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGNsYXNzIE5hbWVzcGFjZU5vdEZvdW5kRXJyb3IgZXh0ZW5kcyBTb2NoREJFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG5hbWVzcGFjZTogc3RyaW5nKSB7XG4gICAgc3VwZXIoYE5hbWVzcGFjZSBub3QgZm91bmQ6ICR7bmFtZXNwYWNlfWApO1xuICAgIHRoaXMubmFtZSA9ICdOYW1lc3BhY2VOb3RGb3VuZEVycm9yJztcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgTmFtZXNwYWNlRXhpc3RzRXJyb3IgZXh0ZW5kcyBTb2NoREJFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG5hbWVzcGFjZTogc3RyaW5nKSB7XG4gICAgc3VwZXIoYE5hbWVzcGFjZSBhbHJlYWR5IGV4aXN0czogJHtuYW1lc3BhY2V9YCk7XG4gICAgdGhpcy5uYW1lID0gJ05hbWVzcGFjZUV4aXN0c0Vycm9yJztcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgQ29sbGVjdGlvbk5vdEZvdW5kRXJyb3IgZXh0ZW5kcyBTb2NoREJFcnJvciB7XG4gIGNvbnN0cnVjdG9yKGNvbGxlY3Rpb246IHN0cmluZykge1xuICAgIHN1cGVyKGBDb2xsZWN0aW9uIG5vdCBmb3VuZDogJHtjb2xsZWN0aW9ufWApO1xuICAgIHRoaXMubmFtZSA9ICdDb2xsZWN0aW9uTm90Rm91bmRFcnJvcic7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIENvbGxlY3Rpb25FeGlzdHNFcnJvciBleHRlbmRzIFNvY2hEQkVycm9yIHtcbiAgY29uc3RydWN0b3IoY29sbGVjdGlvbjogc3RyaW5nKSB7XG4gICAgc3VwZXIoYENvbGxlY3Rpb24gYWxyZWFkeSBleGlzdHM6ICR7Y29sbGVjdGlvbn1gKTtcbiAgICB0aGlzLm5hbWUgPSAnQ29sbGVjdGlvbkV4aXN0c0Vycm9yJztcbiAgfVxufVxuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBDb2xsZWN0aW9uIENvbmZpZ3VyYXRpb25cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuZXhwb3J0IGVudW0gRGlzdGFuY2VNZXRyaWMge1xuICBDb3NpbmUgPSAnY29zaW5lJyxcbiAgRXVjbGlkZWFuID0gJ2V1Y2xpZGVhbicsXG4gIERvdFByb2R1Y3QgPSAnZG90Jyxcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDb2xsZWN0aW9uQ29uZmlnIHtcbiAgbmFtZTogc3RyaW5nO1xuICBkaW1lbnNpb24/OiBudW1iZXI7XG4gIG1ldHJpYz86IERpc3RhbmNlTWV0cmljO1xuICBpbmRleGVkPzogYm9vbGVhbjtcbiAgaG5zd00/OiBudW1iZXI7XG4gIGhuc3dFZkNvbnN0cnVjdGlvbj86IG51bWJlcjtcbiAgbWV0YWRhdGE/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNlYXJjaFJlcXVlc3Qge1xuICBxdWVyeVZlY3RvcjogbnVtYmVyW107XG4gIGs6IG51bWJlcjtcbiAgZmlsdGVyPzogUmVjb3JkPHN0cmluZywgYW55PjtcbiAgaW5jbHVkZU1ldGFkYXRhPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTZWFyY2hSZXN1bHQge1xuICBpZDogc3RyaW5nO1xuICBzY29yZTogbnVtYmVyO1xuICB2ZWN0b3I/OiBudW1iZXJbXTtcbiAgbWV0YWRhdGE/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+O1xufVxuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBDb2xsZWN0aW9uIEhhbmRsZVxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG5leHBvcnQgY2xhc3MgQ29sbGVjdGlvbiB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgZGI6IGFueSxcbiAgICBwcml2YXRlIG5hbWVzcGFjZTogc3RyaW5nLFxuICAgIHByaXZhdGUgbmFtZTogc3RyaW5nLFxuICAgIHByaXZhdGUgY29uZmlnOiBDb2xsZWN0aW9uQ29uZmlnXG4gICkge31cblxuICAvKipcbiAgICogSW5zZXJ0IGEgdmVjdG9yIHdpdGggb3B0aW9uYWwgbWV0YWRhdGFcbiAgICovXG4gIGFzeW5jIGluc2VydChcbiAgICB2ZWN0b3I6IG51bWJlcltdLFxuICAgIG1ldGFkYXRhPzogUmVjb3JkPHN0cmluZywgYW55PixcbiAgICBpZD86IHN0cmluZ1xuICApOiBQcm9taXNlPHN0cmluZz4ge1xuICAgIGlmICh0aGlzLmNvbmZpZy5kaW1lbnNpb24gJiYgdmVjdG9yLmxlbmd0aCAhPT0gdGhpcy5jb25maWcuZGltZW5zaW9uKSB7XG4gICAgICB0aHJvdyBuZXcgRGF0YWJhc2VFcnJvcihcbiAgICAgICAgYFZlY3RvciBkaW1lbnNpb24gbWlzbWF0Y2g6IGV4cGVjdGVkICR7dGhpcy5jb25maWcuZGltZW5zaW9ufSwgZ290ICR7dmVjdG9yLmxlbmd0aH1gXG4gICAgICApO1xuICAgIH1cblxuICAgIGNvbnN0IHZlY3RvcklkID0gaWQgfHwgdGhpcy5nZW5lcmF0ZUlkKCk7XG4gICAgY29uc3Qga2V5ID0gdGhpcy52ZWN0b3JLZXkodmVjdG9ySWQpO1xuICAgIFxuICAgIGNvbnN0IGRhdGEgPSB7XG4gICAgICB2ZWN0b3IsXG4gICAgICBtZXRhZGF0YTogbWV0YWRhdGEgfHwge30sXG4gICAgICB0aW1lc3RhbXA6IERhdGUubm93KCksXG4gICAgfTtcblxuICAgIGF3YWl0IHRoaXMuZGIucHV0KEJ1ZmZlci5mcm9tKGtleSksIEJ1ZmZlci5mcm9tKEpTT04uc3RyaW5naWZ5KGRhdGEpKSk7XG4gICAgcmV0dXJuIHZlY3RvcklkO1xuICB9XG5cbiAgLyoqXG4gICAqIEluc2VydCBtdWx0aXBsZSB2ZWN0b3JzXG4gICAqL1xuICBhc3luYyBpbnNlcnRNYW55KFxuICAgIHZlY3RvcnM6IG51bWJlcltdW10sXG4gICAgbWV0YWRhdGFzPzogUmVjb3JkPHN0cmluZywgYW55PltdLFxuICAgIGlkcz86IHN0cmluZ1tdXG4gICk6IFByb21pc2U8c3RyaW5nW10+IHtcbiAgICBjb25zdCByZXN1bHRJZHM6IHN0cmluZ1tdID0gW107XG4gICAgXG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCB2ZWN0b3JzLmxlbmd0aDsgaSsrKSB7XG4gICAgICBjb25zdCBpZCA9IGlkcyA/IGlkc1tpXSA6IHVuZGVmaW5lZDtcbiAgICAgIGNvbnN0IG1ldGFkYXRhID0gbWV0YWRhdGFzID8gbWV0YWRhdGFzW2ldIDogdW5kZWZpbmVkO1xuICAgICAgY29uc3QgcmVzdWx0SWQgPSBhd2FpdCB0aGlzLmluc2VydCh2ZWN0b3JzW2ldLCBtZXRhZGF0YSwgaWQpO1xuICAgICAgcmVzdWx0SWRzLnB1c2gocmVzdWx0SWQpO1xuICAgIH1cbiAgICBcbiAgICByZXR1cm4gcmVzdWx0SWRzO1xuICB9XG5cbiAgLyoqXG4gICAqIFNlYXJjaCBmb3Igc2ltaWxhciB2ZWN0b3JzXG4gICAqL1xuICBhc3luYyBzZWFyY2gocmVxdWVzdDogU2VhcmNoUmVxdWVzdCk6IFByb21pc2U8U2VhcmNoUmVzdWx0W10+IHtcbiAgICAvLyBGb3Igbm93LCBpbXBsZW1lbnQgYmFzaWMgbGluZWFyIHNlYXJjaFxuICAgIC8vIEluIHByb2R1Y3Rpb24sIHRoaXMgd291bGQgdXNlIEhOU1cgaW5kZXhcbiAgICBjb25zdCByZXN1bHRzOiBTZWFyY2hSZXN1bHRbXSA9IFtdO1xuICAgIGNvbnN0IHByZWZpeCA9IHRoaXMudmVjdG9yS2V5UHJlZml4KCk7XG4gICAgXG4gICAgLy8gU2NhbiBhbGwgdmVjdG9ycyBpbiBjb2xsZWN0aW9uXG4gICAgY29uc3QgYWxsVmVjdG9yczogQXJyYXk8eyBpZDogc3RyaW5nOyB2ZWN0b3I6IG51bWJlcltdOyBtZXRhZGF0YT86IGFueTsgc2NvcmU6IG51bWJlciB9PiA9IFtdO1xuICAgIFxuICAgIC8vIFRPRE86IEltcGxlbWVudCBlZmZpY2llbnQgc2Nhbm5pbmcgd2l0aCByYW5nZSBxdWVyaWVzXG4gICAgLy8gRm9yIG5vdywgdGhpcyBpcyBhIHBsYWNlaG9sZGVyIHRoYXQgc2hvd3MgdGhlIEFQSSBzdHJ1Y3R1cmVcbiAgICBcbiAgICAvLyBTb3J0IGJ5IHNpbWlsYXJpdHkgc2NvcmVcbiAgICBhbGxWZWN0b3JzLnNvcnQoKGEsIGIpID0+IGIuc2NvcmUgLSBhLnNjb3JlKTtcbiAgICBcbiAgICAvLyBSZXR1cm4gdG9wLWsgcmVzdWx0c1xuICAgIHJldHVybiBhbGxWZWN0b3JzLnNsaWNlKDAsIHJlcXVlc3QuaykubWFwKHYgPT4gKHtcbiAgICAgIGlkOiB2LmlkLFxuICAgICAgc2NvcmU6IHYuc2NvcmUsXG4gICAgICB2ZWN0b3I6IHJlcXVlc3QuaW5jbHVkZU1ldGFkYXRhID8gdi52ZWN0b3IgOiB1bmRlZmluZWQsXG4gICAgICBtZXRhZGF0YTogcmVxdWVzdC5pbmNsdWRlTWV0YWRhdGEgPyB2Lm1ldGFkYXRhIDogdW5kZWZpbmVkLFxuICAgIH0pKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgYSB2ZWN0b3IgYnkgSURcbiAgICovXG4gIGFzeW5jIGdldChpZDogc3RyaW5nKTogUHJvbWlzZTx7IHZlY3RvcjogbnVtYmVyW107IG1ldGFkYXRhPzogUmVjb3JkPHN0cmluZywgYW55PiB9IHwgbnVsbD4ge1xuICAgIGNvbnN0IGtleSA9IHRoaXMudmVjdG9yS2V5KGlkKTtcbiAgICBjb25zdCB2YWx1ZSA9IGF3YWl0IHRoaXMuZGIuZ2V0KEJ1ZmZlci5mcm9tKGtleSkpO1xuICAgIFxuICAgIGlmICghdmFsdWUpIHtcbiAgICAgIHJldHVybiBudWxsO1xuICAgIH1cbiAgICBcbiAgICBjb25zdCBkYXRhID0gSlNPTi5wYXJzZSh2YWx1ZS50b1N0cmluZygpKTtcbiAgICByZXR1cm4ge1xuICAgICAgdmVjdG9yOiBkYXRhLnZlY3RvcixcbiAgICAgIG1ldGFkYXRhOiBkYXRhLm1ldGFkYXRhLFxuICAgIH07XG4gIH1cblxuICAvKipcbiAgICogRGVsZXRlIGEgdmVjdG9yIGJ5IElEXG4gICAqL1xuICBhc3luYyBkZWxldGUoaWQ6IHN0cmluZyk6IFByb21pc2U8Ym9vbGVhbj4ge1xuICAgIGNvbnN0IGtleSA9IHRoaXMudmVjdG9yS2V5KGlkKTtcbiAgICBhd2FpdCB0aGlzLmRiLmRlbGV0ZShCdWZmZXIuZnJvbShrZXkpKTtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDb3VudCB2ZWN0b3JzIGluIGNvbGxlY3Rpb25cbiAgICovXG4gIGFzeW5jIGNvdW50KCk6IFByb21pc2U8bnVtYmVyPiB7XG4gICAgLy8gVE9ETzogSW1wbGVtZW50IGVmZmljaWVudCBjb3VudGluZ1xuICAgIHJldHVybiAwO1xuICB9XG5cbiAgLy8gSGVscGVyIG1ldGhvZHNcbiAgcHJpdmF0ZSB2ZWN0b3JLZXkoaWQ6IHN0cmluZyk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGBfY29sbGVjdGlvbi8ke3RoaXMubmFtZXNwYWNlfS8ke3RoaXMubmFtZX0vdmVjdG9ycy8ke2lkfWA7XG4gIH1cblxuICBwcml2YXRlIHZlY3RvcktleVByZWZpeCgpOiBzdHJpbmcge1xuICAgIHJldHVybiBgX2NvbGxlY3Rpb24vJHt0aGlzLm5hbWVzcGFjZX0vJHt0aGlzLm5hbWV9L3ZlY3RvcnMvYDtcbiAgfVxuXG4gIHByaXZhdGUgbWV0YWRhdGFLZXkoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gYF9jb2xsZWN0aW9uLyR7dGhpcy5uYW1lc3BhY2V9LyR7dGhpcy5uYW1lfS9tZXRhZGF0YWA7XG4gIH1cblxuICBwcml2YXRlIGdlbmVyYXRlSWQoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gYCR7RGF0ZS5ub3coKX0tJHtNYXRoLnJhbmRvbSgpLnRvU3RyaW5nKDM2KS5zdWJzdHIoMiwgOSl9YDtcbiAgfVxuXG4gIC8vIENhbGN1bGF0ZSBjb3NpbmUgc2ltaWxhcml0eVxuICBwcml2YXRlIGNvc2luZVNpbWlsYXJpdHkoYTogbnVtYmVyW10sIGI6IG51bWJlcltdKTogbnVtYmVyIHtcbiAgICBsZXQgZG90UHJvZHVjdCA9IDA7XG4gICAgbGV0IG5vcm1BID0gMDtcbiAgICBsZXQgbm9ybUIgPSAwO1xuICAgIFxuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgYS5sZW5ndGg7IGkrKykge1xuICAgICAgZG90UHJvZHVjdCArPSBhW2ldICogYltpXTtcbiAgICAgIG5vcm1BICs9IGFbaV0gKiBhW2ldO1xuICAgICAgbm9ybUIgKz0gYltpXSAqIGJbaV07XG4gICAgfVxuICAgIFxuICAgIHJldHVybiBkb3RQcm9kdWN0IC8gKE1hdGguc3FydChub3JtQSkgKiBNYXRoLnNxcnQobm9ybUIpKTtcbiAgfVxufVxuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBOYW1lc3BhY2UgSGFuZGxlXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCBjbGFzcyBOYW1lc3BhY2Uge1xuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIGRiOiBhbnksXG4gICAgcHJpdmF0ZSBuYW1lOiBzdHJpbmcsXG4gICAgcHJpdmF0ZSBjb25maWc6IE5hbWVzcGFjZUNvbmZpZ1xuICApIHt9XG5cbiAgLyoqXG4gICAqIENyZWF0ZSBhIG5ldyBjb2xsZWN0aW9uIGluIHRoaXMgbmFtZXNwYWNlXG4gICAqL1xuICBhc3luYyBjcmVhdGVDb2xsZWN0aW9uKGNvbmZpZzogQ29sbGVjdGlvbkNvbmZpZyk6IFByb21pc2U8Q29sbGVjdGlvbj4ge1xuICAgIGNvbnN0IG1ldGFkYXRhS2V5ID0gYF9jb2xsZWN0aW9uLyR7dGhpcy5uYW1lfS8ke2NvbmZpZy5uYW1lfS9tZXRhZGF0YWA7XG4gICAgXG4gICAgLy8gQ2hlY2sgaWYgY29sbGVjdGlvbiBhbHJlYWR5IGV4aXN0c1xuICAgIGNvbnN0IGV4aXN0aW5nID0gYXdhaXQgdGhpcy5kYi5nZXQoQnVmZmVyLmZyb20obWV0YWRhdGFLZXkpKTtcbiAgICBpZiAoZXhpc3RpbmcpIHtcbiAgICAgIHRocm93IG5ldyBDb2xsZWN0aW9uRXhpc3RzRXJyb3IoY29uZmlnLm5hbWUpO1xuICAgIH1cblxuICAgIC8vIFN0b3JlIGNvbGxlY3Rpb24gbWV0YWRhdGFcbiAgICBjb25zdCBtZXRhZGF0YSA9IHtcbiAgICAgIC4uLmNvbmZpZyxcbiAgICAgIGNyZWF0ZWRBdDogRGF0ZS5ub3coKSxcbiAgICB9O1xuICAgIFxuICAgIGF3YWl0IHRoaXMuZGIucHV0KFxuICAgICAgQnVmZmVyLmZyb20obWV0YWRhdGFLZXkpLFxuICAgICAgQnVmZmVyLmZyb20oSlNPTi5zdHJpbmdpZnkobWV0YWRhdGEpKVxuICAgICk7XG5cbiAgICByZXR1cm4gbmV3IENvbGxlY3Rpb24odGhpcy5kYiwgdGhpcy5uYW1lLCBjb25maWcubmFtZSwgY29uZmlnKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgYW4gZXhpc3RpbmcgY29sbGVjdGlvblxuICAgKi9cbiAgYXN5bmMgY29sbGVjdGlvbihuYW1lOiBzdHJpbmcpOiBQcm9taXNlPENvbGxlY3Rpb24+IHtcbiAgICBjb25zdCBtZXRhZGF0YUtleSA9IGBfY29sbGVjdGlvbi8ke3RoaXMubmFtZX0vJHtuYW1lfS9tZXRhZGF0YWA7XG4gICAgY29uc3QgbWV0YWRhdGEgPSBhd2FpdCB0aGlzLmRiLmdldChCdWZmZXIuZnJvbShtZXRhZGF0YUtleSkpO1xuICAgIFxuICAgIGlmICghbWV0YWRhdGEpIHtcbiAgICAgIHRocm93IG5ldyBDb2xsZWN0aW9uTm90Rm91bmRFcnJvcihuYW1lKTtcbiAgICB9XG5cbiAgICBjb25zdCBjb25maWcgPSBKU09OLnBhcnNlKG1ldGFkYXRhLnRvU3RyaW5nKCkpO1xuICAgIHJldHVybiBuZXcgQ29sbGVjdGlvbih0aGlzLmRiLCB0aGlzLm5hbWUsIG5hbWUsIGNvbmZpZyk7XG4gIH1cblxuICAvKipcbiAgICogR2V0IG9yIGNyZWF0ZSBhIGNvbGxlY3Rpb25cbiAgICovXG4gIGFzeW5jIGdldE9yQ3JlYXRlQ29sbGVjdGlvbihjb25maWc6IENvbGxlY3Rpb25Db25maWcpOiBQcm9taXNlPENvbGxlY3Rpb24+IHtcbiAgICB0cnkge1xuICAgICAgcmV0dXJuIGF3YWl0IHRoaXMuY29sbGVjdGlvbihjb25maWcubmFtZSk7XG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIGlmIChlcnJvciBpbnN0YW5jZW9mIENvbGxlY3Rpb25Ob3RGb3VuZEVycm9yKSB7XG4gICAgICAgIHJldHVybiBhd2FpdCB0aGlzLmNyZWF0ZUNvbGxlY3Rpb24oY29uZmlnKTtcbiAgICAgIH1cbiAgICAgIHRocm93IGVycm9yO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBEZWxldGUgYSBjb2xsZWN0aW9uXG4gICAqL1xuICBhc3luYyBkZWxldGVDb2xsZWN0aW9uKG5hbWU6IHN0cmluZyk6IFByb21pc2U8Ym9vbGVhbj4ge1xuICAgIGNvbnN0IG1ldGFkYXRhS2V5ID0gYF9jb2xsZWN0aW9uLyR7dGhpcy5uYW1lfS8ke25hbWV9L21ldGFkYXRhYDtcbiAgICBjb25zdCBwcmVmaXggPSBgX2NvbGxlY3Rpb24vJHt0aGlzLm5hbWV9LyR7bmFtZX0vYDtcbiAgICBcbiAgICAvLyBUT0RPOiBEZWxldGUgYWxsIGtleXMgd2l0aCBwcmVmaXhcbiAgICBhd2FpdCB0aGlzLmRiLmRlbGV0ZShCdWZmZXIuZnJvbShtZXRhZGF0YUtleSkpO1xuICAgIFxuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgLyoqXG4gICAqIExpc3QgYWxsIGNvbGxlY3Rpb25zIGluIHRoaXMgbmFtZXNwYWNlXG4gICAqL1xuICBhc3luYyBsaXN0Q29sbGVjdGlvbnMoKTogUHJvbWlzZTxzdHJpbmdbXT4ge1xuICAgIC8vIFRPRE86IEltcGxlbWVudCBlZmZpY2llbnQgbGlzdGluZyB3aXRoIHJhbmdlIHF1ZXJpZXNcbiAgICByZXR1cm4gW107XG4gIH1cblxuICBnZXROYW1lKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMubmFtZTtcbiAgfVxuXG4gIGdldENvbmZpZygpOiBOYW1lc3BhY2VDb25maWcge1xuICAgIHJldHVybiB7IC4uLnRoaXMuY29uZmlnIH07XG4gIH1cbn1cbiJdfQ==
383
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmFtZXNwYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL25hbWVzcGFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7Ozs7Ozs7Ozs7OztHQWVHOzs7QUFFSCxxQ0FBc0Q7QUFhdEQsTUFBYSxzQkFBdUIsU0FBUSxvQkFBVztJQUNyRCxZQUFZLFNBQWlCO1FBQzNCLEtBQUssQ0FBQyx3QkFBd0IsU0FBUyxFQUFFLENBQUMsQ0FBQztRQUMzQyxJQUFJLENBQUMsSUFBSSxHQUFHLHdCQUF3QixDQUFDO0lBQ3ZDLENBQUM7Q0FDRjtBQUxELHdEQUtDO0FBRUQsTUFBYSxvQkFBcUIsU0FBUSxvQkFBVztJQUNuRCxZQUFZLFNBQWlCO1FBQzNCLEtBQUssQ0FBQyw2QkFBNkIsU0FBUyxFQUFFLENBQUMsQ0FBQztRQUNoRCxJQUFJLENBQUMsSUFBSSxHQUFHLHNCQUFzQixDQUFDO0lBQ3JDLENBQUM7Q0FDRjtBQUxELG9EQUtDO0FBRUQsTUFBYSx1QkFBd0IsU0FBUSxvQkFBVztJQUN0RCxZQUFZLFVBQWtCO1FBQzVCLEtBQUssQ0FBQyx5QkFBeUIsVUFBVSxFQUFFLENBQUMsQ0FBQztRQUM3QyxJQUFJLENBQUMsSUFBSSxHQUFHLHlCQUF5QixDQUFDO0lBQ3hDLENBQUM7Q0FDRjtBQUxELDBEQUtDO0FBRUQsTUFBYSxxQkFBc0IsU0FBUSxvQkFBVztJQUNwRCxZQUFZLFVBQWtCO1FBQzVCLEtBQUssQ0FBQyw4QkFBOEIsVUFBVSxFQUFFLENBQUMsQ0FBQztRQUNsRCxJQUFJLENBQUMsSUFBSSxHQUFHLHVCQUF1QixDQUFDO0lBQ3RDLENBQUM7Q0FDRjtBQUxELHNEQUtDO0FBRUQsK0VBQStFO0FBQy9FLDJCQUEyQjtBQUMzQiwrRUFBK0U7QUFFL0UsSUFBWSxjQUlYO0FBSkQsV0FBWSxjQUFjO0lBQ3hCLG1DQUFpQixDQUFBO0lBQ2pCLHlDQUF1QixDQUFBO0lBQ3ZCLG9DQUFrQixDQUFBO0FBQ3BCLENBQUMsRUFK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QUFNLEdBQUcsZUFBZSxJQUFJLENBQUMsSUFBSSxJQUFJLElBQUksR0FBRyxDQUFDO1FBRW5ELG9DQUFvQztRQUNwQyxNQUFNLElBQUksQ0FBQyxFQUFFLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQztRQUUvQyxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRDs7T0FFRztJQUNILEtBQUssQ0FBQyxlQUFlO1FBQ25CLHVEQUF1RDtRQUN2RCxPQUFPLEVBQUUsQ0FBQztJQUNaLENBQUM7SUFFRCxPQUFPO1FBQ0wsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDO0lBQ25CLENBQUM7SUFFRCxTQUFTO1FBQ1AsT0FBTyxFQUFFLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO0lBQzVCLENBQUM7Q0FDRjtBQTFGRCw4QkEwRkMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFNvY2hEQiBOYW1lc3BhY2UgQVBJXG4gKiBcbiAqIFByb3ZpZGVzIHR5cGUtc2FmZSBuYW1lc3BhY2UgaXNvbGF0aW9uIHdpdGggZmlyc3QtY2xhc3MgbmFtZXNwYWNlIGhhbmRsZXMuXG4gKiBcbiAqIEBleGFtcGxlXG4gKiBgYGB0eXBlc2NyaXB0XG4gKiBpbXBvcnQgeyBEYXRhYmFzZSB9IGZyb20gJ0Bzb2NoZGIvc29jaGRiJztcbiAqIFxuICogY29uc3QgZGIgPSBhd2FpdCBEYXRhYmFzZS5vcGVuKCcuL215ZGInKTtcbiAqIGNvbnN0IG5zID0gYXdhaXQgZGIuY3JlYXRlTmFtZXNwYWNlKCd0ZW5hbnRfMTIzJyk7XG4gKiBjb25zdCBjb2xsZWN0aW9uID0gYXdhaXQgbnMuY3JlYXRlQ29sbGVjdGlvbignZG9jdW1lbnRzJywgeyBkaW1lbnNpb246IDM4NCB9KTtcbiAqIGF3YWl0IGNvbGxlY3Rpb24uaW5zZXJ0KFsxLjAsIDIuMCwgLi4uXSwgeyBzb3VyY2U6ICd3ZWInIH0pO1xuICogY29uc3QgcmVzdWx0cyA9IGF3YWl0IGNvbGxlY3Rpb24uc2VhcmNoKHF1ZXJ5VmVjdG9yLCAxMCk7XG4gKiBgYGBcbiAqL1xuXG5pbXBvcnQgeyBTb2NoREJFcnJvciwgRGF0YWJhc2VFcnJvciB9IGZyb20gJy4vZXJyb3JzJztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gTmFtZXNwYWNlIENvbmZpZ3VyYXRpb25cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuZXhwb3J0IGludGVyZmFjZSBOYW1lc3BhY2VDb25maWcge1xuICBuYW1lOiBzdHJpbmc7XG4gIGRpc3BsYXlOYW1lPzogc3RyaW5nO1xuICBsYWJlbHM/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+O1xuICByZWFkT25seT86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBjbGFzcyBOYW1lc3BhY2VOb3RGb3VuZEVycm9yIGV4dGVuZHMgU29jaERCRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihuYW1lc3BhY2U6IHN0cmluZykge1xuICAgIHN1cGVyKGBOYW1lc3BhY2Ugbm90IGZvdW5kOiAke25hbWVzcGFjZX1gKTtcbiAgICB0aGlzLm5hbWUgPSAnTmFtZXNwYWNlTm90Rm91bmRFcnJvcic7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIE5hbWVzcGFjZUV4aXN0c0Vycm9yIGV4dGVuZHMgU29jaERCRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihuYW1lc3BhY2U6IHN0cmluZykge1xuICAgIHN1cGVyKGBOYW1lc3BhY2UgYWxyZWFkeSBleGlzdHM6ICR7bmFtZXNwYWNlfWApO1xuICAgIHRoaXMubmFtZSA9ICdOYW1lc3BhY2VFeGlzdHNFcnJvcic7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIENvbGxlY3Rpb25Ob3RGb3VuZEVycm9yIGV4dGVuZHMgU29jaERCRXJyb3Ige1xuICBjb25zdHJ1Y3Rvcihjb2xsZWN0aW9uOiBzdHJpbmcpIHtcbiAgICBzdXBlcihgQ29sbGVjdGlvbiBub3QgZm91bmQ6ICR7Y29sbGVjdGlvbn1gKTtcbiAgICB0aGlzLm5hbWUgPSAnQ29sbGVjdGlvbk5vdEZvdW5kRXJyb3InO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBDb2xsZWN0aW9uRXhpc3RzRXJyb3IgZXh0ZW5kcyBTb2NoREJFcnJvciB7XG4gIGNvbnN0cnVjdG9yKGNvbGxlY3Rpb246IHN0cmluZykge1xuICAgIHN1cGVyKGBDb2xsZWN0aW9uIGFscmVhZHkgZXhpc3RzOiAke2NvbGxlY3Rpb259YCk7XG4gICAgdGhpcy5uYW1lID0gJ0NvbGxlY3Rpb25FeGlzdHNFcnJvcic7XG4gIH1cbn1cblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gQ29sbGVjdGlvbiBDb25maWd1cmF0aW9uXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCBlbnVtIERpc3RhbmNlTWV0cmljIHtcbiAgQ29zaW5lID0gJ2Nvc2luZScsXG4gIEV1Y2xpZGVhbiA9ICdldWNsaWRlYW4nLFxuICBEb3RQcm9kdWN0ID0gJ2RvdCcsXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29sbGVjdGlvbkNvbmZpZyB7XG4gIG5hbWU6IHN0cmluZztcbiAgZGltZW5zaW9uPzogbnVtYmVyO1xuICBtZXRyaWM/OiBEaXN0YW5jZU1ldHJpYztcbiAgaW5kZXhlZD86IGJvb2xlYW47XG4gIGhuc3dNPzogbnVtYmVyO1xuICBobnN3RWZDb25zdHJ1Y3Rpb24/OiBudW1iZXI7XG4gIG1ldGFkYXRhPzogUmVjb3JkPHN0cmluZywgYW55Pjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTZWFyY2hSZXF1ZXN0IHtcbiAgcXVlcnlWZWN0b3I6IG51bWJlcltdO1xuICBrOiBudW1iZXI7XG4gIGZpbHRlcj86IFJlY29yZDxzdHJpbmcsIGFueT47XG4gIGluY2x1ZGVNZXRhZGF0YT86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2VhcmNoUmVzdWx0IHtcbiAgaWQ6IHN0cmluZztcbiAgc2NvcmU6IG51bWJlcjtcbiAgdmVjdG9yPzogbnVtYmVyW107XG4gIG1ldGFkYXRhPzogUmVjb3JkPHN0cmluZywgYW55Pjtcbn1cblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gQ29sbGVjdGlvbiBIYW5kbGVcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBJbi1tZW1vcnkgdmVjdG9yIGluZGV4IGZvciBzeW5jaHJvbm91cyBzZWFyY2hcbiAqIFVzZXMgYSBzaW1wbGUgYnV0IGVmZmljaWVudCBhcHByb2FjaCBmb3Igc21hbGwtbWVkaXVtIGRhdGFzZXRzXG4gKi9cbmNsYXNzIFZlY3RvckluZGV4IHtcbiAgcHJpdmF0ZSB2ZWN0b3JzOiBNYXA8c3RyaW5nLCB7IHZlY3RvcjogbnVtYmVyW107IG1ldGFkYXRhPzogUmVjb3JkPHN0cmluZywgYW55PiB9PiA9IG5ldyBNYXAoKTtcbiAgcHJpdmF0ZSBkaW1lbnNpb246IG51bWJlcjtcbiAgcHJpdmF0ZSBtZXRyaWM6IERpc3RhbmNlTWV0cmljO1xuXG4gIGNvbnN0cnVjdG9yKGRpbWVuc2lvbjogbnVtYmVyLCBtZXRyaWM6IERpc3RhbmNlTWV0cmljID0gRGlzdGFuY2VNZXRyaWMuQ29zaW5lKSB7XG4gICAgdGhpcy5kaW1lbnNpb24gPSBkaW1lbnNpb247XG4gICAgdGhpcy5tZXRyaWMgPSBtZXRyaWM7XG4gIH1cblxuICBhZGQoaWQ6IHN0cmluZywgdmVjdG9yOiBudW1iZXJbXSwgbWV0YWRhdGE/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+KTogdm9pZCB7XG4gICAgaWYgKHZlY3Rvci5sZW5ndGggIT09IHRoaXMuZGltZW5zaW9uKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYFZlY3RvciBkaW1lbnNpb24gbWlzbWF0Y2g6IGV4cGVjdGVkICR7dGhpcy5kaW1lbnNpb259LCBnb3QgJHt2ZWN0b3IubGVuZ3RofWApO1xuICAgIH1cbiAgICB0aGlzLnZlY3RvcnMuc2V0KGlkLCB7IHZlY3RvciwgbWV0YWRhdGEgfSk7XG4gIH1cblxuICByZW1vdmUoaWQ6IHN0cmluZyk6IHZvaWQge1xuICAgIHRoaXMudmVjdG9ycy5kZWxldGUoaWQpO1xuICB9XG5cbiAgc2VhcmNoKHF1ZXJ5VmVjdG9yOiBudW1iZXJbXSwgazogbnVtYmVyLCBmaWx0ZXI/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+KTogU2VhcmNoUmVzdWx0W10ge1xuICAgIGNvbnN0IHJlc3VsdHM6IFNlYXJjaFJlc3VsdFtdID0gW107XG5cbiAgICBmb3IgKGNvbnN0IFtpZCwgZGF0YV0gb2YgdGhpcy52ZWN0b3JzKSB7XG4gICAgICAvLyBBcHBseSBtZXRhZGF0YSBmaWx0ZXIgaWYgcHJvdmlkZWRcbiAgICAgIGlmIChmaWx0ZXIgJiYgIXRoaXMubWF0Y2hlc0ZpbHRlcihkYXRhLm1ldGFkYXRhLCBmaWx0ZXIpKSB7XG4gICAgICAgIGNvbnRpbnVlO1xuICAgICAgfVxuXG4gICAgICBjb25zdCBzY29yZSA9IHRoaXMuY2FsY3VsYXRlU2ltaWxhcml0eShxdWVyeVZlY3RvciwgZGF0YS52ZWN0b3IpO1xuICAgICAgcmVzdWx0cy5wdXNoKHtcbiAgICAgICAgaWQsXG4gICAgICAgIHNjb3JlLFxuICAgICAgICB2ZWN0b3I6IGRhdGEudmVjdG9yLFxuICAgICAgICBtZXRhZGF0YTogZGF0YS5tZXRhZGF0YSxcbiAgICAgIH0pO1xuICAgIH1cblxuICAgIC8vIFNvcnQgYnkgc2NvcmUgKGhpZ2hlciBpcyBiZXR0ZXIgZm9yIHNpbWlsYXJpdHkpXG4gICAgcmVzdWx0cy5zb3J0KChhLCBiKSA9PiBiLnNjb3JlIC0gYS5zY29yZSk7XG5cbiAgICByZXR1cm4gcmVzdWx0cy5zbGljZSgwLCBrKTtcbiAgfVxuXG4gIHNpemUoKTogbnVtYmVyIHtcbiAgICByZXR1cm4gdGhpcy52ZWN0b3JzLnNpemU7XG4gIH1cblxuICBwcml2YXRlIGNhbGN1bGF0ZVNpbWlsYXJpdHkoYTogbnVtYmVyW10sIGI6IG51bWJlcltdKTogbnVtYmVyIHtcbiAgICBzd2l0Y2ggKHRoaXMubWV0cmljKSB7XG4gICAgICBjYXNlIERpc3RhbmNlTWV0cmljLkNvc2luZTpcbiAgICAgICAgcmV0dXJuIHRoaXMuY29zaW5lU2ltaWxhcml0eShhLCBiKTtcbiAgICAgIGNhc2UgRGlzdGFuY2VNZXRyaWMuRXVjbGlkZWFuOlxuICAgICAgICByZXR1cm4gMSAvICgxICsgdGhpcy5ldWNsaWRlYW5EaXN0YW5jZShhLCBiKSk7XG4gICAgICBjYXNlIERpc3RhbmNlTWV0cmljLkRvdFByb2R1Y3Q6XG4gICAgICAgIHJldHVybiB0aGlzLmRvdFByb2R1Y3QoYSwgYik7XG4gICAgICBkZWZhdWx0OlxuICAgICAgICByZXR1cm4gdGhpcy5jb3NpbmVTaW1pbGFyaXR5KGEsIGIpO1xuICAgIH1cbiAgfVxuXG4gIHByaXZhdGUgY29zaW5lU2ltaWxhcml0eShhOiBudW1iZXJbXSwgYjogbnVtYmVyW10pOiBudW1iZXIge1xuICAgIGxldCBkb3RQcm9kdWN0ID0gMDtcbiAgICBsZXQgbm9ybUEgPSAwO1xuICAgIGxldCBub3JtQiA9IDA7XG5cbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IGEubGVuZ3RoOyBpKyspIHtcbiAgICAgIGRvdFByb2R1Y3QgKz0gYVtpXSAqIGJbaV07XG4gICAgICBub3JtQSArPSBhW2ldICogYVtpXTtcbiAgICAgIG5vcm1CICs9IGJbaV0gKiBiW2ldO1xuICAgIH1cblxuICAgIGlmIChub3JtQSA9PT0gMCB8fCBub3JtQiA9PT0gMCkgcmV0dXJuIDA7XG4gICAgcmV0dXJuIGRvdFByb2R1Y3QgLyAoTWF0aC5zcXJ0KG5vcm1BKSAqIE1hdGguc3FydChub3JtQikpO1xuICB9XG5cbiAgcHJpdmF0ZSBldWNsaWRlYW5EaXN0YW5jZShhOiBudW1iZXJbXSwgYjogbnVtYmVyW10pOiBudW1iZXIge1xuICAgIGxldCBzdW0gPSAwO1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgYS5sZW5ndGg7IGkrKykge1xuICAgICAgY29uc3QgZGlmZiA9IGFbaV0gLSBiW2ldO1xuICAgICAgc3VtICs9IGRpZmYgKiBkaWZmO1xuICAgIH1cbiAgICByZXR1cm4gTWF0aC5zcXJ0KHN1bSk7XG4gIH1cblxuICBwcml2YXRlIGRvdFByb2R1Y3QoYTogbnVtYmVyW10sIGI6IG51bWJlcltdKTogbnVtYmVyIHtcbiAgICBsZXQgc3VtID0gMDtcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IGEubGVuZ3RoOyBpKyspIHtcbiAgICAgIHN1bSArPSBhW2ldICogYltpXTtcbiAgICB9XG4gICAgcmV0dXJuIHN1bTtcbiAgfVxuXG4gIHByaXZhdGUgbWF0Y2hlc0ZpbHRlcihtZXRhZGF0YTogUmVjb3JkPHN0cmluZywgYW55PiB8IHVuZGVmaW5lZCwgZmlsdGVyOiBSZWNvcmQ8c3RyaW5nLCBhbnk+KTogYm9vbGVhbiB7XG4gICAgaWYgKCFtZXRhZGF0YSkgcmV0dXJuIGZhbHNlO1xuICAgIFxuICAgIGZvciAoY29uc3QgW2tleSwgdmFsdWVdIG9mIE9iamVjdC5lbnRyaWVzKGZpbHRlcikpIHtcbiAgICAgIGlmIChtZXRhZGF0YVtrZXldICE9PSB2YWx1ZSkge1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiB0cnVlO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBDb2xsZWN0aW9uIHtcbiAgcHJpdmF0ZSB2ZWN0b3JJbmRleDogVmVjdG9ySW5kZXg7XG4gIHByaXZhdGUgX2luZGV4UmVhZHkgPSBmYWxzZTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIGRiOiBhbnksXG4gICAgcHJpdmF0ZSBuYW1lc3BhY2U6IHN0cmluZyxcbiAgICBwcml2YXRlIG5hbWU6IHN0cmluZyxcbiAgICBwcml2YXRlIGNvbmZpZzogQ29sbGVjdGlvbkNvbmZpZ1xuICApIHtcbiAgICB0aGlzLnZlY3RvckluZGV4ID0gbmV3IFZlY3RvckluZGV4KFxuICAgICAgY29uZmlnLmRpbWVuc2lvbiB8fCAzODQsXG4gICAgICBjb25maWcubWV0cmljIHx8IERpc3RhbmNlTWV0cmljLkNvc2luZVxuICAgICk7XG4gIH1cblxuICAvKipcbiAgICogSW5zZXJ0IGEgdmVjdG9yIHdpdGggb3B0aW9uYWwgbWV0YWRhdGFcbiAgICogVmVjdG9yIGlzIGltbWVkaWF0ZWx5IGluZGV4ZWQgKHN5bmNocm9ub3VzKVxuICAgKi9cbiAgYXN5bmMgaW5zZXJ0KFxuICAgIHZlY3RvcjogbnVtYmVyW10sXG4gICAgbWV0YWRhdGE/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+LFxuICAgIGlkPzogc3RyaW5nXG4gICk6IFByb21pc2U8c3RyaW5nPiB7XG4gICAgaWYgKHRoaXMuY29uZmlnLmRpbWVuc2lvbiAmJiB2ZWN0b3IubGVuZ3RoICE9PSB0aGlzLmNvbmZpZy5kaW1lbnNpb24pIHtcbiAgICAgIHRocm93IG5ldyBEYXRhYmFzZUVycm9yKFxuICAgICAgICBgVmVjdG9yIGRpbWVuc2lvbiBtaXNtYXRjaDogZXhwZWN0ZWQgJHt0aGlzLmNvbmZpZy5kaW1lbnNpb259LCBnb3QgJHt2ZWN0b3IubGVuZ3RofWBcbiAgICAgICk7XG4gICAgfVxuXG4gICAgY29uc3QgdmVjdG9ySWQgPSBpZCB8fCB0aGlzLmdlbmVyYXRlSWQoKTtcbiAgICBjb25zdCBrZXkgPSB0aGlzLnZlY3RvcktleSh2ZWN0b3JJZCk7XG4gICAgXG4gICAgY29uc3QgZGF0YSA9IHtcbiAgICAgIHZlY3RvcixcbiAgICAgIG1ldGFkYXRhOiBtZXRhZGF0YSB8fCB7fSxcbiAgICAgIHRpbWVzdGFtcDogRGF0ZS5ub3coKSxcbiAgICB9O1xuXG4gICAgLy8gU3RvcmUgdG8gZGF0YWJhc2VcbiAgICBhd2FpdCB0aGlzLmRiLnB1dChCdWZmZXIuZnJvbShrZXkpLCBCdWZmZXIuZnJvbShKU09OLnN0cmluZ2lmeShkYXRhKSkpO1xuICAgIFxuICAgIC8vIFNZTkNIUk9OT1VTTFkgYWRkIHRvIGluLW1lbW9yeSBpbmRleFxuICAgIHRoaXMudmVjdG9ySW5kZXguYWRkKHZlY3RvcklkLCB2ZWN0b3IsIG1ldGFkYXRhKTtcblxuICAgIHJldHVybiB2ZWN0b3JJZDtcbiAgfVxuXG4gIC8qKlxuICAgKiBJbnNlcnQgbXVsdGlwbGUgdmVjdG9yc1xuICAgKiBBbGwgdmVjdG9ycyBhcmUgaW5kZXhlZCBzeW5jaHJvbm91c2x5IGFmdGVyIGluc2VydGlvblxuICAgKi9cbiAgYXN5bmMgaW5zZXJ0TWFueShcbiAgICB2ZWN0b3JzOiBudW1iZXJbXVtdLFxuICAgIG1ldGFkYXRhcz86IFJlY29yZDxzdHJpbmcsIGFueT5bXSxcbiAgICBpZHM/OiBzdHJpbmdbXVxuICApOiBQcm9taXNlPHN0cmluZ1tdPiB7XG4gICAgY29uc3QgcmVzdWx0SWRzOiBzdHJpbmdbXSA9IFtdO1xuICAgIFxuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdmVjdG9ycy5sZW5ndGg7IGkrKykge1xuICAgICAgY29uc3QgaWQgPSBpZHMgPyBpZHNbaV0gOiB1bmRlZmluZWQ7XG4gICAgICBjb25zdCBtZXRhZGF0YSA9IG1ldGFkYXRhcyA/IG1ldGFkYXRhc1tpXSA6IHVuZGVmaW5lZDtcbiAgICAgIGNvbnN0IHJlc3VsdElkID0gYXdhaXQgdGhpcy5pbnNlcnQodmVjdG9yc1tpXSwgbWV0YWRhdGEsIGlkKTtcbiAgICAgIHJlc3VsdElkcy5wdXNoKHJlc3VsdElkKTtcbiAgICB9XG4gICAgXG4gICAgcmV0dXJuIHJlc3VsdElkcztcbiAgfVxuXG4gIC8qKlxuICAgKiBSZWJ1aWxkIGluZGV4IGZyb20gZGF0YWJhc2UgKGZvciByZWNvdmVyeS9zdGFydHVwKVxuICAgKi9cbiAgYXN5bmMgcmVidWlsZEluZGV4KCk6IFByb21pc2U8bnVtYmVyPiB7XG4gICAgY29uc3QgcHJlZml4ID0gdGhpcy52ZWN0b3JLZXlQcmVmaXgoKTtcbiAgICBsZXQgY291bnQgPSAwO1xuXG4gICAgdHJ5IHtcbiAgICAgIGZvciBhd2FpdCAoY29uc3QgW2tleUJ1ZmZlciwgdmFsdWVCdWZmZXJdIG9mIHRoaXMuZGIuc2NhblByZWZpeChCdWZmZXIuZnJvbShwcmVmaXgpKSkge1xuICAgICAgICBjb25zdCBrZXkgPSBrZXlCdWZmZXIudG9TdHJpbmcoKTtcbiAgICAgICAgY29uc3QgaWQgPSBrZXkucmVwbGFjZShwcmVmaXgsICcnKTtcbiAgICAgICAgY29uc3QgZGF0YSA9IEpTT04ucGFyc2UodmFsdWVCdWZmZXIudG9TdHJpbmcoKSk7XG4gICAgICAgIFxuICAgICAgICB0aGlzLnZlY3RvckluZGV4LmFkZChpZCwgZGF0YS52ZWN0b3IsIGRhdGEubWV0YWRhdGEpO1xuICAgICAgICBjb3VudCsrO1xuICAgICAgfVxuICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICBjb25zb2xlLndhcm4oJ1tTb2NoREJdIEVycm9yIHJlYnVpbGRpbmcgdmVjdG9yIGluZGV4OicsIGVycm9yKTtcbiAgICB9XG5cbiAgICB0aGlzLl9pbmRleFJlYWR5ID0gdHJ1ZTtcbiAgICByZXR1cm4gY291bnQ7XG4gIH1cblxuICAvKipcbiAgICogQ2hlY2sgaWYgaW5kZXggaXMgcmVhZHkgKGxvYWRlZCBmcm9tIGRpc2spXG4gICAqL1xuICBnZXQgaXNJbmRleFJlYWR5KCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLl9pbmRleFJlYWR5IHx8IHRoaXMudmVjdG9ySW5kZXguc2l6ZSgpID4gMDtcbiAgfVxuXG4gIC8qKlxuICAgKiBTZWFyY2ggZm9yIHNpbWlsYXIgdmVjdG9yc1xuICAgKiBVc2VzIHN5bmNocm9ub3VzIGluLW1lbW9yeSBpbmRleCAtIG5vIGRlbGF5XG4gICAqL1xuICBhc3luYyBzZWFyY2gocmVxdWVzdDogU2VhcmNoUmVxdWVzdCk6IFByb21pc2U8U2VhcmNoUmVzdWx0W10+IHtcbiAgICAvLyBBdXRvLXJlYnVpbGQgaW5kZXggaWYgZW1wdHkgYnV0IHRoZXJlIG1pZ2h0IGJlIGRhdGFcbiAgICBpZiAoIXRoaXMuaXNJbmRleFJlYWR5ICYmIHRoaXMudmVjdG9ySW5kZXguc2l6ZSgpID09PSAwKSB7XG4gICAgICBhd2FpdCB0aGlzLnJlYnVpbGRJbmRleCgpO1xuICAgIH1cblxuICAgIGNvbnN0IHJlc3VsdHMgPSB0aGlzLnZlY3RvckluZGV4LnNlYXJjaChcbiAgICAgIHJlcXVlc3QucXVlcnlWZWN0b3IsXG4gICAgICByZXF1ZXN0LmssXG4gICAgICByZXF1ZXN0LmZpbHRlclxuICAgICk7XG5cbiAgICAvLyBNYXAgcmVzdWx0cyBiYXNlZCBvbiBpbmNsdWRlTWV0YWRhdGEgZmxhZ1xuICAgIHJldHVybiByZXN1bHRzLm1hcChyID0+ICh7XG4gICAgICBpZDogci5pZCxcbiAgICAgIHNjb3JlOiByLnNjb3JlLFxuICAgICAgdmVjdG9yOiByZXF1ZXN0LmluY2x1ZGVNZXRhZGF0YSA/IHIudmVjdG9yIDogdW5kZWZpbmVkLFxuICAgICAgbWV0YWRhdGE6IHJlcXVlc3QuaW5jbHVkZU1ldGFkYXRhID8gci5tZXRhZGF0YSA6IHVuZGVmaW5lZCxcbiAgICB9KSk7XG4gIH1cblxuICAvKipcbiAgICogR2V0IGEgdmVjdG9yIGJ5IElEXG4gICAqL1xuICBhc3luYyBnZXQoaWQ6IHN0cmluZyk6IFByb21pc2U8eyB2ZWN0b3I6IG51bWJlcltdOyBtZXRhZGF0YT86IFJlY29yZDxzdHJpbmcsIGFueT4gfSB8IG51bGw+IHtcbiAgICBjb25zdCBrZXkgPSB0aGlzLnZlY3RvcktleShpZCk7XG4gICAgY29uc3QgdmFsdWUgPSBhd2FpdCB0aGlzLmRiLmdldChCdWZmZXIuZnJvbShrZXkpKTtcbiAgICBcbiAgICBpZiAoIXZhbHVlKSB7XG4gICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG4gICAgXG4gICAgY29uc3QgZGF0YSA9IEpTT04ucGFyc2UodmFsdWUudG9TdHJpbmcoKSk7XG4gICAgcmV0dXJuIHtcbiAgICAgIHZlY3RvcjogZGF0YS52ZWN0b3IsXG4gICAgICBtZXRhZGF0YTogZGF0YS5tZXRhZGF0YSxcbiAgICB9O1xuICB9XG5cbiAgLyoqXG4gICAqIERlbGV0ZSBhIHZlY3RvciBieSBJRFxuICAgKi9cbiAgYXN5bmMgZGVsZXRlKGlkOiBzdHJpbmcpOiBQcm9taXNlPGJvb2xlYW4+IHtcbiAgICBjb25zdCBrZXkgPSB0aGlzLnZlY3RvcktleShpZCk7XG4gICAgYXdhaXQgdGhpcy5kYi5kZWxldGUoQnVmZmVyLmZyb20oa2V5KSk7XG4gICAgLy8gUmVtb3ZlIGZyb20gaW4tbWVtb3J5IGluZGV4XG4gICAgdGhpcy52ZWN0b3JJbmRleC5yZW1vdmUoaWQpO1xuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgLyoqXG4gICAqIENvdW50IHZlY3RvcnMgaW4gY29sbGVjdGlvblxuICAgKi9cbiAgYXN5bmMgY291bnQoKTogUHJvbWlzZTxudW1iZXI+IHtcbiAgICAvLyBJZiBpbmRleCBpcyBsb2FkZWQsIHJldHVybiBmcm9tIGluZGV4XG4gICAgaWYgKHRoaXMuaXNJbmRleFJlYWR5KSB7XG4gICAgICByZXR1cm4gdGhpcy52ZWN0b3JJbmRleC5zaXplKCk7XG4gICAgfVxuICAgIC8vIE90aGVyd2lzZSByZWJ1aWxkIGFuZCBjb3VudFxuICAgIHJldHVybiBhd2FpdCB0aGlzLnJlYnVpbGRJbmRleCgpO1xuICB9XG5cbiAgLy8gSGVscGVyIG1ldGhvZHNcbiAgcHJpdmF0ZSB2ZWN0b3JLZXkoaWQ6IHN0cmluZyk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGBfY29sbGVjdGlvbi8ke3RoaXMubmFtZXNwYWNlfS8ke3RoaXMubmFtZX0vdmVjdG9ycy8ke2lkfWA7XG4gIH1cblxuICBwcml2YXRlIHZlY3RvcktleVByZWZpeCgpOiBzdHJpbmcge1xuICAgIHJldHVybiBgX2NvbGxlY3Rpb24vJHt0aGlzLm5hbWVzcGFjZX0vJHt0aGlzLm5hbWV9L3ZlY3RvcnMvYDtcbiAgfVxuXG4gIHByaXZhdGUgbWV0YWRhdGFLZXkoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gYF9jb2xsZWN0aW9uLyR7dGhpcy5uYW1lc3BhY2V9LyR7dGhpcy5uYW1lfS9tZXRhZGF0YWA7XG4gIH1cblxuICBwcml2YXRlIGdlbmVyYXRlSWQoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gYCR7RGF0ZS5ub3coKX0tJHtNYXRoLnJhbmRvbSgpLnRvU3RyaW5nKDM2KS5zdWJzdHIoMiwgOSl9YDtcbiAgfVxuXG4gIC8vIENhbGN1bGF0ZSBjb3NpbmUgc2ltaWxhcml0eVxuICBwcml2YXRlIGNvc2luZVNpbWlsYXJpdHkoYTogbnVtYmVyW10sIGI6IG51bWJlcltdKTogbnVtYmVyIHtcbiAgICBsZXQgZG90UHJvZHVjdCA9IDA7XG4gICAgbGV0IG5vcm1BID0gMDtcbiAgICBsZXQgbm9ybUIgPSAwO1xuICAgIFxuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgYS5sZW5ndGg7IGkrKykge1xuICAgICAgZG90UHJvZHVjdCArPSBhW2ldICogYltpXTtcbiAgICAgIG5vcm1BICs9IGFbaV0gKiBhW2ldO1xuICAgICAgbm9ybUIgKz0gYltpXSAqIGJbaV07XG4gICAgfVxuICAgIFxuICAgIHJldHVybiBkb3RQcm9kdWN0IC8gKE1hdGguc3FydChub3JtQSkgKiBNYXRoLnNxcnQobm9ybUIpKTtcbiAgfVxufVxuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBOYW1lc3BhY2UgSGFuZGxlXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCBjbGFzcyBOYW1lc3BhY2Uge1xuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIGRiOiBhbnksXG4gICAgcHJpdmF0ZSBuYW1lOiBzdHJpbmcsXG4gICAgcHJpdmF0ZSBjb25maWc6IE5hbWVzcGFjZUNvbmZpZ1xuICApIHt9XG5cbiAgLyoqXG4gICAqIENyZWF0ZSBhIG5ldyBjb2xsZWN0aW9uIGluIHRoaXMgbmFtZXNwYWNlXG4gICAqL1xuICBhc3luYyBjcmVhdGVDb2xsZWN0aW9uKGNvbmZpZzogQ29sbGVjdGlvbkNvbmZpZyk6IFByb21pc2U8Q29sbGVjdGlvbj4ge1xuICAgIGNvbnN0IG1ldGFkYXRhS2V5ID0gYF9jb2xsZWN0aW9uLyR7dGhpcy5uYW1lfS8ke2NvbmZpZy5uYW1lfS9tZXRhZGF0YWA7XG4gICAgXG4gICAgLy8gQ2hlY2sgaWYgY29sbGVjdGlvbiBhbHJlYWR5IGV4aXN0c1xuICAgIGNvbnN0IGV4aXN0aW5nID0gYXdhaXQgdGhpcy5kYi5nZXQoQnVmZmVyLmZyb20obWV0YWRhdGFLZXkpKTtcbiAgICBpZiAoZXhpc3RpbmcpIHtcbiAgICAgIHRocm93IG5ldyBDb2xsZWN0aW9uRXhpc3RzRXJyb3IoY29uZmlnLm5hbWUpO1xuICAgIH1cblxuICAgIC8vIFN0b3JlIGNvbGxlY3Rpb24gbWV0YWRhdGFcbiAgICBjb25zdCBtZXRhZGF0YSA9IHtcbiAgICAgIC4uLmNvbmZpZyxcbiAgICAgIGNyZWF0ZWRBdDogRGF0ZS5ub3coKSxcbiAgICB9O1xuICAgIFxuICAgIGF3YWl0IHRoaXMuZGIucHV0KFxuICAgICAgQnVmZmVyLmZyb20obWV0YWRhdGFLZXkpLFxuICAgICAgQnVmZmVyLmZyb20oSlNPTi5zdHJpbmdpZnkobWV0YWRhdGEpKVxuICAgICk7XG5cbiAgICByZXR1cm4gbmV3IENvbGxlY3Rpb24odGhpcy5kYiwgdGhpcy5uYW1lLCBjb25maWcubmFtZSwgY29uZmlnKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgYW4gZXhpc3RpbmcgY29sbGVjdGlvblxuICAgKi9cbiAgYXN5bmMgY29sbGVjdGlvbihuYW1lOiBzdHJpbmcpOiBQcm9taXNlPENvbGxlY3Rpb24+IHtcbiAgICBjb25zdCBtZXRhZGF0YUtleSA9IGBfY29sbGVjdGlvbi8ke3RoaXMubmFtZX0vJHtuYW1lfS9tZXRhZGF0YWA7XG4gICAgY29uc3QgbWV0YWRhdGEgPSBhd2FpdCB0aGlzLmRiLmdldChCdWZmZXIuZnJvbShtZXRhZGF0YUtleSkpO1xuICAgIFxuICAgIGlmICghbWV0YWRhdGEpIHtcbiAgICAgIHRocm93IG5ldyBDb2xsZWN0aW9uTm90Rm91bmRFcnJvcihuYW1lKTtcbiAgICB9XG5cbiAgICBjb25zdCBjb25maWcgPSBKU09OLnBhcnNlKG1ldGFkYXRhLnRvU3RyaW5nKCkpO1xuICAgIHJldHVybiBuZXcgQ29sbGVjdGlvbih0aGlzLmRiLCB0aGlzLm5hbWUsIG5hbWUsIGNvbmZpZyk7XG4gIH1cblxuICAvKipcbiAgICogR2V0IG9yIGNyZWF0ZSBhIGNvbGxlY3Rpb25cbiAgICovXG4gIGFzeW5jIGdldE9yQ3JlYXRlQ29sbGVjdGlvbihjb25maWc6IENvbGxlY3Rpb25Db25maWcpOiBQcm9taXNlPENvbGxlY3Rpb24+IHtcbiAgICB0cnkge1xuICAgICAgcmV0dXJuIGF3YWl0IHRoaXMuY29sbGVjdGlvbihjb25maWcubmFtZSk7XG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIGlmIChlcnJvciBpbnN0YW5jZW9mIENvbGxlY3Rpb25Ob3RGb3VuZEVycm9yKSB7XG4gICAgICAgIHJldHVybiBhd2FpdCB0aGlzLmNyZWF0ZUNvbGxlY3Rpb24oY29uZmlnKTtcbiAgICAgIH1cbiAgICAgIHRocm93IGVycm9yO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBEZWxldGUgYSBjb2xsZWN0aW9uXG4gICAqL1xuICBhc3luYyBkZWxldGVDb2xsZWN0aW9uKG5hbWU6IHN0cmluZyk6IFByb21pc2U8Ym9vbGVhbj4ge1xuICAgIGNvbnN0IG1ldGFkYXRhS2V5ID0gYF9jb2xsZWN0aW9uLyR7dGhpcy5uYW1lfS8ke25hbWV9L21ldGFkYXRhYDtcbiAgICBjb25zdCBwcmVmaXggPSBgX2NvbGxlY3Rpb24vJHt0aGlzLm5hbWV9LyR7bmFtZX0vYDtcbiAgICBcbiAgICAvLyBUT0RPOiBEZWxldGUgYWxsIGtleXMgd2l0aCBwcmVmaXhcbiAgICBhd2FpdCB0aGlzLmRiLmRlbGV0ZShCdWZmZXIuZnJvbShtZXRhZGF0YUtleSkpO1xuICAgIFxuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgLyoqXG4gICAqIExpc3QgYWxsIGNvbGxlY3Rpb25zIGluIHRoaXMgbmFtZXNwYWNlXG4gICAqL1xuICBhc3luYyBsaXN0Q29sbGVjdGlvbnMoKTogUHJvbWlzZTxzdHJpbmdbXT4ge1xuICAgIC8vIFRPRE86IEltcGxlbWVudCBlZmZpY2llbnQgbGlzdGluZyB3aXRoIHJhbmdlIHF1ZXJpZXNcbiAgICByZXR1cm4gW107XG4gIH1cblxuICBnZXROYW1lKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMubmFtZTtcbiAgfVxuXG4gIGdldENvbmZpZygpOiBOYW1lc3BhY2VDb25maWcge1xuICAgIHJldHVybiB7IC4uLnRoaXMuY29uZmlnIH07XG4gIH1cbn1cbiJdfQ==