ultipa 6.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +65 -0
- package/dist/client.d.ts +194 -0
- package/dist/client.js +390 -0
- package/dist/config.d.ts +65 -0
- package/dist/config.js +135 -0
- package/dist/connection.d.ts +30 -0
- package/dist/connection.js +190 -0
- package/dist/errors.d.ts +99 -0
- package/dist/errors.js +237 -0
- package/dist/index.d.ts +14 -0
- package/dist/index.js +88 -0
- package/dist/printers.d.ts +33 -0
- package/dist/printers.js +312 -0
- package/dist/proto/gqldb.proto +632 -0
- package/dist/response.d.ts +256 -0
- package/dist/response.js +723 -0
- package/dist/services/admin-service.d.ts +40 -0
- package/dist/services/admin-service.js +115 -0
- package/dist/services/bulk-import-service.d.ts +35 -0
- package/dist/services/bulk-import-service.js +108 -0
- package/dist/services/converters.d.ts +57 -0
- package/dist/services/converters.js +254 -0
- package/dist/services/data-service.d.ts +44 -0
- package/dist/services/data-service.js +206 -0
- package/dist/services/graph-service.d.ts +32 -0
- package/dist/services/graph-service.js +127 -0
- package/dist/services/health-service.d.ts +50 -0
- package/dist/services/health-service.js +78 -0
- package/dist/services/index.d.ts +13 -0
- package/dist/services/index.js +30 -0
- package/dist/services/query-service.d.ts +39 -0
- package/dist/services/query-service.js +112 -0
- package/dist/services/service-context.d.ts +39 -0
- package/dist/services/service-context.js +73 -0
- package/dist/services/session-service.d.ts +24 -0
- package/dist/services/session-service.js +66 -0
- package/dist/services/transaction-service.d.ts +33 -0
- package/dist/services/transaction-service.js +100 -0
- package/dist/services.d.ts +28 -0
- package/dist/services.js +122 -0
- package/dist/session.d.ts +45 -0
- package/dist/session.js +75 -0
- package/dist/transaction.d.ts +42 -0
- package/dist/transaction.js +89 -0
- package/dist/types/bulk_import.d.ts +53 -0
- package/dist/types/bulk_import.js +6 -0
- package/dist/types/data_types.d.ts +116 -0
- package/dist/types/data_types.js +122 -0
- package/dist/types/enums.d.ts +59 -0
- package/dist/types/enums.js +67 -0
- package/dist/types/graph_models.d.ts +54 -0
- package/dist/types/graph_models.js +6 -0
- package/dist/types/index.d.ts +11 -0
- package/dist/types/index.js +36 -0
- package/dist/types/metadata.d.ts +60 -0
- package/dist/types/metadata.js +6 -0
- package/dist/types/schema.d.ts +31 -0
- package/dist/types/schema.js +6 -0
- package/dist/types/typed_value.d.ts +25 -0
- package/dist/types/typed_value.js +1176 -0
- package/dist/types/wrappers.d.ts +23 -0
- package/dist/types/wrappers.js +39 -0
- package/dist/types.d.ts +7 -0
- package/dist/types.js +24 -0
- package/package.json +50 -0
package/dist/client.js
ADDED
|
@@ -0,0 +1,390 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Main client for GQLDB Node.js driver.
|
|
4
|
+
*/
|
|
5
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
8
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
9
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
10
|
+
}
|
|
11
|
+
Object.defineProperty(o, k2, desc);
|
|
12
|
+
}) : (function(o, m, k, k2) {
|
|
13
|
+
if (k2 === undefined) k2 = k;
|
|
14
|
+
o[k2] = m[k];
|
|
15
|
+
}));
|
|
16
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
17
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
18
|
+
}) : function(o, v) {
|
|
19
|
+
o["default"] = v;
|
|
20
|
+
});
|
|
21
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
22
|
+
var ownKeys = function(o) {
|
|
23
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
24
|
+
var ar = [];
|
|
25
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
26
|
+
return ar;
|
|
27
|
+
};
|
|
28
|
+
return ownKeys(o);
|
|
29
|
+
};
|
|
30
|
+
return function (mod) {
|
|
31
|
+
if (mod && mod.__esModule) return mod;
|
|
32
|
+
var result = {};
|
|
33
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
34
|
+
__setModuleDefault(result, mod);
|
|
35
|
+
return result;
|
|
36
|
+
};
|
|
37
|
+
})();
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
exports.GqldbClient = void 0;
|
|
40
|
+
const grpc = __importStar(require("@grpc/grpc-js"));
|
|
41
|
+
const config_1 = require("./config");
|
|
42
|
+
const session_1 = require("./session");
|
|
43
|
+
const transaction_1 = require("./transaction");
|
|
44
|
+
const types_1 = require("./types");
|
|
45
|
+
const services_1 = require("./services");
|
|
46
|
+
const index_1 = require("./services/index");
|
|
47
|
+
/** Main client for interacting with GQLDB */
|
|
48
|
+
class GqldbClient {
|
|
49
|
+
config;
|
|
50
|
+
clients;
|
|
51
|
+
sessions;
|
|
52
|
+
txManager;
|
|
53
|
+
closed = false;
|
|
54
|
+
// Service instances
|
|
55
|
+
sessionService;
|
|
56
|
+
queryService;
|
|
57
|
+
graphService;
|
|
58
|
+
transactionService;
|
|
59
|
+
dataService;
|
|
60
|
+
healthService;
|
|
61
|
+
adminService;
|
|
62
|
+
bulkImportService;
|
|
63
|
+
/** Get session metadata for authenticated requests */
|
|
64
|
+
getSessionMetadata() {
|
|
65
|
+
const metadata = new grpc.Metadata();
|
|
66
|
+
const session = this.sessions.getSession();
|
|
67
|
+
metadata.add('session-id', session?.id?.toString() || '0');
|
|
68
|
+
return metadata;
|
|
69
|
+
}
|
|
70
|
+
constructor(config) {
|
|
71
|
+
(0, config_1.validateConfig)(config);
|
|
72
|
+
this.config = config;
|
|
73
|
+
this.sessions = new session_1.SessionManager();
|
|
74
|
+
this.txManager = new transaction_1.TransactionManager();
|
|
75
|
+
// Create gRPC credentials
|
|
76
|
+
let credentials;
|
|
77
|
+
if (config.tlsOptions) {
|
|
78
|
+
credentials = grpc.credentials.createSsl();
|
|
79
|
+
}
|
|
80
|
+
else {
|
|
81
|
+
credentials = grpc.credentials.createInsecure();
|
|
82
|
+
}
|
|
83
|
+
// Channel options
|
|
84
|
+
const options = {
|
|
85
|
+
'grpc.max_receive_message_length': config.maxRecvSize ?? 4 * 1024 * 1024,
|
|
86
|
+
'grpc.keepalive_time_ms': 30000,
|
|
87
|
+
'grpc.keepalive_timeout_ms': 10000,
|
|
88
|
+
};
|
|
89
|
+
// Create service clients for the first host
|
|
90
|
+
const host = config.hosts[0];
|
|
91
|
+
this.clients = (0, services_1.createServiceClients)(host, credentials, options);
|
|
92
|
+
// Initialize service context
|
|
93
|
+
const ctx = new index_1.ServiceContext(this.config, this.sessions, this.txManager, this.clients);
|
|
94
|
+
// Initialize service instances
|
|
95
|
+
this.sessionService = new index_1.SessionService(ctx);
|
|
96
|
+
this.queryService = new index_1.QueryService(ctx);
|
|
97
|
+
this.graphService = new index_1.GraphService(ctx);
|
|
98
|
+
this.transactionService = new index_1.TransactionService(ctx);
|
|
99
|
+
this.dataService = new index_1.DataService(ctx);
|
|
100
|
+
this.healthService = new index_1.HealthService(ctx);
|
|
101
|
+
this.adminService = new index_1.AdminService(ctx);
|
|
102
|
+
this.bulkImportService = new index_1.BulkImportService(ctx);
|
|
103
|
+
}
|
|
104
|
+
/** Close the client and all connections */
|
|
105
|
+
async close() {
|
|
106
|
+
if (this.closed)
|
|
107
|
+
return;
|
|
108
|
+
this.closed = true;
|
|
109
|
+
if (this.sessions.isLoggedIn()) {
|
|
110
|
+
try {
|
|
111
|
+
await this.logout();
|
|
112
|
+
}
|
|
113
|
+
catch (e) {
|
|
114
|
+
// Ignore logout errors during close
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
// Close all service clients
|
|
118
|
+
try {
|
|
119
|
+
this.clients.sessionService.close?.();
|
|
120
|
+
this.clients.queryService.close?.();
|
|
121
|
+
this.clients.graphService.close?.();
|
|
122
|
+
this.clients.transactionService.close?.();
|
|
123
|
+
this.clients.dataService.close?.();
|
|
124
|
+
this.clients.healthService.close?.();
|
|
125
|
+
this.clients.adminService.close?.();
|
|
126
|
+
this.clients.bulkImportService.close?.();
|
|
127
|
+
}
|
|
128
|
+
catch (e) {
|
|
129
|
+
// Ignore close errors
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
// ===========================================================================
|
|
133
|
+
// Session Service
|
|
134
|
+
// ===========================================================================
|
|
135
|
+
/** Authenticate the user and create a session */
|
|
136
|
+
async login(username, password) {
|
|
137
|
+
return this.sessionService.login(username, password, this.config.defaultGraph || '');
|
|
138
|
+
}
|
|
139
|
+
/** Terminate the current session */
|
|
140
|
+
async logout() {
|
|
141
|
+
return this.sessionService.logout();
|
|
142
|
+
}
|
|
143
|
+
/** Check the connection and return the latency in nanoseconds */
|
|
144
|
+
async ping() {
|
|
145
|
+
return this.sessionService.ping();
|
|
146
|
+
}
|
|
147
|
+
// ===========================================================================
|
|
148
|
+
// Query Service
|
|
149
|
+
// ===========================================================================
|
|
150
|
+
/** Execute a GQL query and return the result */
|
|
151
|
+
async gql(query, config) {
|
|
152
|
+
return this.queryService.gql(query, config);
|
|
153
|
+
}
|
|
154
|
+
/** Execute a GQL query and stream the results */
|
|
155
|
+
async gqlStream(query, config, callback) {
|
|
156
|
+
return this.queryService.gqlStream(query, config, callback);
|
|
157
|
+
}
|
|
158
|
+
/** Return the execution plan for a query */
|
|
159
|
+
async explain(query, config) {
|
|
160
|
+
return this.queryService.explain(query, config);
|
|
161
|
+
}
|
|
162
|
+
/** Execute a query with profiling and return statistics */
|
|
163
|
+
async profile(query, config) {
|
|
164
|
+
return this.queryService.profile(query, config);
|
|
165
|
+
}
|
|
166
|
+
// ===========================================================================
|
|
167
|
+
// Graph Service
|
|
168
|
+
// ===========================================================================
|
|
169
|
+
/** Create a new graph */
|
|
170
|
+
async createGraph(name, graphType = types_1.GraphType.OPEN, description = '') {
|
|
171
|
+
return this.graphService.createGraph(name, graphType, description);
|
|
172
|
+
}
|
|
173
|
+
/** Delete a graph */
|
|
174
|
+
async dropGraph(name, ifExists = false) {
|
|
175
|
+
return this.graphService.dropGraph(name, ifExists);
|
|
176
|
+
}
|
|
177
|
+
/** Set the current graph for the session */
|
|
178
|
+
async useGraph(name) {
|
|
179
|
+
return this.graphService.useGraph(name);
|
|
180
|
+
}
|
|
181
|
+
/** Return all available graphs */
|
|
182
|
+
async listGraphs() {
|
|
183
|
+
return this.graphService.listGraphs();
|
|
184
|
+
}
|
|
185
|
+
/** Return information about a specific graph */
|
|
186
|
+
async getGraphInfo(name) {
|
|
187
|
+
return this.graphService.getGraphInfo(name);
|
|
188
|
+
}
|
|
189
|
+
// ===========================================================================
|
|
190
|
+
// Transaction Service
|
|
191
|
+
// ===========================================================================
|
|
192
|
+
/** Start a new transaction */
|
|
193
|
+
async beginTransaction(graphName, readOnly = false, timeout = 0) {
|
|
194
|
+
return this.transactionService.beginTransaction(graphName, readOnly, timeout);
|
|
195
|
+
}
|
|
196
|
+
/** Commit a transaction */
|
|
197
|
+
async commit(transactionId) {
|
|
198
|
+
return this.transactionService.commit(transactionId);
|
|
199
|
+
}
|
|
200
|
+
/** Rollback a transaction */
|
|
201
|
+
async rollback(transactionId) {
|
|
202
|
+
return this.transactionService.rollback(transactionId);
|
|
203
|
+
}
|
|
204
|
+
/** Return active transactions */
|
|
205
|
+
async listTransactions() {
|
|
206
|
+
return this.transactionService.listTransactions();
|
|
207
|
+
}
|
|
208
|
+
/** Execute a function within a transaction */
|
|
209
|
+
async withTransaction(graphName, fn, readOnly = false) {
|
|
210
|
+
return this.transactionService.withTransaction(graphName, fn, readOnly);
|
|
211
|
+
}
|
|
212
|
+
// ===========================================================================
|
|
213
|
+
// Data Service
|
|
214
|
+
// ===========================================================================
|
|
215
|
+
/** Insert multiple nodes into a graph */
|
|
216
|
+
async insertNodes(graphName, nodes, config) {
|
|
217
|
+
return this.dataService.insertNodes(graphName, nodes, config);
|
|
218
|
+
}
|
|
219
|
+
/** Insert multiple edges into a graph */
|
|
220
|
+
async insertEdges(graphName, edges, config) {
|
|
221
|
+
return this.dataService.insertEdges(graphName, edges, config);
|
|
222
|
+
}
|
|
223
|
+
/** Delete nodes from a graph */
|
|
224
|
+
async deleteNodes(graphName, nodeIds, labels, where) {
|
|
225
|
+
return this.dataService.deleteNodes(graphName, nodeIds, labels, where);
|
|
226
|
+
}
|
|
227
|
+
/** Delete edges from a graph */
|
|
228
|
+
async deleteEdges(graphName, edgeIds, label, where) {
|
|
229
|
+
return this.dataService.deleteEdges(graphName, edgeIds, label, where);
|
|
230
|
+
}
|
|
231
|
+
/**
|
|
232
|
+
* Export graph data in JSON Lines format (streaming).
|
|
233
|
+
* @param config Export configuration
|
|
234
|
+
* @param callback Callback for each exported chunk
|
|
235
|
+
*/
|
|
236
|
+
async export(config, callback) {
|
|
237
|
+
return this.dataService.export(config, callback);
|
|
238
|
+
}
|
|
239
|
+
/**
|
|
240
|
+
* Stream nodes from a graph
|
|
241
|
+
* @deprecated Use export() with ExportConfig instead
|
|
242
|
+
*/
|
|
243
|
+
async exportNodes(graphName, labels, limit = 0, callback) {
|
|
244
|
+
return this.dataService.exportNodes(graphName, labels, limit, callback);
|
|
245
|
+
}
|
|
246
|
+
/**
|
|
247
|
+
* Stream edges from a graph
|
|
248
|
+
* @deprecated Use export() with ExportConfig instead
|
|
249
|
+
*/
|
|
250
|
+
async exportEdges(graphName, labels, limit = 0, callback) {
|
|
251
|
+
return this.dataService.exportEdges(graphName, labels, limit, callback);
|
|
252
|
+
}
|
|
253
|
+
// ===========================================================================
|
|
254
|
+
// Health Service
|
|
255
|
+
// ===========================================================================
|
|
256
|
+
/** Check the health of a service */
|
|
257
|
+
async healthCheck(service = '') {
|
|
258
|
+
return this.healthService.healthCheck(service);
|
|
259
|
+
}
|
|
260
|
+
/**
|
|
261
|
+
* Watch health status changes via server-side streaming.
|
|
262
|
+
* Returns a HealthWatcher that emits 'status' events with HealthStatus values.
|
|
263
|
+
* Call stop() to cancel the stream.
|
|
264
|
+
*
|
|
265
|
+
* @param service - Optional service name to watch
|
|
266
|
+
* @returns HealthWatcher - EventEmitter with stop() method
|
|
267
|
+
*
|
|
268
|
+
* @example
|
|
269
|
+
* ```typescript
|
|
270
|
+
* const watcher = client.watch();
|
|
271
|
+
* watcher.on('status', (status: HealthStatus) => {
|
|
272
|
+
* console.log('Health status:', status);
|
|
273
|
+
* });
|
|
274
|
+
* watcher.on('error', (err) => {
|
|
275
|
+
* console.error('Watch error:', err);
|
|
276
|
+
* });
|
|
277
|
+
* watcher.on('end', () => {
|
|
278
|
+
* console.log('Watch stream ended');
|
|
279
|
+
* });
|
|
280
|
+
* // Later, to stop watching:
|
|
281
|
+
* watcher.stop();
|
|
282
|
+
* ```
|
|
283
|
+
*/
|
|
284
|
+
watch(service = '') {
|
|
285
|
+
return this.healthService.watch(service);
|
|
286
|
+
}
|
|
287
|
+
// ===========================================================================
|
|
288
|
+
// Admin Service
|
|
289
|
+
// ===========================================================================
|
|
290
|
+
/** Pre-allocate parser instances */
|
|
291
|
+
async warmupParser(count) {
|
|
292
|
+
return this.adminService.warmupParser(count);
|
|
293
|
+
}
|
|
294
|
+
/** Return cache statistics */
|
|
295
|
+
async getCacheStats(cacheType = types_1.CacheType.ALL) {
|
|
296
|
+
return this.adminService.getCacheStats(cacheType);
|
|
297
|
+
}
|
|
298
|
+
/** Clear the specified cache */
|
|
299
|
+
async clearCache(cacheType = types_1.CacheType.ALL) {
|
|
300
|
+
return this.adminService.clearCache(cacheType);
|
|
301
|
+
}
|
|
302
|
+
/** Return database statistics */
|
|
303
|
+
async getStatistics(graphName = '') {
|
|
304
|
+
return this.adminService.getStatistics(graphName);
|
|
305
|
+
}
|
|
306
|
+
/** Invalidate the RBAC permission cache */
|
|
307
|
+
async invalidatePermissionCache(username = '') {
|
|
308
|
+
return this.adminService.invalidatePermissionCache(username);
|
|
309
|
+
}
|
|
310
|
+
/** Trigger manual compaction of the database storage */
|
|
311
|
+
async compact() {
|
|
312
|
+
return this.adminService.compact();
|
|
313
|
+
}
|
|
314
|
+
/** Wait for the computing engine topology to be ready */
|
|
315
|
+
async waitForComputeTopology(graphName, timeoutMs = 0) {
|
|
316
|
+
return this.adminService.waitForComputeTopology(graphName, timeoutMs);
|
|
317
|
+
}
|
|
318
|
+
// ===========================================================================
|
|
319
|
+
// Bulk Import Service
|
|
320
|
+
// ===========================================================================
|
|
321
|
+
/**
|
|
322
|
+
* Start a bulk import session for optimized high-throughput inserts.
|
|
323
|
+
* @param graphName Target graph name
|
|
324
|
+
* @param options Optional bulk import configuration
|
|
325
|
+
*/
|
|
326
|
+
async startBulkImport(graphName, options) {
|
|
327
|
+
return this.bulkImportService.startBulkImport(graphName, options);
|
|
328
|
+
}
|
|
329
|
+
/**
|
|
330
|
+
* @deprecated Checkpoint is no longer needed. Use endBulkImport() which performs a final flush.
|
|
331
|
+
*/
|
|
332
|
+
async checkpoint(sessionId) {
|
|
333
|
+
return {
|
|
334
|
+
success: true,
|
|
335
|
+
recordCount: 0,
|
|
336
|
+
lastCheckpointCount: 0,
|
|
337
|
+
message: 'Checkpoint has been removed; use endBulkImport which performs a final flush',
|
|
338
|
+
};
|
|
339
|
+
}
|
|
340
|
+
/**
|
|
341
|
+
* End the bulk import session with a final checkpoint.
|
|
342
|
+
* @param sessionId Bulk import session ID
|
|
343
|
+
*/
|
|
344
|
+
async endBulkImport(sessionId) {
|
|
345
|
+
return this.bulkImportService.endBulkImport(sessionId);
|
|
346
|
+
}
|
|
347
|
+
/**
|
|
348
|
+
* Cancel the bulk import session without final sync.
|
|
349
|
+
* @param sessionId Bulk import session ID
|
|
350
|
+
*/
|
|
351
|
+
async abortBulkImport(sessionId) {
|
|
352
|
+
return this.bulkImportService.abortBulkImport(sessionId);
|
|
353
|
+
}
|
|
354
|
+
/**
|
|
355
|
+
* Return the current status of a bulk import session.
|
|
356
|
+
* @param sessionId Bulk import session ID
|
|
357
|
+
*/
|
|
358
|
+
async getBulkImportStatus(sessionId) {
|
|
359
|
+
return this.bulkImportService.getBulkImportStatus(sessionId);
|
|
360
|
+
}
|
|
361
|
+
// ===========================================================================
|
|
362
|
+
// Convenience Methods
|
|
363
|
+
// ===========================================================================
|
|
364
|
+
/** Get the current session */
|
|
365
|
+
getSession() {
|
|
366
|
+
return this.sessions.getSession();
|
|
367
|
+
}
|
|
368
|
+
/** Check if there is an active session */
|
|
369
|
+
isLoggedIn() {
|
|
370
|
+
return this.sessions.isLoggedIn();
|
|
371
|
+
}
|
|
372
|
+
/** Get the client configuration */
|
|
373
|
+
getConfig() {
|
|
374
|
+
return this.config;
|
|
375
|
+
}
|
|
376
|
+
/** Whether this client is connected to a cluster deployment */
|
|
377
|
+
get isCluster() {
|
|
378
|
+
return this.sessions.getSession()?.isCluster || false;
|
|
379
|
+
}
|
|
380
|
+
/** Get the cluster ID (empty string if not a cluster) */
|
|
381
|
+
get clusterId() {
|
|
382
|
+
return this.sessions.getSession()?.clusterId || '';
|
|
383
|
+
}
|
|
384
|
+
/** Get the partition count (0 if not a cluster) */
|
|
385
|
+
get partitionCount() {
|
|
386
|
+
return this.sessions.getSession()?.partitionCount || 0;
|
|
387
|
+
}
|
|
388
|
+
}
|
|
389
|
+
exports.GqldbClient = GqldbClient;
|
|
390
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"client.js","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Main client for GQLDB Node.js driver.\r\n */\r\n\r\nimport * as grpc from '@grpc/grpc-js';\r\nimport { EventEmitter } from 'events';\r\nimport { GqldbConfig, validateConfig } from './config';\r\nimport { EmptyQueryError, LoginFailedError, QueryFailedError } from './errors';\r\nimport {\r\n  Response,\r\n  Row,\r\n  InsertNodesResult,\r\n  InsertEdgesResult,\r\n  DeleteResult,\r\n  ExportNodesResult,\r\n  ExportEdgesResult,\r\n  ExportConfig,\r\n  ExportChunk,\r\n  ExportStats,\r\n} from './response';\r\nimport { Session, SessionManager } from './session';\r\nimport { Transaction, TransactionManager } from './transaction';\r\nimport {\r\n  GraphInfo,\r\n  GraphType,\r\n  HealthStatus,\r\n  CacheStats,\r\n  CacheType,\r\n  Statistics,\r\n  CompactResult,\r\n  ComputeTopologyResult,\r\n  NodeData,\r\n  EdgeData,\r\n  BulkCreateNodesOptions,\r\n  BulkCreateEdgesOptions,\r\n  BulkImportOptions,\r\n  BulkImportSession,\r\n  CheckpointResult,\r\n  EndBulkImportResult,\r\n  AbortBulkImportResult,\r\n  BulkImportStatus,\r\n  TransactionInfo,\r\n} from './types';\r\nimport { createServiceClients, promisifyCall, promisifyCallWithDeadline } from './services';\r\nimport {\r\n  ServiceContext,\r\n  ServiceClients,\r\n  SessionService,\r\n  QueryService,\r\n  GraphService,\r\n  TransactionService,\r\n  DataService,\r\n  HealthService,\r\n  AdminService,\r\n  BulkImportService,\r\n} from './services/index';\r\n\r\n/** Configuration for a query */\r\nexport interface QueryConfig {\r\n  graphName?: string;\r\n  parameters?: Record<string, any>;\r\n  transactionId?: number;\r\n  timeout?: number;\r\n  readOnly?: boolean;\r\n  /** Max paths to return from path queries (0 = unlimited) */\r\n  maxPathResults?: number;\r\n}\r\n\r\n/** Configuration for insert nodes */\r\nexport interface InsertNodesConfig {\r\n  options?: BulkCreateNodesOptions;\r\n  bulkImportSessionId?: string;\r\n}\r\n\r\n/** Configuration for insert edges */\r\nexport interface InsertEdgesConfig {\r\n  options?: BulkCreateEdgesOptions;\r\n  bulkImportSessionId?: string;\r\n}\r\n\r\n/**\r\n * Health watcher interface for streaming health updates.\r\n * Emits 'status' events with HealthStatus and 'error' events on failure.\r\n */\r\nexport interface HealthWatcher extends EventEmitter {\r\n  /** Stop watching health updates */\r\n  stop(): void;\r\n}\r\n\r\n/** Main client for interacting with GQLDB */\r\nexport class GqldbClient {\r\n  private config: GqldbConfig;\r\n  private clients: ServiceClients;\r\n  private sessions: SessionManager;\r\n  private txManager: TransactionManager;\r\n  private closed = false;\r\n\r\n  // Service instances\r\n  private sessionService: SessionService;\r\n  private queryService: QueryService;\r\n  private graphService: GraphService;\r\n  private transactionService: TransactionService;\r\n  private dataService: DataService;\r\n  private healthService: HealthService;\r\n  private adminService: AdminService;\r\n  private bulkImportService: BulkImportService;\r\n\r\n  /** Get session metadata for authenticated requests */\r\n  private getSessionMetadata(): grpc.Metadata {\r\n    const metadata = new grpc.Metadata();\r\n    const session = this.sessions.getSession();\r\n    metadata.add('session-id', session?.id?.toString() || '0');\r\n    return metadata;\r\n  }\r\n\r\n  constructor(config: GqldbConfig) {\r\n    validateConfig(config);\r\n    this.config = config;\r\n    this.sessions = new SessionManager();\r\n    this.txManager = new TransactionManager();\r\n\r\n    // Create gRPC credentials\r\n    let credentials: grpc.ChannelCredentials;\r\n    if (config.tlsOptions) {\r\n      credentials = grpc.credentials.createSsl();\r\n    } else {\r\n      credentials = grpc.credentials.createInsecure();\r\n    }\r\n\r\n    // Channel options\r\n    const options: grpc.ChannelOptions = {\r\n      'grpc.max_receive_message_length': config.maxRecvSize ?? 4 * 1024 * 1024,\r\n      'grpc.keepalive_time_ms': 30000,\r\n      'grpc.keepalive_timeout_ms': 10000,\r\n    };\r\n\r\n    // Create service clients for the first host\r\n    const host = config.hosts[0];\r\n    this.clients = createServiceClients(host, credentials, options);\r\n\r\n    // Initialize service context\r\n    const ctx = new ServiceContext(this.config, this.sessions, this.txManager, this.clients);\r\n\r\n    // Initialize service instances\r\n    this.sessionService = new SessionService(ctx);\r\n    this.queryService = new QueryService(ctx);\r\n    this.graphService = new GraphService(ctx);\r\n    this.transactionService = new TransactionService(ctx);\r\n    this.dataService = new DataService(ctx);\r\n    this.healthService = new HealthService(ctx);\r\n    this.adminService = new AdminService(ctx);\r\n    this.bulkImportService = new BulkImportService(ctx);\r\n  }\r\n\r\n  /** Close the client and all connections */\r\n  async close(): Promise<void> {\r\n    if (this.closed) return;\r\n    this.closed = true;\r\n\r\n    if (this.sessions.isLoggedIn()) {\r\n      try {\r\n        await this.logout();\r\n      } catch (e) {\r\n        // Ignore logout errors during close\r\n      }\r\n    }\r\n\r\n    // Close all service clients\r\n    try {\r\n      (this.clients.sessionService as any).close?.();\r\n      (this.clients.queryService as any).close?.();\r\n      (this.clients.graphService as any).close?.();\r\n      (this.clients.transactionService as any).close?.();\r\n      (this.clients.dataService as any).close?.();\r\n      (this.clients.healthService as any).close?.();\r\n      (this.clients.adminService as any).close?.();\r\n      (this.clients.bulkImportService as any).close?.();\r\n    } catch (e) {\r\n      // Ignore close errors\r\n    }\r\n  }\r\n\r\n  // ===========================================================================\r\n  // Session Service\r\n  // ===========================================================================\r\n\r\n  /** Authenticate the user and create a session */\r\n  async login(username: string, password: string): Promise<Session> {\r\n    return this.sessionService.login(username, password, this.config.defaultGraph || '');\r\n  }\r\n\r\n  /** Terminate the current session */\r\n  async logout(): Promise<void> {\r\n    return this.sessionService.logout();\r\n  }\r\n\r\n  /** Check the connection and return the latency in nanoseconds */\r\n  async ping(): Promise<number> {\r\n    return this.sessionService.ping();\r\n  }\r\n\r\n  // ===========================================================================\r\n  // Query Service\r\n  // ===========================================================================\r\n\r\n  /** Execute a GQL query and return the result */\r\n  async gql(query: string, config?: QueryConfig): Promise<Response> {\r\n    return this.queryService.gql(query, config);\r\n  }\r\n\r\n  /** Execute a GQL query and stream the results */\r\n  async gqlStream(\r\n    query: string,\r\n    config?: QueryConfig,\r\n    callback?: (response: Response) => void\r\n  ): Promise<void> {\r\n    return this.queryService.gqlStream(query, config, callback);\r\n  }\r\n\r\n  /** Return the execution plan for a query */\r\n  async explain(query: string, config?: QueryConfig): Promise<string> {\r\n    return this.queryService.explain(query, config);\r\n  }\r\n\r\n  /** Execute a query with profiling and return statistics */\r\n  async profile(query: string, config?: QueryConfig): Promise<string> {\r\n    return this.queryService.profile(query, config);\r\n  }\r\n\r\n  // ===========================================================================\r\n  // Graph Service\r\n  // ===========================================================================\r\n\r\n  /** Create a new graph */\r\n  async createGraph(\r\n    name: string,\r\n    graphType: GraphType = GraphType.OPEN,\r\n    description: string = ''\r\n  ): Promise<void> {\r\n    return this.graphService.createGraph(name, graphType, description);\r\n  }\r\n\r\n  /** Delete a graph */\r\n  async dropGraph(name: string, ifExists: boolean = false): Promise<void> {\r\n    return this.graphService.dropGraph(name, ifExists);\r\n  }\r\n\r\n  /** Set the current graph for the session */\r\n  async useGraph(name: string): Promise<void> {\r\n    return this.graphService.useGraph(name);\r\n  }\r\n\r\n  /** Return all available graphs */\r\n  async listGraphs(): Promise<GraphInfo[]> {\r\n    return this.graphService.listGraphs();\r\n  }\r\n\r\n  /** Return information about a specific graph */\r\n  async getGraphInfo(name: string): Promise<GraphInfo> {\r\n    return this.graphService.getGraphInfo(name);\r\n  }\r\n\r\n  // ===========================================================================\r\n  // Transaction Service\r\n  // ===========================================================================\r\n\r\n  /** Start a new transaction */\r\n  async beginTransaction(\r\n    graphName: string,\r\n    readOnly: boolean = false,\r\n    timeout: number = 0\r\n  ): Promise<Transaction> {\r\n    return this.transactionService.beginTransaction(graphName, readOnly, timeout);\r\n  }\r\n\r\n  /** Commit a transaction */\r\n  async commit(transactionId: number): Promise<boolean> {\r\n    return this.transactionService.commit(transactionId);\r\n  }\r\n\r\n  /** Rollback a transaction */\r\n  async rollback(transactionId: number): Promise<boolean> {\r\n    return this.transactionService.rollback(transactionId);\r\n  }\r\n\r\n  /** Return active transactions */\r\n  async listTransactions(): Promise<TransactionInfo[]> {\r\n    return this.transactionService.listTransactions();\r\n  }\r\n\r\n  /** Execute a function within a transaction */\r\n  async withTransaction<T>(\r\n    graphName: string,\r\n    fn: (txId: number) => Promise<T>,\r\n    readOnly: boolean = false\r\n  ): Promise<T> {\r\n    return this.transactionService.withTransaction(graphName, fn, readOnly);\r\n  }\r\n\r\n  // ===========================================================================\r\n  // Data Service\r\n  // ===========================================================================\r\n\r\n  /** Insert multiple nodes into a graph */\r\n  async insertNodes(\r\n    graphName: string,\r\n    nodes: NodeData[],\r\n    config?: InsertNodesConfig\r\n  ): Promise<InsertNodesResult> {\r\n    return this.dataService.insertNodes(graphName, nodes, config);\r\n  }\r\n\r\n  /** Insert multiple edges into a graph */\r\n  async insertEdges(\r\n    graphName: string,\r\n    edges: EdgeData[],\r\n    config?: InsertEdgesConfig\r\n  ): Promise<InsertEdgesResult> {\r\n    return this.dataService.insertEdges(graphName, edges, config);\r\n  }\r\n\r\n  /** Delete nodes from a graph */\r\n  async deleteNodes(\r\n    graphName: string,\r\n    nodeIds?: string[],\r\n    labels?: string[],\r\n    where?: string\r\n  ): Promise<DeleteResult> {\r\n    return this.dataService.deleteNodes(graphName, nodeIds, labels, where);\r\n  }\r\n\r\n  /** Delete edges from a graph */\r\n  async deleteEdges(\r\n    graphName: string,\r\n    edgeIds?: string[],\r\n    label?: string,\r\n    where?: string\r\n  ): Promise<DeleteResult> {\r\n    return this.dataService.deleteEdges(graphName, edgeIds, label, where);\r\n  }\r\n\r\n  /**\r\n   * Export graph data in JSON Lines format (streaming).\r\n   * @param config Export configuration\r\n   * @param callback Callback for each exported chunk\r\n   */\r\n  async export(\r\n    config: ExportConfig,\r\n    callback?: (chunk: ExportChunk) => void\r\n  ): Promise<void> {\r\n    return this.dataService.export(config, callback);\r\n  }\r\n\r\n  /**\r\n   * Stream nodes from a graph\r\n   * @deprecated Use export() with ExportConfig instead\r\n   */\r\n  async exportNodes(\r\n    graphName: string,\r\n    labels?: string[],\r\n    limit: number = 0,\r\n    callback?: (result: ExportNodesResult) => void\r\n  ): Promise<void> {\r\n    return this.dataService.exportNodes(graphName, labels, limit, callback);\r\n  }\r\n\r\n  /**\r\n   * Stream edges from a graph\r\n   * @deprecated Use export() with ExportConfig instead\r\n   */\r\n  async exportEdges(\r\n    graphName: string,\r\n    labels?: string[],\r\n    limit: number = 0,\r\n    callback?: (result: ExportEdgesResult) => void\r\n  ): Promise<void> {\r\n    return this.dataService.exportEdges(graphName, labels, limit, callback);\r\n  }\r\n\r\n  // ===========================================================================\r\n  // Health Service\r\n  // ===========================================================================\r\n\r\n  /** Check the health of a service */\r\n  async healthCheck(service: string = ''): Promise<HealthStatus> {\r\n    return this.healthService.healthCheck(service);\r\n  }\r\n\r\n  /**\r\n   * Watch health status changes via server-side streaming.\r\n   * Returns a HealthWatcher that emits 'status' events with HealthStatus values.\r\n   * Call stop() to cancel the stream.\r\n   *\r\n   * @param service - Optional service name to watch\r\n   * @returns HealthWatcher - EventEmitter with stop() method\r\n   *\r\n   * @example\r\n   * ```typescript\r\n   * const watcher = client.watch();\r\n   * watcher.on('status', (status: HealthStatus) => {\r\n   *   console.log('Health status:', status);\r\n   * });\r\n   * watcher.on('error', (err) => {\r\n   *   console.error('Watch error:', err);\r\n   * });\r\n   * watcher.on('end', () => {\r\n   *   console.log('Watch stream ended');\r\n   * });\r\n   * // Later, to stop watching:\r\n   * watcher.stop();\r\n   * ```\r\n   */\r\n  watch(service: string = ''): HealthWatcher {\r\n    return this.healthService.watch(service);\r\n  }\r\n\r\n  // ===========================================================================\r\n  // Admin Service\r\n  // ===========================================================================\r\n\r\n  /** Pre-allocate parser instances */\r\n  async warmupParser(count: number): Promise<void> {\r\n    return this.adminService.warmupParser(count);\r\n  }\r\n\r\n  /** Return cache statistics */\r\n  async getCacheStats(cacheType: CacheType = CacheType.ALL): Promise<CacheStats> {\r\n    return this.adminService.getCacheStats(cacheType);\r\n  }\r\n\r\n  /** Clear the specified cache */\r\n  async clearCache(cacheType: CacheType = CacheType.ALL): Promise<void> {\r\n    return this.adminService.clearCache(cacheType);\r\n  }\r\n\r\n  /** Return database statistics */\r\n  async getStatistics(graphName: string = ''): Promise<Statistics> {\r\n    return this.adminService.getStatistics(graphName);\r\n  }\r\n\r\n  /** Invalidate the RBAC permission cache */\r\n  async invalidatePermissionCache(username: string = ''): Promise<void> {\r\n    return this.adminService.invalidatePermissionCache(username);\r\n  }\r\n\r\n  /** Trigger manual compaction of the database storage */\r\n  async compact(): Promise<CompactResult> {\r\n    return this.adminService.compact();\r\n  }\r\n\r\n  /** Wait for the computing engine topology to be ready */\r\n  async waitForComputeTopology(graphName: string, timeoutMs: number = 0): Promise<ComputeTopologyResult> {\r\n    return this.adminService.waitForComputeTopology(graphName, timeoutMs);\r\n  }\r\n\r\n  // ===========================================================================\r\n  // Bulk Import Service\r\n  // ===========================================================================\r\n\r\n  /**\r\n   * Start a bulk import session for optimized high-throughput inserts.\r\n   * @param graphName Target graph name\r\n   * @param options Optional bulk import configuration\r\n   */\r\n  async startBulkImport(graphName: string, options?: BulkImportOptions): Promise<BulkImportSession> {\r\n    return this.bulkImportService.startBulkImport(graphName, options);\r\n  }\r\n\r\n  /**\r\n   * @deprecated Checkpoint is no longer needed. Use endBulkImport() which performs a final flush.\r\n   */\r\n  async checkpoint(sessionId: string): Promise<CheckpointResult> {\r\n    return {\r\n      success: true,\r\n      recordCount: 0,\r\n      lastCheckpointCount: 0,\r\n      message: 'Checkpoint has been removed; use endBulkImport which performs a final flush',\r\n    };\r\n  }\r\n\r\n  /**\r\n   * End the bulk import session with a final checkpoint.\r\n   * @param sessionId Bulk import session ID\r\n   */\r\n  async endBulkImport(sessionId: string): Promise<EndBulkImportResult> {\r\n    return this.bulkImportService.endBulkImport(sessionId);\r\n  }\r\n\r\n  /**\r\n   * Cancel the bulk import session without final sync.\r\n   * @param sessionId Bulk import session ID\r\n   */\r\n  async abortBulkImport(sessionId: string): Promise<AbortBulkImportResult> {\r\n    return this.bulkImportService.abortBulkImport(sessionId);\r\n  }\r\n\r\n  /**\r\n   * Return the current status of a bulk import session.\r\n   * @param sessionId Bulk import session ID\r\n   */\r\n  async getBulkImportStatus(sessionId: string): Promise<BulkImportStatus> {\r\n    return this.bulkImportService.getBulkImportStatus(sessionId);\r\n  }\r\n\r\n  // ===========================================================================\r\n  // Convenience Methods\r\n  // ===========================================================================\r\n\r\n  /** Get the current session */\r\n  getSession(): Session | null {\r\n    return this.sessions.getSession();\r\n  }\r\n\r\n  /** Check if there is an active session */\r\n  isLoggedIn(): boolean {\r\n    return this.sessions.isLoggedIn();\r\n  }\r\n\r\n  /** Get the client configuration */\r\n  getConfig(): GqldbConfig {\r\n    return this.config;\r\n  }\r\n\r\n  /** Whether this client is connected to a cluster deployment */\r\n  get isCluster(): boolean {\r\n    return this.sessions.getSession()?.isCluster || false;\r\n  }\r\n\r\n  /** Get the cluster ID (empty string if not a cluster) */\r\n  get clusterId(): string {\r\n    return this.sessions.getSession()?.clusterId || '';\r\n  }\r\n\r\n  /** Get the partition count (0 if not a cluster) */\r\n  get partitionCount(): number {\r\n    return this.sessions.getSession()?.partitionCount || 0;\r\n  }\r\n}\r\n"]}
|
package/dist/config.d.ts
ADDED
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Configuration for GQLDB Node.js driver.
|
|
3
|
+
*/
|
|
4
|
+
import * as tls from 'tls';
|
|
5
|
+
/** Configuration options for GqldbClient */
|
|
6
|
+
export interface GqldbConfig {
|
|
7
|
+
/** Server hosts in format "host:port" */
|
|
8
|
+
hosts: string[];
|
|
9
|
+
/** Username for authentication */
|
|
10
|
+
username?: string;
|
|
11
|
+
/** Password for authentication */
|
|
12
|
+
password?: string;
|
|
13
|
+
/** Default graph to use */
|
|
14
|
+
defaultGraph?: string;
|
|
15
|
+
/** Query timeout in milliseconds (default 30000ms = 30s) */
|
|
16
|
+
timeout?: number;
|
|
17
|
+
/** Maximum receive message size in bytes (default 64MB) */
|
|
18
|
+
maxRecvSize?: number;
|
|
19
|
+
/** TLS options for secure connections */
|
|
20
|
+
tlsOptions?: tls.ConnectionOptions;
|
|
21
|
+
/** Connection pool size per host */
|
|
22
|
+
poolSize?: number;
|
|
23
|
+
/** Health check interval in milliseconds (default 30000ms = 30s) */
|
|
24
|
+
healthCheckInterval?: number;
|
|
25
|
+
/** Number of retries for failed requests */
|
|
26
|
+
retryCount?: number;
|
|
27
|
+
/** Delay between retries in milliseconds (default 100ms) */
|
|
28
|
+
retryDelay?: number;
|
|
29
|
+
}
|
|
30
|
+
/** Default configuration values */
|
|
31
|
+
export declare const DEFAULT_CONFIG: Required<Omit<GqldbConfig, 'username' | 'password' | 'defaultGraph' | 'tlsOptions'>>;
|
|
32
|
+
/** Builder for creating GqldbConfig */
|
|
33
|
+
export declare class ConfigBuilder {
|
|
34
|
+
private config;
|
|
35
|
+
/** Set the server hosts */
|
|
36
|
+
hosts(...hosts: string[]): this;
|
|
37
|
+
/** Set the username for authentication */
|
|
38
|
+
username(username: string): this;
|
|
39
|
+
/** Set the password for authentication */
|
|
40
|
+
password(password: string): this;
|
|
41
|
+
/** Set the default graph */
|
|
42
|
+
defaultGraph(graph: string): this;
|
|
43
|
+
/** Set the query timeout in milliseconds */
|
|
44
|
+
timeout(ms: number): this;
|
|
45
|
+
/** Set the query timeout in seconds (convenience method) */
|
|
46
|
+
timeoutSeconds(seconds: number): this;
|
|
47
|
+
/** Set the maximum receive message size */
|
|
48
|
+
maxRecvSize(bytes: number): this;
|
|
49
|
+
/** Set TLS options */
|
|
50
|
+
tls(options: tls.ConnectionOptions): this;
|
|
51
|
+
/** Set the connection pool size per host */
|
|
52
|
+
poolSize(size: number): this;
|
|
53
|
+
/** Set the health check interval in milliseconds */
|
|
54
|
+
healthCheckInterval(ms: number): this;
|
|
55
|
+
/** Set the number of retries */
|
|
56
|
+
retryCount(count: number): this;
|
|
57
|
+
/** Set the delay between retries in milliseconds */
|
|
58
|
+
retryDelay(ms: number): this;
|
|
59
|
+
/** Build and return the configuration */
|
|
60
|
+
build(): GqldbConfig;
|
|
61
|
+
}
|
|
62
|
+
/** Validate the configuration */
|
|
63
|
+
export declare function validateConfig(config: GqldbConfig): void;
|
|
64
|
+
/** Create a configuration with defaults */
|
|
65
|
+
export declare function createConfig(options?: Partial<GqldbConfig>): GqldbConfig;
|