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/response.js
ADDED
|
@@ -0,0 +1,723 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Response handling for GQLDB Node.js driver.
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.Response = exports.AliasResult = exports.Row = void 0;
|
|
7
|
+
const types_1 = require("./types");
|
|
8
|
+
/** Represents a single row in the query result */
|
|
9
|
+
class Row {
|
|
10
|
+
values;
|
|
11
|
+
types;
|
|
12
|
+
constructor(values, types = []) {
|
|
13
|
+
this.values = values;
|
|
14
|
+
this.types = types;
|
|
15
|
+
}
|
|
16
|
+
/** Get the value at the given column index */
|
|
17
|
+
get(index) {
|
|
18
|
+
if (index < 0 || index >= this.values.length) {
|
|
19
|
+
throw new Error(`Column index out of range: ${index}`);
|
|
20
|
+
}
|
|
21
|
+
const value = this.values[index];
|
|
22
|
+
// If value is a TypedValue object, convert it
|
|
23
|
+
if (value && typeof value === 'object' && 'type' in value && 'data' in value && 'isNull' in value) {
|
|
24
|
+
return (0, types_1.typedValueToJS)(value);
|
|
25
|
+
}
|
|
26
|
+
return value;
|
|
27
|
+
}
|
|
28
|
+
/** Get the PropertyType at the given column index */
|
|
29
|
+
getType(index) {
|
|
30
|
+
if (index < 0 || index >= this.types.length) {
|
|
31
|
+
return types_1.PropertyType.UNSET;
|
|
32
|
+
}
|
|
33
|
+
return this.types[index];
|
|
34
|
+
}
|
|
35
|
+
/** Get the value at the given column index as a string */
|
|
36
|
+
getString(index) {
|
|
37
|
+
const val = this.get(index);
|
|
38
|
+
if (val === null || val === undefined)
|
|
39
|
+
return '';
|
|
40
|
+
if (typeof val === 'string')
|
|
41
|
+
return val;
|
|
42
|
+
return String(val);
|
|
43
|
+
}
|
|
44
|
+
/** Get the value at the given column index as a number */
|
|
45
|
+
getNumber(index) {
|
|
46
|
+
const val = this.get(index);
|
|
47
|
+
if (val === null || val === undefined)
|
|
48
|
+
return 0;
|
|
49
|
+
if (typeof val === 'number')
|
|
50
|
+
return val;
|
|
51
|
+
const num = Number(val);
|
|
52
|
+
if (isNaN(num))
|
|
53
|
+
throw new Error(`Cannot convert ${typeof val} to number`);
|
|
54
|
+
return num;
|
|
55
|
+
}
|
|
56
|
+
/** Get the value at the given column index as a boolean */
|
|
57
|
+
getBoolean(index) {
|
|
58
|
+
const val = this.get(index);
|
|
59
|
+
if (val === null || val === undefined)
|
|
60
|
+
return false;
|
|
61
|
+
if (typeof val === 'boolean')
|
|
62
|
+
return val;
|
|
63
|
+
throw new Error(`Cannot convert ${typeof val} to boolean`);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
exports.Row = Row;
|
|
67
|
+
/**
|
|
68
|
+
* Represents a single column's data from the response.
|
|
69
|
+
* Allows chaining operations like resp.alias("n").asNodes() or resp.get(0).asNodes().
|
|
70
|
+
*/
|
|
71
|
+
class AliasResult {
|
|
72
|
+
aliasName;
|
|
73
|
+
columnIdx;
|
|
74
|
+
response;
|
|
75
|
+
constructor(aliasName, columnIdx, response) {
|
|
76
|
+
this.aliasName = aliasName;
|
|
77
|
+
this.columnIdx = columnIdx;
|
|
78
|
+
this.response = response;
|
|
79
|
+
}
|
|
80
|
+
/** Get the alias name */
|
|
81
|
+
get alias() {
|
|
82
|
+
return this.aliasName;
|
|
83
|
+
}
|
|
84
|
+
/** Get the column index */
|
|
85
|
+
get columnIndex() {
|
|
86
|
+
return this.columnIdx;
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Extract nodes from the aliased column with schema info.
|
|
90
|
+
* Throws TypeError if the column contains non-NODE types.
|
|
91
|
+
*/
|
|
92
|
+
collectNode(val, nodes, schemas) {
|
|
93
|
+
if (val && typeof val.id === 'string' && 'labels' in val) {
|
|
94
|
+
const node = {
|
|
95
|
+
id: val.id,
|
|
96
|
+
labels: val.labels || [],
|
|
97
|
+
properties: val.properties || {},
|
|
98
|
+
};
|
|
99
|
+
nodes.push(node);
|
|
100
|
+
for (const label of node.labels) {
|
|
101
|
+
if (!schemas.has(label)) {
|
|
102
|
+
schemas.set(label, this.buildSchemaFromNode(label, node));
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
collectEdge(val, edges, schemas) {
|
|
108
|
+
if (val && typeof val.id === 'string' && 'label' in val) {
|
|
109
|
+
const edge = {
|
|
110
|
+
id: val.id,
|
|
111
|
+
label: val.label || '',
|
|
112
|
+
fromNodeId: val.fromNodeId || '',
|
|
113
|
+
toNodeId: val.toNodeId || '',
|
|
114
|
+
properties: val.properties || {},
|
|
115
|
+
};
|
|
116
|
+
edges.push(edge);
|
|
117
|
+
if (edge.label && !schemas.has(edge.label)) {
|
|
118
|
+
schemas.set(edge.label, this.buildSchemaFromEdge(edge.label, edge));
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* Extract nodes from the aliased column with schema info.
|
|
124
|
+
* Supports both direct NODE columns and LIST of NODE columns
|
|
125
|
+
* (e.g., group variables from quantified patterns).
|
|
126
|
+
*/
|
|
127
|
+
asNodes() {
|
|
128
|
+
const nodes = [];
|
|
129
|
+
const schemas = new Map();
|
|
130
|
+
for (const row of this.response.rows) {
|
|
131
|
+
if (this.columnIdx >= row.values.length) {
|
|
132
|
+
continue;
|
|
133
|
+
}
|
|
134
|
+
let itemType = row.getType(this.columnIdx);
|
|
135
|
+
const rawValue = row.values[this.columnIdx];
|
|
136
|
+
if (itemType === types_1.PropertyType.UNSET && rawValue && typeof rawValue === 'object' && 'type' in rawValue) {
|
|
137
|
+
itemType = rawValue.type;
|
|
138
|
+
}
|
|
139
|
+
if (!rawValue || (typeof rawValue === 'object' && 'isNull' in rawValue && rawValue.isNull)) {
|
|
140
|
+
continue;
|
|
141
|
+
}
|
|
142
|
+
if (itemType === types_1.PropertyType.NODE) {
|
|
143
|
+
this.collectNode(row.get(this.columnIdx), nodes, schemas);
|
|
144
|
+
}
|
|
145
|
+
else if (itemType === types_1.PropertyType.LIST) {
|
|
146
|
+
// LIST of NODE (group variable from quantified pattern)
|
|
147
|
+
const list = row.get(this.columnIdx);
|
|
148
|
+
if (Array.isArray(list)) {
|
|
149
|
+
for (const item of list) {
|
|
150
|
+
this.collectNode(item, nodes, schemas);
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
else {
|
|
155
|
+
throw new TypeError(`Type mismatch: column '${this.aliasName}' (index ${this.columnIdx}) contains ${types_1.PropertyType[itemType]}, expected NODE or LIST of NODE`);
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
return { nodes, schemas };
|
|
159
|
+
}
|
|
160
|
+
/**
|
|
161
|
+
* Extract edges from the aliased column with schema info.
|
|
162
|
+
* Supports both direct EDGE columns and LIST of EDGE columns
|
|
163
|
+
* (e.g., group variables from quantified patterns).
|
|
164
|
+
*/
|
|
165
|
+
asEdges() {
|
|
166
|
+
const edges = [];
|
|
167
|
+
const schemas = new Map();
|
|
168
|
+
for (const row of this.response.rows) {
|
|
169
|
+
if (this.columnIdx >= row.values.length) {
|
|
170
|
+
continue;
|
|
171
|
+
}
|
|
172
|
+
let itemType = row.getType(this.columnIdx);
|
|
173
|
+
const rawValue = row.values[this.columnIdx];
|
|
174
|
+
if (itemType === types_1.PropertyType.UNSET && rawValue && typeof rawValue === 'object' && 'type' in rawValue) {
|
|
175
|
+
itemType = rawValue.type;
|
|
176
|
+
}
|
|
177
|
+
if (!rawValue || (typeof rawValue === 'object' && 'isNull' in rawValue && rawValue.isNull)) {
|
|
178
|
+
continue;
|
|
179
|
+
}
|
|
180
|
+
if (itemType === types_1.PropertyType.EDGE) {
|
|
181
|
+
this.collectEdge(row.get(this.columnIdx), edges, schemas);
|
|
182
|
+
}
|
|
183
|
+
else if (itemType === types_1.PropertyType.LIST) {
|
|
184
|
+
// LIST of EDGE (group variable from quantified pattern)
|
|
185
|
+
const list = row.get(this.columnIdx);
|
|
186
|
+
if (Array.isArray(list)) {
|
|
187
|
+
for (const item of list) {
|
|
188
|
+
this.collectEdge(item, edges, schemas);
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
else {
|
|
193
|
+
throw new TypeError(`Type mismatch: column '${this.aliasName}' (index ${this.columnIdx}) contains ${types_1.PropertyType[itemType]}, expected EDGE or LIST of EDGE`);
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
return { edges, schemas };
|
|
197
|
+
}
|
|
198
|
+
/**
|
|
199
|
+
* Extract paths from the aliased column.
|
|
200
|
+
* Throws TypeError if the column contains non-PATH types.
|
|
201
|
+
*/
|
|
202
|
+
asPaths() {
|
|
203
|
+
const paths = [];
|
|
204
|
+
for (const row of this.response.rows) {
|
|
205
|
+
if (this.columnIdx >= row.values.length) {
|
|
206
|
+
continue;
|
|
207
|
+
}
|
|
208
|
+
// Check type from types array or from TypedValue object
|
|
209
|
+
let itemType = row.getType(this.columnIdx);
|
|
210
|
+
const rawValue = row.values[this.columnIdx];
|
|
211
|
+
if (itemType === types_1.PropertyType.UNSET && rawValue && typeof rawValue === 'object' && 'type' in rawValue) {
|
|
212
|
+
itemType = rawValue.type;
|
|
213
|
+
}
|
|
214
|
+
// Skip null values
|
|
215
|
+
if (!rawValue || (typeof rawValue === 'object' && 'isNull' in rawValue && rawValue.isNull)) {
|
|
216
|
+
continue;
|
|
217
|
+
}
|
|
218
|
+
// Type checking: must be PATH type
|
|
219
|
+
if (itemType !== types_1.PropertyType.PATH) {
|
|
220
|
+
throw new TypeError(`Type mismatch: column '${this.aliasName}' (index ${this.columnIdx}) contains ${types_1.PropertyType[itemType]}, expected PATH`);
|
|
221
|
+
}
|
|
222
|
+
// Convert TypedValue to GqldbPath
|
|
223
|
+
const val = row.get(this.columnIdx);
|
|
224
|
+
if (val && Array.isArray(val.nodes)) {
|
|
225
|
+
// Convert GqldbNode/GqldbEdge to Node/Edge
|
|
226
|
+
const nodes = (val.nodes || []).map((n) => ({
|
|
227
|
+
id: n.id || '',
|
|
228
|
+
labels: n.labels || [],
|
|
229
|
+
properties: n.properties || {},
|
|
230
|
+
}));
|
|
231
|
+
const edges = (val.edges || []).map((e) => ({
|
|
232
|
+
id: e.id || '',
|
|
233
|
+
label: e.label || '',
|
|
234
|
+
fromNodeId: e.fromNodeId || '',
|
|
235
|
+
toNodeId: e.toNodeId || '',
|
|
236
|
+
properties: e.properties || {},
|
|
237
|
+
}));
|
|
238
|
+
paths.push({ nodes, edges });
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
return paths;
|
|
242
|
+
}
|
|
243
|
+
/** Convert the aliased column to a single-column table */
|
|
244
|
+
asTable() {
|
|
245
|
+
// Check if first non-null value is a GqldbTable — if so, unwrap it
|
|
246
|
+
for (const row of this.response.rows) {
|
|
247
|
+
if (this.columnIdx < row.values.length) {
|
|
248
|
+
const itemType = row.getType(this.columnIdx);
|
|
249
|
+
if (itemType === types_1.PropertyType.TABLE) {
|
|
250
|
+
const val = row.get(this.columnIdx);
|
|
251
|
+
if (val && 'columns' in val && 'rows' in val) {
|
|
252
|
+
return this.unwrapGqldbTable(val);
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
break; // only check first row
|
|
257
|
+
}
|
|
258
|
+
// Fallback: generic single-column table
|
|
259
|
+
const headers = [{
|
|
260
|
+
name: this.aliasName,
|
|
261
|
+
type: types_1.PropertyType.UNSET,
|
|
262
|
+
}];
|
|
263
|
+
if (this.response.rows.length > 0) {
|
|
264
|
+
for (const row of this.response.rows) {
|
|
265
|
+
if (this.columnIdx < row.values.length) {
|
|
266
|
+
const type = row.getType(this.columnIdx);
|
|
267
|
+
if (type !== types_1.PropertyType.UNSET) {
|
|
268
|
+
headers[0].type = type;
|
|
269
|
+
break;
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
}
|
|
274
|
+
const tableRows = this.response.rows.map(row => {
|
|
275
|
+
if (this.columnIdx < row.values.length) {
|
|
276
|
+
return [row.get(this.columnIdx)];
|
|
277
|
+
}
|
|
278
|
+
return [null];
|
|
279
|
+
});
|
|
280
|
+
return { name: '', headers, rows: tableRows };
|
|
281
|
+
}
|
|
282
|
+
unwrapGqldbTable(gt) {
|
|
283
|
+
const headers = gt.columns.map((col, i) => {
|
|
284
|
+
let colType = types_1.PropertyType.UNSET;
|
|
285
|
+
if (gt.rows.length > 0 && i < gt.rows[0].length) {
|
|
286
|
+
const v = gt.rows[0][i];
|
|
287
|
+
if (typeof v === 'number')
|
|
288
|
+
colType = Number.isInteger(v) ? types_1.PropertyType.INT64 : types_1.PropertyType.DOUBLE;
|
|
289
|
+
else if (typeof v === 'string')
|
|
290
|
+
colType = types_1.PropertyType.STRING;
|
|
291
|
+
else if (typeof v === 'boolean')
|
|
292
|
+
colType = types_1.PropertyType.BOOL;
|
|
293
|
+
}
|
|
294
|
+
return { name: col, type: colType };
|
|
295
|
+
});
|
|
296
|
+
return { name: this.aliasName, headers, rows: gt.rows };
|
|
297
|
+
}
|
|
298
|
+
/** Extract scalar or list attribute values from the aliased column */
|
|
299
|
+
asAttr() {
|
|
300
|
+
const values = [];
|
|
301
|
+
let attrType = types_1.PropertyType.UNSET;
|
|
302
|
+
for (const row of this.response.rows) {
|
|
303
|
+
if (this.columnIdx < row.values.length) {
|
|
304
|
+
// Try to get type from row.types first, then from TypedValue object
|
|
305
|
+
if (attrType === types_1.PropertyType.UNSET) {
|
|
306
|
+
attrType = row.getType(this.columnIdx);
|
|
307
|
+
if (attrType === types_1.PropertyType.UNSET) {
|
|
308
|
+
const rawValue = row.values[this.columnIdx];
|
|
309
|
+
if (rawValue && typeof rawValue === 'object' && 'type' in rawValue) {
|
|
310
|
+
attrType = rawValue.type;
|
|
311
|
+
}
|
|
312
|
+
}
|
|
313
|
+
}
|
|
314
|
+
const value = row.get(this.columnIdx); // Use get() to convert TypedValue
|
|
315
|
+
values.push(value);
|
|
316
|
+
}
|
|
317
|
+
}
|
|
318
|
+
return { name: this.aliasName, type: attrType, values };
|
|
319
|
+
}
|
|
320
|
+
/** Extract raw JavaScript values from the aliased column */
|
|
321
|
+
asValues() {
|
|
322
|
+
const values = [];
|
|
323
|
+
for (const row of this.response.rows) {
|
|
324
|
+
if (this.columnIdx < row.values.length) {
|
|
325
|
+
values.push(row.get(this.columnIdx));
|
|
326
|
+
}
|
|
327
|
+
}
|
|
328
|
+
return values;
|
|
329
|
+
}
|
|
330
|
+
// Helper methods
|
|
331
|
+
buildSchemaFromNode(label, node) {
|
|
332
|
+
const properties = Object.entries(node.properties).map(([name, value]) => ({
|
|
333
|
+
name,
|
|
334
|
+
type: this.inferPropertyType(value),
|
|
335
|
+
}));
|
|
336
|
+
return { name: label, properties };
|
|
337
|
+
}
|
|
338
|
+
buildSchemaFromEdge(label, edge) {
|
|
339
|
+
const properties = Object.entries(edge.properties).map(([name, value]) => ({
|
|
340
|
+
name,
|
|
341
|
+
type: this.inferPropertyType(value),
|
|
342
|
+
}));
|
|
343
|
+
return { name: label, properties };
|
|
344
|
+
}
|
|
345
|
+
inferPropertyType(value) {
|
|
346
|
+
if (value === null || value === undefined)
|
|
347
|
+
return types_1.PropertyType.NULL;
|
|
348
|
+
if (typeof value === 'boolean')
|
|
349
|
+
return types_1.PropertyType.BOOL;
|
|
350
|
+
if (typeof value === 'number') {
|
|
351
|
+
return Number.isInteger(value) ? types_1.PropertyType.INT64 : types_1.PropertyType.DOUBLE;
|
|
352
|
+
}
|
|
353
|
+
if (typeof value === 'string')
|
|
354
|
+
return types_1.PropertyType.STRING;
|
|
355
|
+
if (Buffer.isBuffer(value))
|
|
356
|
+
return types_1.PropertyType.BLOB;
|
|
357
|
+
if (Array.isArray(value))
|
|
358
|
+
return types_1.PropertyType.LIST;
|
|
359
|
+
if (typeof value === 'object')
|
|
360
|
+
return types_1.PropertyType.MAP;
|
|
361
|
+
return types_1.PropertyType.UNSET;
|
|
362
|
+
}
|
|
363
|
+
}
|
|
364
|
+
exports.AliasResult = AliasResult;
|
|
365
|
+
/** Represents the result of a GQL query */
|
|
366
|
+
class Response {
|
|
367
|
+
columns;
|
|
368
|
+
rows;
|
|
369
|
+
rowCount;
|
|
370
|
+
hasMore;
|
|
371
|
+
warnings;
|
|
372
|
+
rowsAffected;
|
|
373
|
+
constructor(columns, rows, rowCount, hasMore, warnings, rowsAffected = 0) {
|
|
374
|
+
this.columns = columns;
|
|
375
|
+
this.rows = rows;
|
|
376
|
+
this.rowCount = rowCount;
|
|
377
|
+
this.hasMore = hasMore;
|
|
378
|
+
this.warnings = warnings;
|
|
379
|
+
this.rowsAffected = rowsAffected;
|
|
380
|
+
}
|
|
381
|
+
/** Check if the response has no rows */
|
|
382
|
+
isEmpty() {
|
|
383
|
+
return this.rows.length === 0;
|
|
384
|
+
}
|
|
385
|
+
/** Get the first row */
|
|
386
|
+
first() {
|
|
387
|
+
return this.rows[0];
|
|
388
|
+
}
|
|
389
|
+
/** Get the last row */
|
|
390
|
+
last() {
|
|
391
|
+
return this.rows[this.rows.length - 1];
|
|
392
|
+
}
|
|
393
|
+
/** Get the value for a column by name */
|
|
394
|
+
getByName(row, columnName) {
|
|
395
|
+
const index = this.columns.indexOf(columnName);
|
|
396
|
+
if (index === -1) {
|
|
397
|
+
throw new Error(`Column not found: ${columnName}`);
|
|
398
|
+
}
|
|
399
|
+
return row.get(index);
|
|
400
|
+
}
|
|
401
|
+
/** Iterate over all rows with a callback */
|
|
402
|
+
forEach(fn) {
|
|
403
|
+
this.rows.forEach(fn);
|
|
404
|
+
}
|
|
405
|
+
/** Transform each row using a callback */
|
|
406
|
+
map(fn) {
|
|
407
|
+
return this.rows.map(fn);
|
|
408
|
+
}
|
|
409
|
+
/** Convert the response to an array of objects */
|
|
410
|
+
toObjects() {
|
|
411
|
+
return this.rows.map(row => {
|
|
412
|
+
const obj = {};
|
|
413
|
+
this.columns.forEach((col, i) => {
|
|
414
|
+
// Add boundary check to handle mismatched columns/values
|
|
415
|
+
obj[col] = i < row.values.length ? row.get(i) : null;
|
|
416
|
+
});
|
|
417
|
+
return obj;
|
|
418
|
+
});
|
|
419
|
+
}
|
|
420
|
+
/** Convert the response to JSON */
|
|
421
|
+
toJSON() {
|
|
422
|
+
return JSON.stringify(this.toObjects());
|
|
423
|
+
}
|
|
424
|
+
/** Get the single value from a single-row, single-column response */
|
|
425
|
+
singleValue() {
|
|
426
|
+
if (this.rows.length === 0)
|
|
427
|
+
return null;
|
|
428
|
+
if (this.rows.length > 1) {
|
|
429
|
+
throw new Error(`Expected single row, got ${this.rows.length}`);
|
|
430
|
+
}
|
|
431
|
+
if (this.rows[0].values.length === 0)
|
|
432
|
+
return null;
|
|
433
|
+
if (this.rows[0].values.length > 1) {
|
|
434
|
+
throw new Error(`Expected single column, got ${this.rows[0].values.length}`);
|
|
435
|
+
}
|
|
436
|
+
return this.rows[0].get(0);
|
|
437
|
+
}
|
|
438
|
+
/** Get the single number value */
|
|
439
|
+
singleNumber() {
|
|
440
|
+
const val = this.singleValue();
|
|
441
|
+
if (val === null || val === undefined)
|
|
442
|
+
return 0;
|
|
443
|
+
if (typeof val === 'number')
|
|
444
|
+
return val;
|
|
445
|
+
const num = Number(val);
|
|
446
|
+
if (isNaN(num))
|
|
447
|
+
throw new Error(`Cannot convert ${typeof val} to number`);
|
|
448
|
+
return num;
|
|
449
|
+
}
|
|
450
|
+
/** Get the single string value */
|
|
451
|
+
singleString() {
|
|
452
|
+
const val = this.singleValue();
|
|
453
|
+
if (val === null || val === undefined)
|
|
454
|
+
return '';
|
|
455
|
+
if (typeof val === 'string')
|
|
456
|
+
return val;
|
|
457
|
+
return String(val);
|
|
458
|
+
}
|
|
459
|
+
/** Iterator support */
|
|
460
|
+
[Symbol.iterator]() {
|
|
461
|
+
return this.rows[Symbol.iterator]();
|
|
462
|
+
}
|
|
463
|
+
/** Get the number of rows */
|
|
464
|
+
get length() {
|
|
465
|
+
return this.rows.length;
|
|
466
|
+
}
|
|
467
|
+
/**
|
|
468
|
+
* Get an AliasResult for the specified column name.
|
|
469
|
+
* Use this to extract data from a specific column by name.
|
|
470
|
+
* Example: resp.alias("n").asNodes()
|
|
471
|
+
*/
|
|
472
|
+
alias(columnName) {
|
|
473
|
+
const colIdx = this.columns.indexOf(columnName);
|
|
474
|
+
if (colIdx === -1) {
|
|
475
|
+
throw new Error(`Column alias not found: ${columnName}`);
|
|
476
|
+
}
|
|
477
|
+
return new AliasResult(columnName, colIdx, this);
|
|
478
|
+
}
|
|
479
|
+
/**
|
|
480
|
+
* Get an AliasResult for the column at the specified index.
|
|
481
|
+
* Use this to extract data from a specific column by index.
|
|
482
|
+
* Example: resp.get(0).asNodes()
|
|
483
|
+
*/
|
|
484
|
+
get(index) {
|
|
485
|
+
if (index < 0 || index >= this.columns.length) {
|
|
486
|
+
throw new Error(`Column index out of range: ${index} (total: ${this.columns.length})`);
|
|
487
|
+
}
|
|
488
|
+
return new AliasResult(this.columns[index], index, this);
|
|
489
|
+
}
|
|
490
|
+
/**
|
|
491
|
+
* @deprecated Use alias() or get() instead. This method will be removed in a future version.
|
|
492
|
+
* Extract nodes from response with schema info.
|
|
493
|
+
* Supports both NODE and LIST of NODE columns.
|
|
494
|
+
*/
|
|
495
|
+
asNodes() {
|
|
496
|
+
const nodes = [];
|
|
497
|
+
const schemas = new Map();
|
|
498
|
+
const collectNode = (val) => {
|
|
499
|
+
if (val && typeof val.id === 'string' && 'labels' in val) {
|
|
500
|
+
const node = {
|
|
501
|
+
id: val.id,
|
|
502
|
+
labels: val.labels || [],
|
|
503
|
+
properties: val.properties || {},
|
|
504
|
+
};
|
|
505
|
+
nodes.push(node);
|
|
506
|
+
for (const label of node.labels) {
|
|
507
|
+
if (!schemas.has(label)) {
|
|
508
|
+
schemas.set(label, this.buildSchemaFromNode(label, node));
|
|
509
|
+
}
|
|
510
|
+
}
|
|
511
|
+
}
|
|
512
|
+
};
|
|
513
|
+
for (const row of this.rows) {
|
|
514
|
+
for (let i = 0; i < row.values.length; i++) {
|
|
515
|
+
let itemType = row.getType(i);
|
|
516
|
+
const rawValue = row.values[i];
|
|
517
|
+
if (itemType === types_1.PropertyType.UNSET && rawValue && typeof rawValue === 'object' && 'type' in rawValue) {
|
|
518
|
+
itemType = rawValue.type;
|
|
519
|
+
}
|
|
520
|
+
if (itemType === types_1.PropertyType.NODE) {
|
|
521
|
+
collectNode(row.get(i));
|
|
522
|
+
}
|
|
523
|
+
else if (itemType === types_1.PropertyType.LIST) {
|
|
524
|
+
const list = row.get(i);
|
|
525
|
+
if (Array.isArray(list)) {
|
|
526
|
+
for (const item of list) {
|
|
527
|
+
collectNode(item);
|
|
528
|
+
}
|
|
529
|
+
}
|
|
530
|
+
}
|
|
531
|
+
}
|
|
532
|
+
}
|
|
533
|
+
return { nodes, schemas };
|
|
534
|
+
}
|
|
535
|
+
/**
|
|
536
|
+
* @deprecated Use alias() or get() instead. This method will be removed in a future version.
|
|
537
|
+
* Extract edges from response with schema info.
|
|
538
|
+
* Supports both EDGE and LIST of EDGE columns.
|
|
539
|
+
*/
|
|
540
|
+
asEdges() {
|
|
541
|
+
const edges = [];
|
|
542
|
+
const schemas = new Map();
|
|
543
|
+
const collectEdge = (val) => {
|
|
544
|
+
if (val && typeof val.id === 'string' && 'label' in val) {
|
|
545
|
+
const edge = {
|
|
546
|
+
id: val.id,
|
|
547
|
+
label: val.label || '',
|
|
548
|
+
fromNodeId: val.fromNodeId || '',
|
|
549
|
+
toNodeId: val.toNodeId || '',
|
|
550
|
+
properties: val.properties || {},
|
|
551
|
+
};
|
|
552
|
+
edges.push(edge);
|
|
553
|
+
if (edge.label && !schemas.has(edge.label)) {
|
|
554
|
+
schemas.set(edge.label, this.buildSchemaFromEdge(edge.label, edge));
|
|
555
|
+
}
|
|
556
|
+
}
|
|
557
|
+
};
|
|
558
|
+
for (const row of this.rows) {
|
|
559
|
+
for (let i = 0; i < row.values.length; i++) {
|
|
560
|
+
let itemType = row.getType(i);
|
|
561
|
+
const rawValue = row.values[i];
|
|
562
|
+
if (itemType === types_1.PropertyType.UNSET && rawValue && typeof rawValue === 'object' && 'type' in rawValue) {
|
|
563
|
+
itemType = rawValue.type;
|
|
564
|
+
}
|
|
565
|
+
if (itemType === types_1.PropertyType.EDGE) {
|
|
566
|
+
collectEdge(row.get(i));
|
|
567
|
+
}
|
|
568
|
+
else if (itemType === types_1.PropertyType.LIST) {
|
|
569
|
+
const list = row.get(i);
|
|
570
|
+
if (Array.isArray(list)) {
|
|
571
|
+
for (const item of list) {
|
|
572
|
+
collectEdge(item);
|
|
573
|
+
}
|
|
574
|
+
}
|
|
575
|
+
}
|
|
576
|
+
}
|
|
577
|
+
}
|
|
578
|
+
return { edges, schemas };
|
|
579
|
+
}
|
|
580
|
+
/**
|
|
581
|
+
* @deprecated Use alias() or get() instead. This method will be removed in a future version.
|
|
582
|
+
* Extract paths from response.
|
|
583
|
+
* Paths are identified by PropertyType.PATH type in the TypedValue.
|
|
584
|
+
*/
|
|
585
|
+
asPaths() {
|
|
586
|
+
const paths = [];
|
|
587
|
+
for (const row of this.rows) {
|
|
588
|
+
for (let i = 0; i < row.values.length; i++) {
|
|
589
|
+
// Check type from types array or from TypedValue object
|
|
590
|
+
let itemType = row.getType(i);
|
|
591
|
+
const rawValue = row.values[i];
|
|
592
|
+
if (itemType === types_1.PropertyType.UNSET && rawValue && typeof rawValue === 'object' && 'type' in rawValue) {
|
|
593
|
+
itemType = rawValue.type;
|
|
594
|
+
}
|
|
595
|
+
if (itemType === types_1.PropertyType.PATH) {
|
|
596
|
+
// Convert TypedValue to GqldbPath
|
|
597
|
+
const val = row.get(i);
|
|
598
|
+
if (val && Array.isArray(val.nodes)) {
|
|
599
|
+
// Convert GqldbNode/GqldbEdge to Node/Edge
|
|
600
|
+
const nodes = (val.nodes || []).map((n) => ({
|
|
601
|
+
id: n.id || '',
|
|
602
|
+
labels: n.labels || [],
|
|
603
|
+
properties: n.properties || {},
|
|
604
|
+
}));
|
|
605
|
+
const edges = (val.edges || []).map((e) => ({
|
|
606
|
+
id: e.id || '',
|
|
607
|
+
label: e.label || '',
|
|
608
|
+
fromNodeId: e.fromNodeId || '',
|
|
609
|
+
toNodeId: e.toNodeId || '',
|
|
610
|
+
properties: e.properties || {},
|
|
611
|
+
}));
|
|
612
|
+
paths.push({ nodes, edges });
|
|
613
|
+
}
|
|
614
|
+
}
|
|
615
|
+
}
|
|
616
|
+
}
|
|
617
|
+
return paths;
|
|
618
|
+
}
|
|
619
|
+
/**
|
|
620
|
+
* @deprecated Use alias() or get() instead. This method will be removed in a future version.
|
|
621
|
+
* Return response as generic table.
|
|
622
|
+
* If response is a single TABLE column, unwraps the GqldbTable into proper headers/rows.
|
|
623
|
+
*/
|
|
624
|
+
asTable() {
|
|
625
|
+
// If single column of TABLE type, unwrap GqldbTable
|
|
626
|
+
if (this.columns.length === 1 && this.rows.length > 0) {
|
|
627
|
+
const itemType = this.rows[0].getType(0);
|
|
628
|
+
if (itemType === types_1.PropertyType.TABLE) {
|
|
629
|
+
const val = this.rows[0].get(0);
|
|
630
|
+
if (val && 'columns' in val && 'rows' in val) {
|
|
631
|
+
const gt = val;
|
|
632
|
+
const headers = gt.columns.map((col, i) => {
|
|
633
|
+
let colType = types_1.PropertyType.UNSET;
|
|
634
|
+
if (gt.rows.length > 0 && i < gt.rows[0].length) {
|
|
635
|
+
const v = gt.rows[0][i];
|
|
636
|
+
if (typeof v === 'number')
|
|
637
|
+
colType = Number.isInteger(v) ? types_1.PropertyType.INT64 : types_1.PropertyType.DOUBLE;
|
|
638
|
+
else if (typeof v === 'string')
|
|
639
|
+
colType = types_1.PropertyType.STRING;
|
|
640
|
+
else if (typeof v === 'boolean')
|
|
641
|
+
colType = types_1.PropertyType.BOOL;
|
|
642
|
+
}
|
|
643
|
+
return { name: col, type: colType };
|
|
644
|
+
});
|
|
645
|
+
return { name: this.columns[0], headers, rows: gt.rows };
|
|
646
|
+
}
|
|
647
|
+
}
|
|
648
|
+
}
|
|
649
|
+
// Fallback: generic multi-column table
|
|
650
|
+
const headers = this.columns.map(col => ({
|
|
651
|
+
name: col,
|
|
652
|
+
type: types_1.PropertyType.UNSET,
|
|
653
|
+
}));
|
|
654
|
+
const tableRows = this.rows.map(row => {
|
|
655
|
+
return this.columns.map((_, i) => (i < row.values.length ? row.get(i) : null));
|
|
656
|
+
});
|
|
657
|
+
return { name: '', headers, rows: tableRows };
|
|
658
|
+
}
|
|
659
|
+
/**
|
|
660
|
+
* @deprecated Use alias() or get() instead. This method will be removed in a future version.
|
|
661
|
+
* Extract scalar or list attribute values
|
|
662
|
+
*/
|
|
663
|
+
asAttr(columnName) {
|
|
664
|
+
const colIndex = this.columns.indexOf(columnName);
|
|
665
|
+
if (colIndex === -1) {
|
|
666
|
+
throw new Error(`Column not found: ${columnName}`);
|
|
667
|
+
}
|
|
668
|
+
const values = [];
|
|
669
|
+
let attrType = types_1.PropertyType.UNSET;
|
|
670
|
+
for (const row of this.rows) {
|
|
671
|
+
if (colIndex < row.values.length) {
|
|
672
|
+
// Try to get type from row.types first, then from TypedValue object
|
|
673
|
+
if (attrType === types_1.PropertyType.UNSET) {
|
|
674
|
+
attrType = row.getType(colIndex);
|
|
675
|
+
if (attrType === types_1.PropertyType.UNSET) {
|
|
676
|
+
const rawValue = row.values[colIndex];
|
|
677
|
+
if (rawValue && typeof rawValue === 'object' && 'type' in rawValue) {
|
|
678
|
+
attrType = rawValue.type;
|
|
679
|
+
}
|
|
680
|
+
}
|
|
681
|
+
}
|
|
682
|
+
const value = row.get(colIndex); // Use get() to convert TypedValue
|
|
683
|
+
values.push(value);
|
|
684
|
+
}
|
|
685
|
+
}
|
|
686
|
+
return { name: columnName, type: attrType, values };
|
|
687
|
+
}
|
|
688
|
+
// Helper methods
|
|
689
|
+
buildSchemaFromNode(label, node) {
|
|
690
|
+
const properties = Object.entries(node.properties).map(([name, value]) => ({
|
|
691
|
+
name,
|
|
692
|
+
type: this.inferPropertyType(value),
|
|
693
|
+
}));
|
|
694
|
+
return { name: label, properties };
|
|
695
|
+
}
|
|
696
|
+
buildSchemaFromEdge(label, edge) {
|
|
697
|
+
const properties = Object.entries(edge.properties).map(([name, value]) => ({
|
|
698
|
+
name,
|
|
699
|
+
type: this.inferPropertyType(value),
|
|
700
|
+
}));
|
|
701
|
+
return { name: label, properties };
|
|
702
|
+
}
|
|
703
|
+
inferPropertyType(value) {
|
|
704
|
+
if (value === null || value === undefined)
|
|
705
|
+
return types_1.PropertyType.NULL;
|
|
706
|
+
if (typeof value === 'boolean')
|
|
707
|
+
return types_1.PropertyType.BOOL;
|
|
708
|
+
if (typeof value === 'number') {
|
|
709
|
+
return Number.isInteger(value) ? types_1.PropertyType.INT64 : types_1.PropertyType.DOUBLE;
|
|
710
|
+
}
|
|
711
|
+
if (typeof value === 'string')
|
|
712
|
+
return types_1.PropertyType.STRING;
|
|
713
|
+
if (Buffer.isBuffer(value))
|
|
714
|
+
return types_1.PropertyType.BLOB;
|
|
715
|
+
if (Array.isArray(value))
|
|
716
|
+
return types_1.PropertyType.LIST;
|
|
717
|
+
if (typeof value === 'object')
|
|
718
|
+
return types_1.PropertyType.MAP;
|
|
719
|
+
return types_1.PropertyType.UNSET;
|
|
720
|
+
}
|
|
721
|
+
}
|
|
722
|
+
exports.Response = Response;
|
|
723
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"response.js","sourceRoot":"","sources":["../src/response.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Response handling for GQLDB Node.js driver.\r\n */\r\n\r\nimport { TypedValue, typedValueToJS, PropertyType, Schema, PropertyDef, Table, Header, Attr, GqldbNode, GqldbEdge, GqldbPath } from './types';\r\n\r\n/** Represents a single row in the query result */\r\nexport class Row {\r\n  constructor(\r\n    public readonly values: any[],\r\n    public readonly types: PropertyType[] = []\r\n  ) {}\r\n\r\n  /** Get the value at the given column index */\r\n  get(index: number): any {\r\n    if (index < 0 || index >= this.values.length) {\r\n      throw new Error(`Column index out of range: ${index}`);\r\n    }\r\n    const value = this.values[index];\r\n    // If value is a TypedValue object, convert it\r\n    if (value && typeof value === 'object' && 'type' in value && 'data' in value && 'isNull' in value) {\r\n      return typedValueToJS(value as TypedValue);\r\n    }\r\n    return value;\r\n  }\r\n\r\n  /** Get the PropertyType at the given column index */\r\n  getType(index: number): PropertyType {\r\n    if (index < 0 || index >= this.types.length) {\r\n      return PropertyType.UNSET;\r\n    }\r\n    return this.types[index];\r\n  }\r\n\r\n  /** Get the value at the given column index as a string */\r\n  getString(index: number): string {\r\n    const val = this.get(index);\r\n    if (val === null || val === undefined) return '';\r\n    if (typeof val === 'string') return val;\r\n    return String(val);\r\n  }\r\n\r\n  /** Get the value at the given column index as a number */\r\n  getNumber(index: number): number {\r\n    const val = this.get(index);\r\n    if (val === null || val === undefined) return 0;\r\n    if (typeof val === 'number') return val;\r\n    const num = Number(val);\r\n    if (isNaN(num)) throw new Error(`Cannot convert ${typeof val} to number`);\r\n    return num;\r\n  }\r\n\r\n  /** Get the value at the given column index as a boolean */\r\n  getBoolean(index: number): boolean {\r\n    const val = this.get(index);\r\n    if (val === null || val === undefined) return false;\r\n    if (typeof val === 'boolean') return val;\r\n    throw new Error(`Cannot convert ${typeof val} to boolean`);\r\n  }\r\n}\r\n\r\n/**\r\n * Represents a single column's data from the response.\r\n * Allows chaining operations like resp.alias(\"n\").asNodes() or resp.get(0).asNodes().\r\n */\r\nexport class AliasResult {\r\n  constructor(\r\n    private readonly aliasName: string,\r\n    private readonly columnIdx: number,\r\n    private readonly response: Response\r\n  ) {}\r\n\r\n  /** Get the alias name */\r\n  get alias(): string {\r\n    return this.aliasName;\r\n  }\r\n\r\n  /** Get the column index */\r\n  get columnIndex(): number {\r\n    return this.columnIdx;\r\n  }\r\n\r\n  /**\r\n   * Extract nodes from the aliased column with schema info.\r\n   * Throws TypeError if the column contains non-NODE types.\r\n   */\r\n  private collectNode(val: any, nodes: Node[], schemas: Map<string, Schema>): void {\r\n    if (val && typeof val.id === 'string' && 'labels' in val) {\r\n      const node: Node = {\r\n        id: val.id,\r\n        labels: val.labels || [],\r\n        properties: val.properties || {},\r\n      };\r\n      nodes.push(node);\r\n      for (const label of node.labels) {\r\n        if (!schemas.has(label)) {\r\n          schemas.set(label, this.buildSchemaFromNode(label, node));\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private collectEdge(val: any, edges: Edge[], schemas: Map<string, Schema>): void {\r\n    if (val && typeof val.id === 'string' && 'label' in val) {\r\n      const edge: Edge = {\r\n        id: val.id,\r\n        label: val.label || '',\r\n        fromNodeId: val.fromNodeId || '',\r\n        toNodeId: val.toNodeId || '',\r\n        properties: val.properties || {},\r\n      };\r\n      edges.push(edge);\r\n      if (edge.label && !schemas.has(edge.label)) {\r\n        schemas.set(edge.label, this.buildSchemaFromEdge(edge.label, edge));\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Extract nodes from the aliased column with schema info.\r\n   * Supports both direct NODE columns and LIST of NODE columns\r\n   * (e.g., group variables from quantified patterns).\r\n   */\r\n  asNodes(): NodeResult {\r\n    const nodes: Node[] = [];\r\n    const schemas = new Map<string, Schema>();\r\n\r\n    for (const row of this.response.rows) {\r\n      if (this.columnIdx >= row.values.length) {\r\n        continue;\r\n      }\r\n\r\n      let itemType = row.getType(this.columnIdx);\r\n      const rawValue = row.values[this.columnIdx];\r\n      if (itemType === PropertyType.UNSET && rawValue && typeof rawValue === 'object' && 'type' in rawValue) {\r\n        itemType = rawValue.type;\r\n      }\r\n\r\n      if (!rawValue || (typeof rawValue === 'object' && 'isNull' in rawValue && rawValue.isNull)) {\r\n        continue;\r\n      }\r\n\r\n      if (itemType === PropertyType.NODE) {\r\n        this.collectNode(row.get(this.columnIdx), nodes, schemas);\r\n      } else if (itemType === PropertyType.LIST) {\r\n        // LIST of NODE (group variable from quantified pattern)\r\n        const list = row.get(this.columnIdx);\r\n        if (Array.isArray(list)) {\r\n          for (const item of list) {\r\n            this.collectNode(item, nodes, schemas);\r\n          }\r\n        }\r\n      } else {\r\n        throw new TypeError(\r\n          `Type mismatch: column '${this.aliasName}' (index ${this.columnIdx}) contains ${PropertyType[itemType]}, expected NODE or LIST of NODE`\r\n        );\r\n      }\r\n    }\r\n\r\n    return { nodes, schemas };\r\n  }\r\n\r\n  /**\r\n   * Extract edges from the aliased column with schema info.\r\n   * Supports both direct EDGE columns and LIST of EDGE columns\r\n   * (e.g., group variables from quantified patterns).\r\n   */\r\n  asEdges(): EdgeResult {\r\n    const edges: Edge[] = [];\r\n    const schemas = new Map<string, Schema>();\r\n\r\n    for (const row of this.response.rows) {\r\n      if (this.columnIdx >= row.values.length) {\r\n        continue;\r\n      }\r\n\r\n      let itemType = row.getType(this.columnIdx);\r\n      const rawValue = row.values[this.columnIdx];\r\n      if (itemType === PropertyType.UNSET && rawValue && typeof rawValue === 'object' && 'type' in rawValue) {\r\n        itemType = rawValue.type;\r\n      }\r\n\r\n      if (!rawValue || (typeof rawValue === 'object' && 'isNull' in rawValue && rawValue.isNull)) {\r\n        continue;\r\n      }\r\n\r\n      if (itemType === PropertyType.EDGE) {\r\n        this.collectEdge(row.get(this.columnIdx), edges, schemas);\r\n      } else if (itemType === PropertyType.LIST) {\r\n        // LIST of EDGE (group variable from quantified pattern)\r\n        const list = row.get(this.columnIdx);\r\n        if (Array.isArray(list)) {\r\n          for (const item of list) {\r\n            this.collectEdge(item, edges, schemas);\r\n          }\r\n        }\r\n      } else {\r\n        throw new TypeError(\r\n          `Type mismatch: column '${this.aliasName}' (index ${this.columnIdx}) contains ${PropertyType[itemType]}, expected EDGE or LIST of EDGE`\r\n        );\r\n      }\r\n    }\r\n\r\n    return { edges, schemas };\r\n  }\r\n\r\n  /**\r\n   * Extract paths from the aliased column.\r\n   * Throws TypeError if the column contains non-PATH types.\r\n   */\r\n  asPaths(): Path[] {\r\n    const paths: Path[] = [];\r\n\r\n    for (const row of this.response.rows) {\r\n      if (this.columnIdx >= row.values.length) {\r\n        continue;\r\n      }\r\n\r\n      // Check type from types array or from TypedValue object\r\n      let itemType = row.getType(this.columnIdx);\r\n      const rawValue = row.values[this.columnIdx];\r\n      if (itemType === PropertyType.UNSET && rawValue && typeof rawValue === 'object' && 'type' in rawValue) {\r\n        itemType = rawValue.type;\r\n      }\r\n\r\n      // Skip null values\r\n      if (!rawValue || (typeof rawValue === 'object' && 'isNull' in rawValue && rawValue.isNull)) {\r\n        continue;\r\n      }\r\n\r\n      // Type checking: must be PATH type\r\n      if (itemType !== PropertyType.PATH) {\r\n        throw new TypeError(\r\n          `Type mismatch: column '${this.aliasName}' (index ${this.columnIdx}) contains ${PropertyType[itemType]}, expected PATH`\r\n        );\r\n      }\r\n\r\n      // Convert TypedValue to GqldbPath\r\n      const val = row.get(this.columnIdx) as GqldbPath;\r\n      if (val && Array.isArray(val.nodes)) {\r\n        // Convert GqldbNode/GqldbEdge to Node/Edge\r\n        const nodes: Node[] = (val.nodes || []).map((n: GqldbNode) => ({\r\n          id: n.id || '',\r\n          labels: n.labels || [],\r\n          properties: n.properties || {},\r\n        }));\r\n        const edges: Edge[] = (val.edges || []).map((e: GqldbEdge) => ({\r\n          id: e.id || '',\r\n          label: e.label || '',\r\n          fromNodeId: e.fromNodeId || '',\r\n          toNodeId: e.toNodeId || '',\r\n          properties: e.properties || {},\r\n        }));\r\n        paths.push({ nodes, edges });\r\n      }\r\n    }\r\n\r\n    return paths;\r\n  }\r\n\r\n  /** Convert the aliased column to a single-column table */\r\n  asTable(): Table {\r\n    // Check if first non-null value is a GqldbTable — if so, unwrap it\r\n    for (const row of this.response.rows) {\r\n      if (this.columnIdx < row.values.length) {\r\n        const itemType = row.getType(this.columnIdx);\r\n        if (itemType === PropertyType.TABLE) {\r\n          const val = row.get(this.columnIdx) as any;\r\n          if (val && 'columns' in val && 'rows' in val) {\r\n            return this.unwrapGqldbTable(val);\r\n          }\r\n        }\r\n      }\r\n      break; // only check first row\r\n    }\r\n\r\n    // Fallback: generic single-column table\r\n    const headers: Header[] = [{\r\n      name: this.aliasName,\r\n      type: PropertyType.UNSET,\r\n    }];\r\n\r\n    if (this.response.rows.length > 0) {\r\n      for (const row of this.response.rows) {\r\n        if (this.columnIdx < row.values.length) {\r\n          const type = row.getType(this.columnIdx);\r\n          if (type !== PropertyType.UNSET) {\r\n            headers[0].type = type;\r\n            break;\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n    const tableRows: any[][] = this.response.rows.map(row => {\r\n      if (this.columnIdx < row.values.length) {\r\n        return [row.get(this.columnIdx)];\r\n      }\r\n      return [null];\r\n    });\r\n\r\n    return { name: '', headers, rows: tableRows };\r\n  }\r\n\r\n  private unwrapGqldbTable(gt: { columns: string[]; rows: any[][] }): Table {\r\n    const headers: Header[] = gt.columns.map((col, i) => {\r\n      let colType = PropertyType.UNSET;\r\n      if (gt.rows.length > 0 && i < gt.rows[0].length) {\r\n        const v = gt.rows[0][i];\r\n        if (typeof v === 'number') colType = Number.isInteger(v) ? PropertyType.INT64 : PropertyType.DOUBLE;\r\n        else if (typeof v === 'string') colType = PropertyType.STRING;\r\n        else if (typeof v === 'boolean') colType = PropertyType.BOOL;\r\n      }\r\n      return { name: col, type: colType };\r\n    });\r\n    return { name: this.aliasName, headers, rows: gt.rows };\r\n  }\r\n\r\n  /** Extract scalar or list attribute values from the aliased column */\r\n  asAttr(): Attr {\r\n    const values: any[] = [];\r\n    let attrType = PropertyType.UNSET;\r\n\r\n    for (const row of this.response.rows) {\r\n      if (this.columnIdx < row.values.length) {\r\n        // Try to get type from row.types first, then from TypedValue object\r\n        if (attrType === PropertyType.UNSET) {\r\n          attrType = row.getType(this.columnIdx);\r\n          if (attrType === PropertyType.UNSET) {\r\n            const rawValue = row.values[this.columnIdx];\r\n            if (rawValue && typeof rawValue === 'object' && 'type' in rawValue) {\r\n              attrType = rawValue.type;\r\n            }\r\n          }\r\n        }\r\n        const value = row.get(this.columnIdx);  // Use get() to convert TypedValue\r\n        values.push(value);\r\n      }\r\n    }\r\n\r\n    return { name: this.aliasName, type: attrType, values };\r\n  }\r\n\r\n  /** Extract raw JavaScript values from the aliased column */\r\n  asValues(): any[] {\r\n    const values: any[] = [];\r\n\r\n    for (const row of this.response.rows) {\r\n      if (this.columnIdx < row.values.length) {\r\n        values.push(row.get(this.columnIdx));\r\n      }\r\n    }\r\n\r\n    return values;\r\n  }\r\n\r\n  // Helper methods\r\n\r\n  private buildSchemaFromNode(label: string, node: Node): Schema {\r\n    const properties: PropertyDef[] = Object.entries(node.properties).map(([name, value]) => ({\r\n      name,\r\n      type: this.inferPropertyType(value),\r\n    }));\r\n    return { name: label, properties };\r\n  }\r\n\r\n  private buildSchemaFromEdge(label: string, edge: Edge): Schema {\r\n    const properties: PropertyDef[] = Object.entries(edge.properties).map(([name, value]) => ({\r\n      name,\r\n      type: this.inferPropertyType(value),\r\n    }));\r\n    return { name: label, properties };\r\n  }\r\n\r\n  private inferPropertyType(value: any): PropertyType {\r\n    if (value === null || value === undefined) return PropertyType.NULL;\r\n    if (typeof value === 'boolean') return PropertyType.BOOL;\r\n    if (typeof value === 'number') {\r\n      return Number.isInteger(value) ? PropertyType.INT64 : PropertyType.DOUBLE;\r\n    }\r\n    if (typeof value === 'string') return PropertyType.STRING;\r\n    if (Buffer.isBuffer(value)) return PropertyType.BLOB;\r\n    if (Array.isArray(value)) return PropertyType.LIST;\r\n    if (typeof value === 'object') return PropertyType.MAP;\r\n    return PropertyType.UNSET;\r\n  }\r\n}\r\n\r\n/** Represents the result of a GQL query */\r\nexport class Response {\r\n  constructor(\r\n    public readonly columns: string[],\r\n    public readonly rows: Row[],\r\n    public readonly rowCount: number,\r\n    public readonly hasMore: boolean,\r\n    public readonly warnings: string[],\r\n    public readonly rowsAffected: number = 0\r\n  ) {}\r\n\r\n  /** Check if the response has no rows */\r\n  isEmpty(): boolean {\r\n    return this.rows.length === 0;\r\n  }\r\n\r\n  /** Get the first row */\r\n  first(): Row | undefined {\r\n    return this.rows[0];\r\n  }\r\n\r\n  /** Get the last row */\r\n  last(): Row | undefined {\r\n    return this.rows[this.rows.length - 1];\r\n  }\r\n\r\n  /** Get the value for a column by name */\r\n  getByName(row: Row, columnName: string): any {\r\n    const index = this.columns.indexOf(columnName);\r\n    if (index === -1) {\r\n      throw new Error(`Column not found: ${columnName}`);\r\n    }\r\n    return row.get(index);\r\n  }\r\n\r\n  /** Iterate over all rows with a callback */\r\n  forEach(fn: (row: Row, index: number) => void): void {\r\n    this.rows.forEach(fn);\r\n  }\r\n\r\n  /** Transform each row using a callback */\r\n  map<T>(fn: (row: Row) => T): T[] {\r\n    return this.rows.map(fn);\r\n  }\r\n\r\n  /** Convert the response to an array of objects */\r\n  toObjects(): Record<string, any>[] {\r\n    return this.rows.map(row => {\r\n      const obj: Record<string, any> = {};\r\n      this.columns.forEach((col, i) => {\r\n        // Add boundary check to handle mismatched columns/values\r\n        obj[col] = i < row.values.length ? row.get(i) : null;\r\n      });\r\n      return obj;\r\n    });\r\n  }\r\n\r\n  /** Convert the response to JSON */\r\n  toJSON(): string {\r\n    return JSON.stringify(this.toObjects());\r\n  }\r\n\r\n  /** Get the single value from a single-row, single-column response */\r\n  singleValue(): any {\r\n    if (this.rows.length === 0) return null;\r\n    if (this.rows.length > 1) {\r\n      throw new Error(`Expected single row, got ${this.rows.length}`);\r\n    }\r\n    if (this.rows[0].values.length === 0) return null;\r\n    if (this.rows[0].values.length > 1) {\r\n      throw new Error(`Expected single column, got ${this.rows[0].values.length}`);\r\n    }\r\n    return this.rows[0].get(0);\r\n  }\r\n\r\n  /** Get the single number value */\r\n  singleNumber(): number {\r\n    const val = this.singleValue();\r\n    if (val === null || val === undefined) return 0;\r\n    if (typeof val === 'number') return val;\r\n    const num = Number(val);\r\n    if (isNaN(num)) throw new Error(`Cannot convert ${typeof val} to number`);\r\n    return num;\r\n  }\r\n\r\n  /** Get the single string value */\r\n  singleString(): string {\r\n    const val = this.singleValue();\r\n    if (val === null || val === undefined) return '';\r\n    if (typeof val === 'string') return val;\r\n    return String(val);\r\n  }\r\n\r\n  /** Iterator support */\r\n  [Symbol.iterator](): Iterator<Row> {\r\n    return this.rows[Symbol.iterator]();\r\n  }\r\n\r\n  /** Get the number of rows */\r\n  get length(): number {\r\n    return this.rows.length;\r\n  }\r\n\r\n  /**\r\n   * Get an AliasResult for the specified column name.\r\n   * Use this to extract data from a specific column by name.\r\n   * Example: resp.alias(\"n\").asNodes()\r\n   */\r\n  alias(columnName: string): AliasResult {\r\n    const colIdx = this.columns.indexOf(columnName);\r\n    if (colIdx === -1) {\r\n      throw new Error(`Column alias not found: ${columnName}`);\r\n    }\r\n    return new AliasResult(columnName, colIdx, this);\r\n  }\r\n\r\n  /**\r\n   * Get an AliasResult for the column at the specified index.\r\n   * Use this to extract data from a specific column by index.\r\n   * Example: resp.get(0).asNodes()\r\n   */\r\n  get(index: number): AliasResult {\r\n    if (index < 0 || index >= this.columns.length) {\r\n      throw new Error(`Column index out of range: ${index} (total: ${this.columns.length})`);\r\n    }\r\n    return new AliasResult(this.columns[index], index, this);\r\n  }\r\n\r\n  /**\r\n   * @deprecated Use alias() or get() instead. This method will be removed in a future version.\r\n   * Extract nodes from response with schema info.\r\n   * Supports both NODE and LIST of NODE columns.\r\n   */\r\n  asNodes(): NodeResult {\r\n    const nodes: Node[] = [];\r\n    const schemas = new Map<string, Schema>();\r\n\r\n    const collectNode = (val: any) => {\r\n      if (val && typeof val.id === 'string' && 'labels' in val) {\r\n        const node: Node = {\r\n          id: val.id,\r\n          labels: val.labels || [],\r\n          properties: val.properties || {},\r\n        };\r\n        nodes.push(node);\r\n        for (const label of node.labels) {\r\n          if (!schemas.has(label)) {\r\n            schemas.set(label, this.buildSchemaFromNode(label, node));\r\n          }\r\n        }\r\n      }\r\n    };\r\n\r\n    for (const row of this.rows) {\r\n      for (let i = 0; i < row.values.length; i++) {\r\n        let itemType = row.getType(i);\r\n        const rawValue = row.values[i];\r\n        if (itemType === PropertyType.UNSET && rawValue && typeof rawValue === 'object' && 'type' in rawValue) {\r\n          itemType = rawValue.type;\r\n        }\r\n\r\n        if (itemType === PropertyType.NODE) {\r\n          collectNode(row.get(i));\r\n        } else if (itemType === PropertyType.LIST) {\r\n          const list = row.get(i);\r\n          if (Array.isArray(list)) {\r\n            for (const item of list) {\r\n              collectNode(item);\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n    return { nodes, schemas };\r\n  }\r\n\r\n  /**\r\n   * @deprecated Use alias() or get() instead. This method will be removed in a future version.\r\n   * Extract edges from response with schema info.\r\n   * Supports both EDGE and LIST of EDGE columns.\r\n   */\r\n  asEdges(): EdgeResult {\r\n    const edges: Edge[] = [];\r\n    const schemas = new Map<string, Schema>();\r\n\r\n    const collectEdge = (val: any) => {\r\n      if (val && typeof val.id === 'string' && 'label' in val) {\r\n        const edge: Edge = {\r\n          id: val.id,\r\n          label: val.label || '',\r\n          fromNodeId: val.fromNodeId || '',\r\n          toNodeId: val.toNodeId || '',\r\n          properties: val.properties || {},\r\n        };\r\n        edges.push(edge);\r\n        if (edge.label && !schemas.has(edge.label)) {\r\n          schemas.set(edge.label, this.buildSchemaFromEdge(edge.label, edge));\r\n        }\r\n      }\r\n    };\r\n\r\n    for (const row of this.rows) {\r\n      for (let i = 0; i < row.values.length; i++) {\r\n        let itemType = row.getType(i);\r\n        const rawValue = row.values[i];\r\n        if (itemType === PropertyType.UNSET && rawValue && typeof rawValue === 'object' && 'type' in rawValue) {\r\n          itemType = rawValue.type;\r\n        }\r\n\r\n        if (itemType === PropertyType.EDGE) {\r\n          collectEdge(row.get(i));\r\n        } else if (itemType === PropertyType.LIST) {\r\n          const list = row.get(i);\r\n          if (Array.isArray(list)) {\r\n            for (const item of list) {\r\n              collectEdge(item);\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n    return { edges, schemas };\r\n  }\r\n\r\n  /**\r\n   * @deprecated Use alias() or get() instead. This method will be removed in a future version.\r\n   * Extract paths from response.\r\n   * Paths are identified by PropertyType.PATH type in the TypedValue.\r\n   */\r\n  asPaths(): Path[] {\r\n    const paths: Path[] = [];\r\n\r\n    for (const row of this.rows) {\r\n      for (let i = 0; i < row.values.length; i++) {\r\n        // Check type from types array or from TypedValue object\r\n        let itemType = row.getType(i);\r\n        const rawValue = row.values[i];\r\n        if (itemType === PropertyType.UNSET && rawValue && typeof rawValue === 'object' && 'type' in rawValue) {\r\n          itemType = rawValue.type;\r\n        }\r\n\r\n        if (itemType === PropertyType.PATH) {\r\n          // Convert TypedValue to GqldbPath\r\n          const val = row.get(i) as GqldbPath;\r\n          if (val && Array.isArray(val.nodes)) {\r\n            // Convert GqldbNode/GqldbEdge to Node/Edge\r\n            const nodes: Node[] = (val.nodes || []).map((n: GqldbNode) => ({\r\n              id: n.id || '',\r\n              labels: n.labels || [],\r\n              properties: n.properties || {},\r\n            }));\r\n            const edges: Edge[] = (val.edges || []).map((e: GqldbEdge) => ({\r\n              id: e.id || '',\r\n              label: e.label || '',\r\n              fromNodeId: e.fromNodeId || '',\r\n              toNodeId: e.toNodeId || '',\r\n              properties: e.properties || {},\r\n            }));\r\n            paths.push({ nodes, edges });\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n    return paths;\r\n  }\r\n\r\n  /**\r\n   * @deprecated Use alias() or get() instead. This method will be removed in a future version.\r\n   * Return response as generic table.\r\n   * If response is a single TABLE column, unwraps the GqldbTable into proper headers/rows.\r\n   */\r\n  asTable(): Table {\r\n    // If single column of TABLE type, unwrap GqldbTable\r\n    if (this.columns.length === 1 && this.rows.length > 0) {\r\n      const itemType = this.rows[0].getType(0);\r\n      if (itemType === PropertyType.TABLE) {\r\n        const val = this.rows[0].get(0) as any;\r\n        if (val && 'columns' in val && 'rows' in val) {\r\n          const gt = val as { columns: string[]; rows: any[][] };\r\n          const headers: Header[] = gt.columns.map((col: string, i: number) => {\r\n            let colType = PropertyType.UNSET;\r\n            if (gt.rows.length > 0 && i < gt.rows[0].length) {\r\n              const v = gt.rows[0][i];\r\n              if (typeof v === 'number') colType = Number.isInteger(v) ? PropertyType.INT64 : PropertyType.DOUBLE;\r\n              else if (typeof v === 'string') colType = PropertyType.STRING;\r\n              else if (typeof v === 'boolean') colType = PropertyType.BOOL;\r\n            }\r\n            return { name: col, type: colType };\r\n          });\r\n          return { name: this.columns[0], headers, rows: gt.rows };\r\n        }\r\n      }\r\n    }\r\n\r\n    // Fallback: generic multi-column table\r\n    const headers: Header[] = this.columns.map(col => ({\r\n      name: col,\r\n      type: PropertyType.UNSET,\r\n    }));\r\n\r\n    const tableRows: any[][] = this.rows.map(row => {\r\n      return this.columns.map((_, i) => (i < row.values.length ? row.get(i) : null));\r\n    });\r\n\r\n    return { name: '', headers, rows: tableRows };\r\n  }\r\n\r\n  /**\r\n   * @deprecated Use alias() or get() instead. This method will be removed in a future version.\r\n   * Extract scalar or list attribute values\r\n   */\r\n  asAttr(columnName: string): Attr {\r\n    const colIndex = this.columns.indexOf(columnName);\r\n    if (colIndex === -1) {\r\n      throw new Error(`Column not found: ${columnName}`);\r\n    }\r\n\r\n    const values: any[] = [];\r\n    let attrType = PropertyType.UNSET;\r\n\r\n    for (const row of this.rows) {\r\n      if (colIndex < row.values.length) {\r\n        // Try to get type from row.types first, then from TypedValue object\r\n        if (attrType === PropertyType.UNSET) {\r\n          attrType = row.getType(colIndex);\r\n          if (attrType === PropertyType.UNSET) {\r\n            const rawValue = row.values[colIndex];\r\n            if (rawValue && typeof rawValue === 'object' && 'type' in rawValue) {\r\n              attrType = rawValue.type;\r\n            }\r\n          }\r\n        }\r\n        const value = row.get(colIndex);  // Use get() to convert TypedValue\r\n        values.push(value);\r\n      }\r\n    }\r\n\r\n    return { name: columnName, type: attrType, values };\r\n  }\r\n\r\n  // Helper methods\r\n\r\n  private buildSchemaFromNode(label: string, node: Node): Schema {\r\n    const properties: PropertyDef[] = Object.entries(node.properties).map(([name, value]) => ({\r\n      name,\r\n      type: this.inferPropertyType(value),\r\n    }));\r\n    return { name: label, properties };\r\n  }\r\n\r\n  private buildSchemaFromEdge(label: string, edge: Edge): Schema {\r\n    const properties: PropertyDef[] = Object.entries(edge.properties).map(([name, value]) => ({\r\n      name,\r\n      type: this.inferPropertyType(value),\r\n    }));\r\n    return { name: label, properties };\r\n  }\r\n\r\n  private inferPropertyType(value: any): PropertyType {\r\n    if (value === null || value === undefined) return PropertyType.NULL;\r\n    if (typeof value === 'boolean') return PropertyType.BOOL;\r\n    if (typeof value === 'number') {\r\n      return Number.isInteger(value) ? PropertyType.INT64 : PropertyType.DOUBLE;\r\n    }\r\n    if (typeof value === 'string') return PropertyType.STRING;\r\n    if (Buffer.isBuffer(value)) return PropertyType.BLOB;\r\n    if (Array.isArray(value)) return PropertyType.LIST;\r\n    if (typeof value === 'object') return PropertyType.MAP;\r\n    return PropertyType.UNSET;\r\n  }\r\n}\r\n\r\n/** Result of an insert nodes operation */\r\nexport interface InsertNodesResult {\r\n  success: boolean;\r\n  nodeIds: string[];\r\n  nodeCount: number;\r\n  message: string;\r\n}\r\n\r\n/** Result of an insert edges operation */\r\nexport interface InsertEdgesResult {\r\n  success: boolean;\r\n  edgeIds: string[];\r\n  edgeCount: number;\r\n  message: string;\r\n  skippedCount: number;\r\n}\r\n\r\n/** Result of a delete operation */\r\nexport interface DeleteResult {\r\n  success: boolean;\r\n  deletedCount: number;\r\n  message: string;\r\n}\r\n\r\n/** Configuration for the unified Export operation */\r\nexport interface ExportConfig {\r\n  graphName: string;\r\n  batchSize?: number;\r\n  exportNodes?: boolean;\r\n  exportEdges?: boolean;\r\n  nodeLabels?: string[];\r\n  edgeLabels?: string[];\r\n  includeMetadata?: boolean;\r\n}\r\n\r\n/** Statistics for an export operation */\r\nexport interface ExportStats {\r\n  nodesExported: number;\r\n  edgesExported: number;\r\n  bytesWritten: number;\r\n  durationMs: number;\r\n}\r\n\r\n/** A chunk of exported data in JSON Lines format */\r\nexport interface ExportChunk {\r\n  data: Buffer;\r\n  isFinal: boolean;\r\n  stats?: ExportStats;\r\n}\r\n\r\n/**\r\n * A batch of exported nodes\r\n * @deprecated Use export() with ExportConfig instead\r\n */\r\nexport interface ExportNodesResult {\r\n  nodes: ExportedNode[];\r\n  hasMore: boolean;\r\n}\r\n\r\n/**\r\n * A batch of exported edges\r\n * @deprecated Use export() with ExportConfig instead\r\n */\r\nexport interface ExportEdgesResult {\r\n  edges: ExportedEdge[];\r\n  hasMore: boolean;\r\n}\r\n\r\n/**\r\n * A node exported from the database\r\n * @deprecated Use export() with ExportConfig instead\r\n */\r\nexport interface ExportedNode {\r\n  id: string;\r\n  labels: string[];\r\n  properties: Record<string, any>;\r\n}\r\n\r\n/**\r\n * An edge exported from the database\r\n * @deprecated Use export() with ExportConfig instead\r\n */\r\nexport interface ExportedEdge {\r\n  id: string;\r\n  label: string;\r\n  fromNodeId: string;\r\n  toNodeId: string;\r\n  properties: Record<string, any>;\r\n}\r\n\r\n/** Represents a node in the graph database */\r\nexport interface Node {\r\n  id: string;\r\n  labels: string[];\r\n  properties: Record<string, any>;\r\n}\r\n\r\n/** Represents an edge in the graph database */\r\nexport interface Edge {\r\n  id: string;\r\n  label: string;\r\n  fromNodeId: string;\r\n  toNodeId: string;\r\n  properties: Record<string, any>;\r\n}\r\n\r\n/** Represents a path in the graph database */\r\nexport interface Path {\r\n  nodes: Node[];\r\n  edges: Edge[];\r\n}\r\n\r\n/** Result wrapper for nodes with schema information */\r\nexport interface NodeResult {\r\n  nodes: Node[];\r\n  schemas: Map<string, Schema>;\r\n}\r\n\r\n/** Result wrapper for edges with schema information */\r\nexport interface EdgeResult {\r\n  edges: Edge[];\r\n  schemas: Map<string, Schema>;\r\n}\r\n"]}
|