@sochdb/sochdb 0.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +201 -0
- package/README.md +3349 -0
- package/_bin/aarch64-apple-darwin/libsochdb_storage.dylib +0 -0
- package/_bin/aarch64-apple-darwin/sochdb-bulk +0 -0
- package/_bin/aarch64-apple-darwin/sochdb-grpc-server +0 -0
- package/_bin/aarch64-apple-darwin/sochdb-server +0 -0
- package/_bin/x86_64-pc-windows-msvc/sochdb-bulk.exe +0 -0
- package/_bin/x86_64-pc-windows-msvc/sochdb-grpc-server.exe +0 -0
- package/_bin/x86_64-pc-windows-msvc/sochdb_storage.dll +0 -0
- package/_bin/x86_64-unknown-linux-gnu/libsochdb_storage.so +0 -0
- package/_bin/x86_64-unknown-linux-gnu/sochdb-bulk +0 -0
- package/_bin/x86_64-unknown-linux-gnu/sochdb-grpc-server +0 -0
- package/_bin/x86_64-unknown-linux-gnu/sochdb-server +0 -0
- package/bin/sochdb-bulk.js +80 -0
- package/bin/sochdb-grpc-server.js +80 -0
- package/bin/sochdb-server.js +84 -0
- package/dist/cjs/analytics.js +196 -0
- package/dist/cjs/database.js +929 -0
- package/dist/cjs/embedded/database.js +236 -0
- package/dist/cjs/embedded/ffi/bindings.js +113 -0
- package/dist/cjs/embedded/ffi/library-finder.js +135 -0
- package/dist/cjs/embedded/index.js +14 -0
- package/dist/cjs/embedded/transaction.js +172 -0
- package/dist/cjs/errors.js +71 -0
- package/dist/cjs/format.js +176 -0
- package/dist/cjs/grpc-client.js +328 -0
- package/dist/cjs/index.js +75 -0
- package/dist/cjs/ipc-client.js +504 -0
- package/dist/cjs/query.js +154 -0
- package/dist/cjs/server-manager.js +295 -0
- package/dist/cjs/sql-engine.js +874 -0
- package/dist/esm/analytics.js +196 -0
- package/dist/esm/database.js +931 -0
- package/dist/esm/embedded/database.js +239 -0
- package/dist/esm/embedded/ffi/bindings.js +142 -0
- package/dist/esm/embedded/ffi/library-finder.js +135 -0
- package/dist/esm/embedded/index.js +14 -0
- package/dist/esm/embedded/transaction.js +176 -0
- package/dist/esm/errors.js +71 -0
- package/dist/esm/format.js +179 -0
- package/dist/esm/grpc-client.js +333 -0
- package/dist/esm/index.js +75 -0
- package/dist/esm/ipc-client.js +505 -0
- package/dist/esm/query.js +159 -0
- package/dist/esm/server-manager.js +295 -0
- package/dist/esm/sql-engine.js +875 -0
- package/dist/types/analytics.d.ts +66 -0
- package/dist/types/analytics.d.ts.map +1 -0
- package/dist/types/database.d.ts +523 -0
- package/dist/types/database.d.ts.map +1 -0
- package/dist/types/embedded/database.d.ts +105 -0
- package/dist/types/embedded/database.d.ts.map +1 -0
- package/dist/types/embedded/ffi/bindings.d.ts +24 -0
- package/dist/types/embedded/ffi/bindings.d.ts.map +1 -0
- package/dist/types/embedded/ffi/library-finder.d.ts +17 -0
- package/dist/types/embedded/ffi/library-finder.d.ts.map +1 -0
- package/dist/types/embedded/index.d.ts +9 -0
- package/dist/types/embedded/index.d.ts.map +1 -0
- package/dist/types/embedded/transaction.d.ts +21 -0
- package/dist/types/embedded/transaction.d.ts.map +1 -0
- package/dist/types/errors.d.ts +36 -0
- package/dist/types/errors.d.ts.map +1 -0
- package/dist/types/format.d.ts +117 -0
- package/dist/types/format.d.ts.map +1 -0
- package/dist/types/grpc-client.d.ts +120 -0
- package/dist/types/grpc-client.d.ts.map +1 -0
- package/dist/types/index.d.ts +50 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/ipc-client.d.ts +177 -0
- package/dist/types/ipc-client.d.ts.map +1 -0
- package/dist/types/query.d.ts +85 -0
- package/dist/types/query.d.ts.map +1 -0
- package/dist/types/server-manager.d.ts +29 -0
- package/dist/types/server-manager.d.ts.map +1 -0
- package/dist/types/sql-engine.d.ts +100 -0
- package/dist/types/sql-engine.d.ts.map +1 -0
- package/package.json +90 -0
- package/scripts/postinstall.js +50 -0
|
@@ -0,0 +1,333 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* SochDB gRPC Client - Thin SDK Wrapper
|
|
4
|
+
*
|
|
5
|
+
* This module provides a thin gRPC client wrapper for the SochDB server.
|
|
6
|
+
* All business logic runs on the server (Thick Server / Thin Client architecture).
|
|
7
|
+
*
|
|
8
|
+
* The client is approximately ~250 lines of code, delegating all operations to the server.
|
|
9
|
+
*/
|
|
10
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
11
|
+
if (k2 === undefined) k2 = k;
|
|
12
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
13
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
14
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
15
|
+
}
|
|
16
|
+
Object.defineProperty(o, k2, desc);
|
|
17
|
+
}) : (function(o, m, k, k2) {
|
|
18
|
+
if (k2 === undefined) k2 = k;
|
|
19
|
+
o[k2] = m[k];
|
|
20
|
+
}));
|
|
21
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
22
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
23
|
+
}) : function(o, v) {
|
|
24
|
+
o["default"] = v;
|
|
25
|
+
});
|
|
26
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
27
|
+
var ownKeys = function(o) {
|
|
28
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
29
|
+
var ar = [];
|
|
30
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
31
|
+
return ar;
|
|
32
|
+
};
|
|
33
|
+
return ownKeys(o);
|
|
34
|
+
};
|
|
35
|
+
return function (mod) {
|
|
36
|
+
if (mod && mod.__esModule) return mod;
|
|
37
|
+
var result = {};
|
|
38
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
39
|
+
__setModuleDefault(result, mod);
|
|
40
|
+
return result;
|
|
41
|
+
};
|
|
42
|
+
})();
|
|
43
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
44
|
+
exports.GrpcClient = exports.SochDBClient = void 0;
|
|
45
|
+
exports.connect = connect;
|
|
46
|
+
const grpc = __importStar(require("@grpc/grpc-js"));
|
|
47
|
+
const protoLoader = __importStar(require("@grpc/proto-loader"));
|
|
48
|
+
const path = __importStar(require("path"));
|
|
49
|
+
/**
|
|
50
|
+
* Thin gRPC client for SochDB.
|
|
51
|
+
*
|
|
52
|
+
* All operations are delegated to the SochDB gRPC server.
|
|
53
|
+
* This client provides a TypeScript interface over the gRPC protocol.
|
|
54
|
+
*
|
|
55
|
+
* Usage:
|
|
56
|
+
* ```typescript
|
|
57
|
+
* const client = new SochDBClient({ address: 'localhost:50051' });
|
|
58
|
+
*
|
|
59
|
+
* // Create collection
|
|
60
|
+
* await client.createCollection('docs', { dimension: 384 });
|
|
61
|
+
*
|
|
62
|
+
* // Add documents
|
|
63
|
+
* await client.addDocuments('docs', [
|
|
64
|
+
* { id: '1', content: 'Hello', embedding: [...] }
|
|
65
|
+
* ]);
|
|
66
|
+
*
|
|
67
|
+
* // Search
|
|
68
|
+
* const results = await client.search('docs', queryVector, 5);
|
|
69
|
+
* ```
|
|
70
|
+
*/
|
|
71
|
+
class SochDBClient {
|
|
72
|
+
address;
|
|
73
|
+
credentials;
|
|
74
|
+
stubs = new Map();
|
|
75
|
+
protoPath;
|
|
76
|
+
packageDefinition;
|
|
77
|
+
proto;
|
|
78
|
+
constructor(options = {}) {
|
|
79
|
+
this.address = options.address || 'localhost:50051';
|
|
80
|
+
this.credentials = options.secure
|
|
81
|
+
? grpc.credentials.createSsl()
|
|
82
|
+
: grpc.credentials.createInsecure();
|
|
83
|
+
this.protoPath = options.protoPath || path.join(__dirname, '../../proto/sochdb.proto');
|
|
84
|
+
// Load proto definition
|
|
85
|
+
this.packageDefinition = protoLoader.loadSync(this.protoPath, {
|
|
86
|
+
keepCase: false,
|
|
87
|
+
longs: String,
|
|
88
|
+
enums: String,
|
|
89
|
+
defaults: true,
|
|
90
|
+
oneofs: true,
|
|
91
|
+
});
|
|
92
|
+
const loadedPackage = grpc.loadPackageDefinition(this.packageDefinition);
|
|
93
|
+
this.proto = loadedPackage?.sochdb?.v1;
|
|
94
|
+
}
|
|
95
|
+
getStub(serviceName) {
|
|
96
|
+
if (!this.stubs.has(serviceName)) {
|
|
97
|
+
const ServiceClass = this.proto?.[serviceName];
|
|
98
|
+
if (!ServiceClass) {
|
|
99
|
+
throw new Error(`Service ${serviceName} not found in proto definition`);
|
|
100
|
+
}
|
|
101
|
+
this.stubs.set(serviceName, new ServiceClass(this.address, this.credentials));
|
|
102
|
+
}
|
|
103
|
+
return this.stubs.get(serviceName);
|
|
104
|
+
}
|
|
105
|
+
promisify(stub, method, request) {
|
|
106
|
+
return new Promise((resolve, reject) => {
|
|
107
|
+
stub[method](request, (error, response) => {
|
|
108
|
+
if (error)
|
|
109
|
+
reject(error);
|
|
110
|
+
else
|
|
111
|
+
resolve(response);
|
|
112
|
+
});
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* Close all gRPC connections.
|
|
117
|
+
*/
|
|
118
|
+
close() {
|
|
119
|
+
for (const stub of this.stubs.values()) {
|
|
120
|
+
grpc.closeClient(stub);
|
|
121
|
+
}
|
|
122
|
+
this.stubs.clear();
|
|
123
|
+
}
|
|
124
|
+
// ===========================================================================
|
|
125
|
+
// Vector Index Operations (VectorIndexService)
|
|
126
|
+
// ===========================================================================
|
|
127
|
+
async createIndex(name, dimension, options = {}) {
|
|
128
|
+
const stub = this.getStub('VectorIndexService');
|
|
129
|
+
const response = await this.promisify(stub, 'createIndex', {
|
|
130
|
+
name,
|
|
131
|
+
dimension,
|
|
132
|
+
metric: options.metric === 'l2' ? 1 : options.metric === 'dot' ? 3 : 2,
|
|
133
|
+
config: {
|
|
134
|
+
maxConnections: options.m || 16,
|
|
135
|
+
efConstruction: options.efConstruction || 200,
|
|
136
|
+
},
|
|
137
|
+
});
|
|
138
|
+
return response.success;
|
|
139
|
+
}
|
|
140
|
+
async insertVectors(indexName, ids, vectors) {
|
|
141
|
+
const stub = this.getStub('VectorIndexService');
|
|
142
|
+
const flatVectors = vectors.flat();
|
|
143
|
+
const response = await this.promisify(stub, 'insertBatch', {
|
|
144
|
+
indexName,
|
|
145
|
+
ids,
|
|
146
|
+
vectors: flatVectors,
|
|
147
|
+
});
|
|
148
|
+
return response.insertedCount;
|
|
149
|
+
}
|
|
150
|
+
async search(indexName, query, k = 10, ef = 50) {
|
|
151
|
+
const stub = this.getStub('VectorIndexService');
|
|
152
|
+
const response = await this.promisify(stub, 'search', {
|
|
153
|
+
indexName,
|
|
154
|
+
query,
|
|
155
|
+
k,
|
|
156
|
+
ef,
|
|
157
|
+
});
|
|
158
|
+
return (response.results || []).map((r) => ({
|
|
159
|
+
id: Number(r.id),
|
|
160
|
+
distance: r.distance,
|
|
161
|
+
}));
|
|
162
|
+
}
|
|
163
|
+
// ===========================================================================
|
|
164
|
+
// Collection Operations (CollectionService)
|
|
165
|
+
// ===========================================================================
|
|
166
|
+
async createCollection(name, options) {
|
|
167
|
+
const stub = this.getStub('CollectionService');
|
|
168
|
+
const response = await this.promisify(stub, 'createCollection', {
|
|
169
|
+
name,
|
|
170
|
+
namespace: options.namespace || 'default',
|
|
171
|
+
dimension: options.dimension,
|
|
172
|
+
metric: options.metric === 'l2' ? 1 : options.metric === 'dot' ? 3 : 2,
|
|
173
|
+
});
|
|
174
|
+
return response.success;
|
|
175
|
+
}
|
|
176
|
+
async addDocuments(collectionName, documents, namespace = 'default') {
|
|
177
|
+
const stub = this.getStub('CollectionService');
|
|
178
|
+
const response = await this.promisify(stub, 'addDocuments', {
|
|
179
|
+
collectionName,
|
|
180
|
+
namespace,
|
|
181
|
+
documents: documents.map((d) => ({
|
|
182
|
+
id: d.id || '',
|
|
183
|
+
content: d.content || '',
|
|
184
|
+
embedding: d.embedding || [],
|
|
185
|
+
metadata: d.metadata || {},
|
|
186
|
+
})),
|
|
187
|
+
});
|
|
188
|
+
return response.ids || [];
|
|
189
|
+
}
|
|
190
|
+
async searchCollection(collectionName, query, k = 10, options = {}) {
|
|
191
|
+
const stub = this.getStub('CollectionService');
|
|
192
|
+
const response = await this.promisify(stub, 'searchCollection', {
|
|
193
|
+
collectionName,
|
|
194
|
+
namespace: options.namespace || 'default',
|
|
195
|
+
query,
|
|
196
|
+
k,
|
|
197
|
+
filter: options.filter || {},
|
|
198
|
+
});
|
|
199
|
+
return (response.results || []).map((r) => ({
|
|
200
|
+
id: r.document.id,
|
|
201
|
+
content: r.document.content,
|
|
202
|
+
embedding: r.document.embedding || [],
|
|
203
|
+
metadata: r.document.metadata || {},
|
|
204
|
+
}));
|
|
205
|
+
}
|
|
206
|
+
// ===========================================================================
|
|
207
|
+
// Graph Operations (GraphService)
|
|
208
|
+
// ===========================================================================
|
|
209
|
+
async addNode(nodeId, nodeType, properties = {}, namespace = 'default') {
|
|
210
|
+
const stub = this.getStub('GraphService');
|
|
211
|
+
const response = await this.promisify(stub, 'addNode', {
|
|
212
|
+
namespace,
|
|
213
|
+
node: { id: nodeId, nodeType, properties },
|
|
214
|
+
});
|
|
215
|
+
return response.success;
|
|
216
|
+
}
|
|
217
|
+
async addEdge(fromId, edgeType, toId, properties = {}, namespace = 'default') {
|
|
218
|
+
const stub = this.getStub('GraphService');
|
|
219
|
+
const response = await this.promisify(stub, 'addEdge', {
|
|
220
|
+
namespace,
|
|
221
|
+
edge: { fromId, edgeType, toId, properties },
|
|
222
|
+
});
|
|
223
|
+
return response.success;
|
|
224
|
+
}
|
|
225
|
+
async traverse(startNode, options = {}) {
|
|
226
|
+
const stub = this.getStub('GraphService');
|
|
227
|
+
const response = await this.promisify(stub, 'traverse', {
|
|
228
|
+
namespace: options.namespace || 'default',
|
|
229
|
+
startNodeId: startNode,
|
|
230
|
+
order: options.order === 'dfs' ? 1 : 0,
|
|
231
|
+
maxDepth: options.maxDepth || 10,
|
|
232
|
+
});
|
|
233
|
+
return {
|
|
234
|
+
nodes: (response.nodes || []).map((n) => ({
|
|
235
|
+
id: n.id,
|
|
236
|
+
nodeType: n.nodeType,
|
|
237
|
+
properties: n.properties || {},
|
|
238
|
+
})),
|
|
239
|
+
edges: (response.edges || []).map((e) => ({
|
|
240
|
+
fromId: e.fromId,
|
|
241
|
+
edgeType: e.edgeType,
|
|
242
|
+
toId: e.toId,
|
|
243
|
+
properties: e.properties || {},
|
|
244
|
+
})),
|
|
245
|
+
};
|
|
246
|
+
}
|
|
247
|
+
// ===========================================================================
|
|
248
|
+
// Semantic Cache Operations (SemanticCacheService)
|
|
249
|
+
// ===========================================================================
|
|
250
|
+
async cacheGet(cacheName, queryEmbedding, threshold = 0.85) {
|
|
251
|
+
const stub = this.getStub('SemanticCacheService');
|
|
252
|
+
const response = await this.promisify(stub, 'get', {
|
|
253
|
+
cacheName,
|
|
254
|
+
queryEmbedding,
|
|
255
|
+
similarityThreshold: threshold,
|
|
256
|
+
});
|
|
257
|
+
return response.hit ? response.cachedValue : null;
|
|
258
|
+
}
|
|
259
|
+
async cachePut(cacheName, key, value, keyEmbedding, ttlSeconds = 0) {
|
|
260
|
+
const stub = this.getStub('SemanticCacheService');
|
|
261
|
+
const response = await this.promisify(stub, 'put', {
|
|
262
|
+
cacheName,
|
|
263
|
+
key,
|
|
264
|
+
value,
|
|
265
|
+
keyEmbedding,
|
|
266
|
+
ttlSeconds,
|
|
267
|
+
});
|
|
268
|
+
return response.success;
|
|
269
|
+
}
|
|
270
|
+
// ===========================================================================
|
|
271
|
+
// Trace Operations (TraceService)
|
|
272
|
+
// ===========================================================================
|
|
273
|
+
async startTrace(name) {
|
|
274
|
+
const stub = this.getStub('TraceService');
|
|
275
|
+
const response = await this.promisify(stub, 'startTrace', { name });
|
|
276
|
+
return { traceId: response.traceId, rootSpanId: response.rootSpanId };
|
|
277
|
+
}
|
|
278
|
+
async startSpan(traceId, parentSpanId, name) {
|
|
279
|
+
const stub = this.getStub('TraceService');
|
|
280
|
+
const response = await this.promisify(stub, 'startSpan', {
|
|
281
|
+
traceId,
|
|
282
|
+
parentSpanId,
|
|
283
|
+
name,
|
|
284
|
+
});
|
|
285
|
+
return response.spanId;
|
|
286
|
+
}
|
|
287
|
+
async endSpan(traceId, spanId, status = 'ok') {
|
|
288
|
+
const stub = this.getStub('TraceService');
|
|
289
|
+
const statusMap = { unset: 0, ok: 1, error: 2 };
|
|
290
|
+
const response = await this.promisify(stub, 'endSpan', {
|
|
291
|
+
traceId,
|
|
292
|
+
spanId,
|
|
293
|
+
status: statusMap[status],
|
|
294
|
+
});
|
|
295
|
+
return Number(response.durationUs);
|
|
296
|
+
}
|
|
297
|
+
// ===========================================================================
|
|
298
|
+
// KV Operations (KvService)
|
|
299
|
+
// ===========================================================================
|
|
300
|
+
async get(key, namespace = 'default') {
|
|
301
|
+
const stub = this.getStub('KvService');
|
|
302
|
+
const response = await this.promisify(stub, 'get', { namespace, key });
|
|
303
|
+
return response.found ? Buffer.from(response.value) : null;
|
|
304
|
+
}
|
|
305
|
+
async put(key, value, namespace = 'default', ttlSeconds = 0) {
|
|
306
|
+
const stub = this.getStub('KvService');
|
|
307
|
+
const response = await this.promisify(stub, 'put', {
|
|
308
|
+
namespace,
|
|
309
|
+
key,
|
|
310
|
+
value,
|
|
311
|
+
ttlSeconds,
|
|
312
|
+
});
|
|
313
|
+
return response.success;
|
|
314
|
+
}
|
|
315
|
+
async delete(key, namespace = 'default') {
|
|
316
|
+
const stub = this.getStub('KvService');
|
|
317
|
+
const response = await this.promisify(stub, 'delete', { namespace, key });
|
|
318
|
+
return response.success;
|
|
319
|
+
}
|
|
320
|
+
}
|
|
321
|
+
exports.SochDBClient = SochDBClient;
|
|
322
|
+
/**
|
|
323
|
+
* Connect to SochDB gRPC server.
|
|
324
|
+
*/
|
|
325
|
+
function connect(address = 'localhost:50051', options = {}) {
|
|
326
|
+
if (address.startsWith('grpc://')) {
|
|
327
|
+
address = address.slice(7);
|
|
328
|
+
}
|
|
329
|
+
return new SochDBClient({ address, ...options });
|
|
330
|
+
}
|
|
331
|
+
// Alias for backwards compatibility
|
|
332
|
+
exports.GrpcClient = SochDBClient;
|
|
333
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grpc-client.js","sourceRoot":"","sources":["../../src/grpc-client.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * SochDB gRPC Client - Thin SDK Wrapper\n *\n * This module provides a thin gRPC client wrapper for the SochDB server.\n * All business logic runs on the server (Thick Server / Thin Client architecture).\n *\n * The client is approximately ~250 lines of code, delegating all operations to the server.\n */\n\nimport * as grpc from '@grpc/grpc-js';\nimport * as protoLoader from '@grpc/proto-loader';\nimport * as path from 'path';\n\n// Types\nexport interface SearchResult {\n  id: number;\n  distance: number;\n}\n\nexport interface Document {\n  id: string;\n  content: string;\n  embedding: number[];\n  metadata: Record<string, string>;\n}\n\nexport interface GraphNode {\n  id: string;\n  nodeType: string;\n  properties: Record<string, string>;\n}\n\nexport interface GraphEdge {\n  fromId: string;\n  edgeType: string;\n  toId: string;\n  properties: Record<string, string>;\n}\n\nexport interface SochDBClientOptions {\n  address?: string;\n  secure?: boolean;\n  protoPath?: string;\n}\n\n/**\n * Thin gRPC client for SochDB.\n *\n * All operations are delegated to the SochDB gRPC server.\n * This client provides a TypeScript interface over the gRPC protocol.\n *\n * Usage:\n * ```typescript\n * const client = new SochDBClient({ address: 'localhost:50051' });\n *\n * // Create collection\n * await client.createCollection('docs', { dimension: 384 });\n *\n * // Add documents\n * await client.addDocuments('docs', [\n *   { id: '1', content: 'Hello', embedding: [...] }\n * ]);\n *\n * // Search\n * const results = await client.search('docs', queryVector, 5);\n * ```\n */\nexport class SochDBClient {\n  private address: string;\n  private credentials: grpc.ChannelCredentials;\n  private stubs: Map<string, any> = new Map();\n  private protoPath: string;\n  private packageDefinition: any;\n  private proto: any;\n\n  constructor(options: SochDBClientOptions = {}) {\n    this.address = options.address || 'localhost:50051';\n    this.credentials = options.secure\n      ? grpc.credentials.createSsl()\n      : grpc.credentials.createInsecure();\n    this.protoPath = options.protoPath || path.join(__dirname, '../../proto/sochdb.proto');\n\n    // Load proto definition\n    this.packageDefinition = protoLoader.loadSync(this.protoPath, {\n      keepCase: false,\n      longs: String,\n      enums: String,\n      defaults: true,\n      oneofs: true,\n    });\n    const loadedPackage = grpc.loadPackageDefinition(this.packageDefinition) as any;\n    this.proto = loadedPackage?.sochdb?.v1;\n  }\n\n  private getStub(serviceName: string): any {\n    if (!this.stubs.has(serviceName)) {\n      const ServiceClass = this.proto?.[serviceName];\n      if (!ServiceClass) {\n        throw new Error(`Service ${serviceName} not found in proto definition`);\n      }\n      this.stubs.set(serviceName, new ServiceClass(this.address, this.credentials));\n    }\n    return this.stubs.get(serviceName)!;\n  }\n\n  private promisify<T>(stub: any, method: string, request: any): Promise<T> {\n    return new Promise((resolve, reject) => {\n      stub[method](request, (error: any, response: T) => {\n        if (error) reject(error);\n        else resolve(response);\n      });\n    });\n  }\n\n  /**\n   * Close all gRPC connections.\n   */\n  close(): void {\n    for (const stub of this.stubs.values()) {\n      grpc.closeClient(stub);\n    }\n    this.stubs.clear();\n  }\n\n  // ===========================================================================\n  // Vector Index Operations (VectorIndexService)\n  // ===========================================================================\n\n  async createIndex(\n    name: string,\n    dimension: number,\n    options: { metric?: string; m?: number; efConstruction?: number } = {}\n  ): Promise<boolean> {\n    const stub = this.getStub('VectorIndexService');\n    const response = await this.promisify<any>(stub, 'createIndex', {\n      name,\n      dimension,\n      metric: options.metric === 'l2' ? 1 : options.metric === 'dot' ? 3 : 2,\n      config: {\n        maxConnections: options.m || 16,\n        efConstruction: options.efConstruction || 200,\n      },\n    });\n    return response.success;\n  }\n\n  async insertVectors(\n    indexName: string,\n    ids: number[],\n    vectors: number[][]\n  ): Promise<number> {\n    const stub = this.getStub('VectorIndexService');\n    const flatVectors = vectors.flat();\n    const response = await this.promisify<any>(stub, 'insertBatch', {\n      indexName,\n      ids,\n      vectors: flatVectors,\n    });\n    return response.insertedCount;\n  }\n\n  async search(\n    indexName: string,\n    query: number[],\n    k: number = 10,\n    ef: number = 50\n  ): Promise<SearchResult[]> {\n    const stub = this.getStub('VectorIndexService');\n    const response = await this.promisify<any>(stub, 'search', {\n      indexName,\n      query,\n      k,\n      ef,\n    });\n    return (response.results || []).map((r: any) => ({\n      id: Number(r.id),\n      distance: r.distance,\n    }));\n  }\n\n  // ===========================================================================\n  // Collection Operations (CollectionService)\n  // ===========================================================================\n\n  async createCollection(\n    name: string,\n    options: { dimension: number; namespace?: string; metric?: string }\n  ): Promise<boolean> {\n    const stub = this.getStub('CollectionService');\n    const response = await this.promisify<any>(stub, 'createCollection', {\n      name,\n      namespace: options.namespace || 'default',\n      dimension: options.dimension,\n      metric: options.metric === 'l2' ? 1 : options.metric === 'dot' ? 3 : 2,\n    });\n    return response.success;\n  }\n\n  async addDocuments(\n    collectionName: string,\n    documents: Array<{\n      id?: string;\n      content?: string;\n      embedding?: number[];\n      metadata?: Record<string, string>;\n    }>,\n    namespace: string = 'default'\n  ): Promise<string[]> {\n    const stub = this.getStub('CollectionService');\n    const response = await this.promisify<any>(stub, 'addDocuments', {\n      collectionName,\n      namespace,\n      documents: documents.map((d) => ({\n        id: d.id || '',\n        content: d.content || '',\n        embedding: d.embedding || [],\n        metadata: d.metadata || {},\n      })),\n    });\n    return response.ids || [];\n  }\n\n  async searchCollection(\n    collectionName: string,\n    query: number[],\n    k: number = 10,\n    options: { namespace?: string; filter?: Record<string, string> } = {}\n  ): Promise<Document[]> {\n    const stub = this.getStub('CollectionService');\n    const response = await this.promisify<any>(stub, 'searchCollection', {\n      collectionName,\n      namespace: options.namespace || 'default',\n      query,\n      k,\n      filter: options.filter || {},\n    });\n    return (response.results || []).map((r: any) => ({\n      id: r.document.id,\n      content: r.document.content,\n      embedding: r.document.embedding || [],\n      metadata: r.document.metadata || {},\n    }));\n  }\n\n  // ===========================================================================\n  // Graph Operations (GraphService)\n  // ===========================================================================\n\n  async addNode(\n    nodeId: string,\n    nodeType: string,\n    properties: Record<string, string> = {},\n    namespace: string = 'default'\n  ): Promise<boolean> {\n    const stub = this.getStub('GraphService');\n    const response = await this.promisify<any>(stub, 'addNode', {\n      namespace,\n      node: { id: nodeId, nodeType, properties },\n    });\n    return response.success;\n  }\n\n  async addEdge(\n    fromId: string,\n    edgeType: string,\n    toId: string,\n    properties: Record<string, string> = {},\n    namespace: string = 'default'\n  ): Promise<boolean> {\n    const stub = this.getStub('GraphService');\n    const response = await this.promisify<any>(stub, 'addEdge', {\n      namespace,\n      edge: { fromId, edgeType, toId, properties },\n    });\n    return response.success;\n  }\n\n  async traverse(\n    startNode: string,\n    options: { maxDepth?: number; order?: 'bfs' | 'dfs'; namespace?: string } = {}\n  ): Promise<{ nodes: GraphNode[]; edges: GraphEdge[] }> {\n    const stub = this.getStub('GraphService');\n    const response = await this.promisify<any>(stub, 'traverse', {\n      namespace: options.namespace || 'default',\n      startNodeId: startNode,\n      order: options.order === 'dfs' ? 1 : 0,\n      maxDepth: options.maxDepth || 10,\n    });\n    return {\n      nodes: (response.nodes || []).map((n: any) => ({\n        id: n.id,\n        nodeType: n.nodeType,\n        properties: n.properties || {},\n      })),\n      edges: (response.edges || []).map((e: any) => ({\n        fromId: e.fromId,\n        edgeType: e.edgeType,\n        toId: e.toId,\n        properties: e.properties || {},\n      })),\n    };\n  }\n\n  // ===========================================================================\n  // Semantic Cache Operations (SemanticCacheService)\n  // ===========================================================================\n\n  async cacheGet(\n    cacheName: string,\n    queryEmbedding: number[],\n    threshold: number = 0.85\n  ): Promise<string | null> {\n    const stub = this.getStub('SemanticCacheService');\n    const response = await this.promisify<any>(stub, 'get', {\n      cacheName,\n      queryEmbedding,\n      similarityThreshold: threshold,\n    });\n    return response.hit ? response.cachedValue : null;\n  }\n\n  async cachePut(\n    cacheName: string,\n    key: string,\n    value: string,\n    keyEmbedding: number[],\n    ttlSeconds: number = 0\n  ): Promise<boolean> {\n    const stub = this.getStub('SemanticCacheService');\n    const response = await this.promisify<any>(stub, 'put', {\n      cacheName,\n      key,\n      value,\n      keyEmbedding,\n      ttlSeconds,\n    });\n    return response.success;\n  }\n\n  // ===========================================================================\n  // Trace Operations (TraceService)\n  // ===========================================================================\n\n  async startTrace(name: string): Promise<{ traceId: string; rootSpanId: string }> {\n    const stub = this.getStub('TraceService');\n    const response = await this.promisify<any>(stub, 'startTrace', { name });\n    return { traceId: response.traceId, rootSpanId: response.rootSpanId };\n  }\n\n  async startSpan(traceId: string, parentSpanId: string, name: string): Promise<string> {\n    const stub = this.getStub('TraceService');\n    const response = await this.promisify<any>(stub, 'startSpan', {\n      traceId,\n      parentSpanId,\n      name,\n    });\n    return response.spanId;\n  }\n\n  async endSpan(\n    traceId: string,\n    spanId: string,\n    status: 'ok' | 'error' | 'unset' = 'ok'\n  ): Promise<number> {\n    const stub = this.getStub('TraceService');\n    const statusMap = { unset: 0, ok: 1, error: 2 };\n    const response = await this.promisify<any>(stub, 'endSpan', {\n      traceId,\n      spanId,\n      status: statusMap[status],\n    });\n    return Number(response.durationUs);\n  }\n\n  // ===========================================================================\n  // KV Operations (KvService)\n  // ===========================================================================\n\n  async get(key: Buffer, namespace: string = 'default'): Promise<Buffer | null> {\n    const stub = this.getStub('KvService');\n    const response = await this.promisify<any>(stub, 'get', { namespace, key });\n    return response.found ? Buffer.from(response.value) : null;\n  }\n\n  async put(\n    key: Buffer,\n    value: Buffer,\n    namespace: string = 'default',\n    ttlSeconds: number = 0\n  ): Promise<boolean> {\n    const stub = this.getStub('KvService');\n    const response = await this.promisify<any>(stub, 'put', {\n      namespace,\n      key,\n      value,\n      ttlSeconds,\n    });\n    return response.success;\n  }\n\n  async delete(key: Buffer, namespace: string = 'default'): Promise<boolean> {\n    const stub = this.getStub('KvService');\n    const response = await this.promisify<any>(stub, 'delete', { namespace, key });\n    return response.success;\n  }\n}\n\n/**\n * Connect to SochDB gRPC server.\n */\nexport function connect(address: string = 'localhost:50051', options: Omit<SochDBClientOptions, 'address'> = {}): SochDBClient {\n  if (address.startsWith('grpc://')) {\n    address = address.slice(7);\n  }\n  return new SochDBClient({ address, ...options });\n}\n\n// Alias for backwards compatibility\nexport const GrpcClient = SochDBClient;\n"]}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* SochDB Node.js SDK v0.4.0
|
|
4
|
+
*
|
|
5
|
+
* Dual-mode architecture: Embedded (FFI) + Server (gRPC/IPC)
|
|
6
|
+
*
|
|
7
|
+
* Architecture: Flexible Deployment
|
|
8
|
+
* ==================================
|
|
9
|
+
* This SDK supports BOTH modes:
|
|
10
|
+
*
|
|
11
|
+
* 1. Embedded Mode (FFI) - For single-process apps:
|
|
12
|
+
* - Direct FFI bindings to Rust libraries
|
|
13
|
+
* - No server required - just npm install and run
|
|
14
|
+
* - Best for: Local development, simple apps
|
|
15
|
+
*
|
|
16
|
+
* 2. Server Mode (gRPC/IPC) - For distributed systems:
|
|
17
|
+
* - Thin client connecting to sochdb-grpc server
|
|
18
|
+
* - Best for: Production, multi-language, scalability
|
|
19
|
+
*
|
|
20
|
+
* @example Embedded Mode
|
|
21
|
+
* ```typescript
|
|
22
|
+
* import { Database } from '@sochdb/sochdb';
|
|
23
|
+
*
|
|
24
|
+
* // Direct FFI - no server needed
|
|
25
|
+
* const db = await Database.open('./mydb');
|
|
26
|
+
* await db.put(Buffer.from('key'), Buffer.from('value'));
|
|
27
|
+
* await db.close();
|
|
28
|
+
* ```
|
|
29
|
+
*
|
|
30
|
+
* @example Server Mode
|
|
31
|
+
* ```typescript
|
|
32
|
+
* import { SochDBClient } from '@sochdb/sochdb';
|
|
33
|
+
*
|
|
34
|
+
* // Connect to server
|
|
35
|
+
* const client = new SochDBClient({ address: 'localhost:50051' });
|
|
36
|
+
* await client.putKv('key', Buffer.from('value'));
|
|
37
|
+
* ```
|
|
38
|
+
*/
|
|
39
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
40
|
+
exports.GrpcClient = exports.DatabaseError = exports.ProtocolError = exports.TransactionError = exports.ConnectionError = exports.SochDBError = exports.Query = exports.FormatConversionError = exports.FormatCapabilities = exports.CanonicalFormat = exports.ContextFormat = exports.WireFormat = exports.IpcClient = exports.SochDBClient = exports.Database = exports.EmbeddedTransaction = exports.EmbeddedDatabase = exports.VERSION = void 0;
|
|
41
|
+
// Version
|
|
42
|
+
exports.VERSION = '0.4.0';
|
|
43
|
+
// Embedded mode (FFI) - NEW
|
|
44
|
+
var embedded_1 = require("./embedded");
|
|
45
|
+
Object.defineProperty(exports, "EmbeddedDatabase", { enumerable: true, get: function () { return embedded_1.EmbeddedDatabase; } });
|
|
46
|
+
var embedded_2 = require("./embedded");
|
|
47
|
+
Object.defineProperty(exports, "EmbeddedTransaction", { enumerable: true, get: function () { return embedded_2.EmbeddedTransaction; } });
|
|
48
|
+
// Embedded mode (FFI) - Convenience alias
|
|
49
|
+
var embedded_3 = require("./embedded");
|
|
50
|
+
Object.defineProperty(exports, "Database", { enumerable: true, get: function () { return embedded_3.EmbeddedDatabase; } });
|
|
51
|
+
// Server mode (gRPC/IPC)
|
|
52
|
+
var grpc_client_1 = require("./grpc-client");
|
|
53
|
+
Object.defineProperty(exports, "SochDBClient", { enumerable: true, get: function () { return grpc_client_1.SochDBClient; } });
|
|
54
|
+
var ipc_client_1 = require("./ipc-client");
|
|
55
|
+
Object.defineProperty(exports, "IpcClient", { enumerable: true, get: function () { return ipc_client_1.IpcClient; } });
|
|
56
|
+
// Format utilities
|
|
57
|
+
var format_1 = require("./format");
|
|
58
|
+
Object.defineProperty(exports, "WireFormat", { enumerable: true, get: function () { return format_1.WireFormat; } });
|
|
59
|
+
Object.defineProperty(exports, "ContextFormat", { enumerable: true, get: function () { return format_1.ContextFormat; } });
|
|
60
|
+
Object.defineProperty(exports, "CanonicalFormat", { enumerable: true, get: function () { return format_1.CanonicalFormat; } });
|
|
61
|
+
Object.defineProperty(exports, "FormatCapabilities", { enumerable: true, get: function () { return format_1.FormatCapabilities; } });
|
|
62
|
+
Object.defineProperty(exports, "FormatConversionError", { enumerable: true, get: function () { return format_1.FormatConversionError; } });
|
|
63
|
+
// Type definitions
|
|
64
|
+
var query_1 = require("./query");
|
|
65
|
+
Object.defineProperty(exports, "Query", { enumerable: true, get: function () { return query_1.Query; } });
|
|
66
|
+
var errors_1 = require("./errors");
|
|
67
|
+
Object.defineProperty(exports, "SochDBError", { enumerable: true, get: function () { return errors_1.SochDBError; } });
|
|
68
|
+
Object.defineProperty(exports, "ConnectionError", { enumerable: true, get: function () { return errors_1.ConnectionError; } });
|
|
69
|
+
Object.defineProperty(exports, "TransactionError", { enumerable: true, get: function () { return errors_1.TransactionError; } });
|
|
70
|
+
Object.defineProperty(exports, "ProtocolError", { enumerable: true, get: function () { return errors_1.ProtocolError; } });
|
|
71
|
+
Object.defineProperty(exports, "DatabaseError", { enumerable: true, get: function () { return errors_1.DatabaseError; } });
|
|
72
|
+
// Convenience alias
|
|
73
|
+
var grpc_client_2 = require("./grpc-client");
|
|
74
|
+
Object.defineProperty(exports, "GrpcClient", { enumerable: true, get: function () { return grpc_client_2.SochDBClient; } });
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FvQ0c7OztBQUVILFVBQVU7QUFDRyxRQUFBLE9BQU8sR0FBRyxPQUFPLENBQUM7QUFFL0IsNEJBQTRCO0FBQzVCLHVDQUFzRTtBQUE3RCw0R0FBQSxnQkFBZ0IsT0FBQTtBQUN6Qix1Q0FBaUQ7QUFBeEMsK0dBQUEsbUJBQW1CLE9BQUE7QUFFNUIsMENBQTBDO0FBQzFDLHVDQUEwRDtBQUFqRCxvR0FBQSxnQkFBZ0IsT0FBWTtBQUVyQyx5QkFBeUI7QUFDekIsNkNBQTZDO0FBQXBDLDJHQUFBLFlBQVksT0FBQTtBQVFyQiwyQ0FBeUM7QUFBaEMsdUdBQUEsU0FBUyxPQUFBO0FBRWxCLG1CQUFtQjtBQUNuQixtQ0FNa0I7QUFMaEIsb0dBQUEsVUFBVSxPQUFBO0FBQ1YsdUdBQUEsYUFBYSxPQUFBO0FBQ2IseUdBQUEsZUFBZSxPQUFBO0FBQ2YsNEdBQUEsa0JBQWtCLE9BQUE7QUFDbEIsK0dBQUEscUJBQXFCLE9BQUE7QUFHdkIsbUJBQW1CO0FBQ25CLGlDQUFnQztBQUF2Qiw4RkFBQSxLQUFLLE9BQUE7QUFHZCxtQ0FNa0I7QUFMaEIscUdBQUEsV0FBVyxPQUFBO0FBQ1gseUdBQUEsZUFBZSxPQUFBO0FBQ2YsMEdBQUEsZ0JBQWdCLE9BQUE7QUFDaEIsdUdBQUEsYUFBYSxPQUFBO0FBQ2IsdUdBQUEsYUFBYSxPQUFBO0FBR2Ysb0JBQW9CO0FBQ3BCLDZDQUEyRDtBQUFsRCx5R0FBQSxZQUFZLE9BQWMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFNvY2hEQiBOb2RlLmpzIFNESyB2MC40LjBcbiAqIFxuICogRHVhbC1tb2RlIGFyY2hpdGVjdHVyZTogRW1iZWRkZWQgKEZGSSkgKyBTZXJ2ZXIgKGdSUEMvSVBDKVxuICogXG4gKiBBcmNoaXRlY3R1cmU6IEZsZXhpYmxlIERlcGxveW1lbnRcbiAqID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbiAqIFRoaXMgU0RLIHN1cHBvcnRzIEJPVEggbW9kZXM6XG4gKiBcbiAqIDEuIEVtYmVkZGVkIE1vZGUgKEZGSSkgLSBGb3Igc2luZ2xlLXByb2Nlc3MgYXBwczpcbiAqICAgIC0gRGlyZWN0IEZGSSBiaW5kaW5ncyB0byBSdXN0IGxpYnJhcmllc1xuICogICAgLSBObyBzZXJ2ZXIgcmVxdWlyZWQgLSBqdXN0IG5wbSBpbnN0YWxsIGFuZCBydW5cbiAqICAgIC0gQmVzdCBmb3I6IExvY2FsIGRldmVsb3BtZW50LCBzaW1wbGUgYXBwc1xuICogXG4gKiAyLiBTZXJ2ZXIgTW9kZSAoZ1JQQy9JUEMpIC0gRm9yIGRpc3RyaWJ1dGVkIHN5c3RlbXM6XG4gKiAgICAtIFRoaW4gY2xpZW50IGNvbm5lY3RpbmcgdG8gc29jaGRiLWdycGMgc2VydmVyXG4gKiAgICAtIEJlc3QgZm9yOiBQcm9kdWN0aW9uLCBtdWx0aS1sYW5ndWFnZSwgc2NhbGFiaWxpdHlcbiAqIFxuICogQGV4YW1wbGUgRW1iZWRkZWQgTW9kZVxuICogYGBgdHlwZXNjcmlwdFxuICogaW1wb3J0IHsgRGF0YWJhc2UgfSBmcm9tICdAc29jaGRiL3NvY2hkYic7XG4gKiBcbiAqIC8vIERpcmVjdCBGRkkgLSBubyBzZXJ2ZXIgbmVlZGVkXG4gKiBjb25zdCBkYiA9IGF3YWl0IERhdGFiYXNlLm9wZW4oJy4vbXlkYicpO1xuICogYXdhaXQgZGIucHV0KEJ1ZmZlci5mcm9tKCdrZXknKSwgQnVmZmVyLmZyb20oJ3ZhbHVlJykpO1xuICogYXdhaXQgZGIuY2xvc2UoKTtcbiAqIGBgYFxuICogXG4gKiBAZXhhbXBsZSBTZXJ2ZXIgTW9kZVxuICogYGBgdHlwZXNjcmlwdFxuICogaW1wb3J0IHsgU29jaERCQ2xpZW50IH0gZnJvbSAnQHNvY2hkYi9zb2NoZGInO1xuICogXG4gKiAvLyBDb25uZWN0IHRvIHNlcnZlclxuICogY29uc3QgY2xpZW50ID0gbmV3IFNvY2hEQkNsaWVudCh7IGFkZHJlc3M6ICdsb2NhbGhvc3Q6NTAwNTEnIH0pO1xuICogYXdhaXQgY2xpZW50LnB1dEt2KCdrZXknLCBCdWZmZXIuZnJvbSgndmFsdWUnKSk7XG4gKiBgYGBcbiAqL1xuXG4vLyBWZXJzaW9uXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9ICcwLjQuMCc7XG5cbi8vIEVtYmVkZGVkIG1vZGUgKEZGSSkgLSBORVdcbmV4cG9ydCB7IEVtYmVkZGVkRGF0YWJhc2UsIEVtYmVkZGVkRGF0YWJhc2VDb25maWcgfSBmcm9tICcuL2VtYmVkZGVkJztcbmV4cG9ydCB7IEVtYmVkZGVkVHJhbnNhY3Rpb24gfSBmcm9tICcuL2VtYmVkZGVkJztcblxuLy8gRW1iZWRkZWQgbW9kZSAoRkZJKSAtIENvbnZlbmllbmNlIGFsaWFzXG5leHBvcnQgeyBFbWJlZGRlZERhdGFiYXNlIGFzIERhdGFiYXNlIH0gZnJvbSAnLi9lbWJlZGRlZCc7XG5cbi8vIFNlcnZlciBtb2RlIChnUlBDL0lQQylcbmV4cG9ydCB7IFNvY2hEQkNsaWVudCB9IGZyb20gJy4vZ3JwYy1jbGllbnQnO1xuZXhwb3J0IHR5cGUge1xuICBTZWFyY2hSZXN1bHQsXG4gIERvY3VtZW50LFxuICBHcmFwaE5vZGUsXG4gIEdyYXBoRWRnZSxcbn0gZnJvbSAnLi9ncnBjLWNsaWVudCc7XG5cbmV4cG9ydCB7IElwY0NsaWVudCB9IGZyb20gJy4vaXBjLWNsaWVudCc7XG5cbi8vIEZvcm1hdCB1dGlsaXRpZXNcbmV4cG9ydCB7XG4gIFdpcmVGb3JtYXQsXG4gIENvbnRleHRGb3JtYXQsXG4gIENhbm9uaWNhbEZvcm1hdCxcbiAgRm9ybWF0Q2FwYWJpbGl0aWVzLFxuICBGb3JtYXRDb252ZXJzaW9uRXJyb3IsXG59IGZyb20gJy4vZm9ybWF0JztcblxuLy8gVHlwZSBkZWZpbml0aW9uc1xuZXhwb3J0IHsgUXVlcnkgfSBmcm9tICcuL3F1ZXJ5JztcbmV4cG9ydCB0eXBlIHsgUXVlcnlSZXN1bHQgfSBmcm9tICcuL3F1ZXJ5JztcblxuZXhwb3J0IHtcbiAgU29jaERCRXJyb3IsXG4gIENvbm5lY3Rpb25FcnJvcixcbiAgVHJhbnNhY3Rpb25FcnJvcixcbiAgUHJvdG9jb2xFcnJvcixcbiAgRGF0YWJhc2VFcnJvcixcbn0gZnJvbSAnLi9lcnJvcnMnO1xuXG4vLyBDb252ZW5pZW5jZSBhbGlhc1xuZXhwb3J0IHsgU29jaERCQ2xpZW50IGFzIEdycGNDbGllbnQgfSBmcm9tICcuL2dycGMtY2xpZW50JztcbiJdfQ==
|