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.
Files changed (66) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +65 -0
  3. package/dist/client.d.ts +194 -0
  4. package/dist/client.js +390 -0
  5. package/dist/config.d.ts +65 -0
  6. package/dist/config.js +135 -0
  7. package/dist/connection.d.ts +30 -0
  8. package/dist/connection.js +190 -0
  9. package/dist/errors.d.ts +99 -0
  10. package/dist/errors.js +237 -0
  11. package/dist/index.d.ts +14 -0
  12. package/dist/index.js +88 -0
  13. package/dist/printers.d.ts +33 -0
  14. package/dist/printers.js +312 -0
  15. package/dist/proto/gqldb.proto +632 -0
  16. package/dist/response.d.ts +256 -0
  17. package/dist/response.js +723 -0
  18. package/dist/services/admin-service.d.ts +40 -0
  19. package/dist/services/admin-service.js +115 -0
  20. package/dist/services/bulk-import-service.d.ts +35 -0
  21. package/dist/services/bulk-import-service.js +108 -0
  22. package/dist/services/converters.d.ts +57 -0
  23. package/dist/services/converters.js +254 -0
  24. package/dist/services/data-service.d.ts +44 -0
  25. package/dist/services/data-service.js +206 -0
  26. package/dist/services/graph-service.d.ts +32 -0
  27. package/dist/services/graph-service.js +127 -0
  28. package/dist/services/health-service.d.ts +50 -0
  29. package/dist/services/health-service.js +78 -0
  30. package/dist/services/index.d.ts +13 -0
  31. package/dist/services/index.js +30 -0
  32. package/dist/services/query-service.d.ts +39 -0
  33. package/dist/services/query-service.js +112 -0
  34. package/dist/services/service-context.d.ts +39 -0
  35. package/dist/services/service-context.js +73 -0
  36. package/dist/services/session-service.d.ts +24 -0
  37. package/dist/services/session-service.js +66 -0
  38. package/dist/services/transaction-service.d.ts +33 -0
  39. package/dist/services/transaction-service.js +100 -0
  40. package/dist/services.d.ts +28 -0
  41. package/dist/services.js +122 -0
  42. package/dist/session.d.ts +45 -0
  43. package/dist/session.js +75 -0
  44. package/dist/transaction.d.ts +42 -0
  45. package/dist/transaction.js +89 -0
  46. package/dist/types/bulk_import.d.ts +53 -0
  47. package/dist/types/bulk_import.js +6 -0
  48. package/dist/types/data_types.d.ts +116 -0
  49. package/dist/types/data_types.js +122 -0
  50. package/dist/types/enums.d.ts +59 -0
  51. package/dist/types/enums.js +67 -0
  52. package/dist/types/graph_models.d.ts +54 -0
  53. package/dist/types/graph_models.js +6 -0
  54. package/dist/types/index.d.ts +11 -0
  55. package/dist/types/index.js +36 -0
  56. package/dist/types/metadata.d.ts +60 -0
  57. package/dist/types/metadata.js +6 -0
  58. package/dist/types/schema.d.ts +31 -0
  59. package/dist/types/schema.js +6 -0
  60. package/dist/types/typed_value.d.ts +25 -0
  61. package/dist/types/typed_value.js +1176 -0
  62. package/dist/types/wrappers.d.ts +23 -0
  63. package/dist/types/wrappers.js +39 -0
  64. package/dist/types.d.ts +7 -0
  65. package/dist/types.js +24 -0
  66. package/package.json +50 -0
@@ -0,0 +1,254 @@
1
+ "use strict";
2
+ /**
3
+ * Type conversion utilities between gRPC proto types and JavaScript types.
4
+ */
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.buildGqlRequest = buildGqlRequest;
7
+ exports.buildParameters = buildParameters;
8
+ exports.convertGqlResponse = convertGqlResponse;
9
+ exports.convertTypedValue = convertTypedValue;
10
+ exports.convertProtoProperties = convertProtoProperties;
11
+ exports.convertGraphInfo = convertGraphInfo;
12
+ exports.graphTypeToProto = graphTypeToProto;
13
+ exports.protoToGraphType = protoToGraphType;
14
+ exports.protoToHealthStatus = protoToHealthStatus;
15
+ exports.cacheTypeToProto = cacheTypeToProto;
16
+ exports.nodeDataToProto = nodeDataToProto;
17
+ exports.edgeDataToProto = edgeDataToProto;
18
+ const response_1 = require("../response");
19
+ const types_1 = require("../types");
20
+ /**
21
+ * Build a GQL request from config.
22
+ */
23
+ function buildGqlRequest(query, session, config, queryConfig) {
24
+ return {
25
+ gql: query,
26
+ graph_name: queryConfig?.graphName || session?.defaultGraph || config.defaultGraph || '',
27
+ parameters: buildParameters(queryConfig?.parameters),
28
+ session_id: session?.id?.toString() || '0',
29
+ transaction_id: queryConfig?.transactionId?.toString() || '0',
30
+ timeout: Math.floor((queryConfig?.timeout || config.timeout || 30000) / 1000), // Convert ms to seconds for gRPC
31
+ read_only: queryConfig?.readOnly || false,
32
+ max_path_results: queryConfig?.maxPathResults || 0,
33
+ };
34
+ }
35
+ /**
36
+ * Build parameters array for gRPC.
37
+ */
38
+ function buildParameters(params) {
39
+ if (!params)
40
+ return [];
41
+ return Object.entries(params).map(([name, value]) => ({
42
+ name,
43
+ value: (0, types_1.createTypedValue)(value),
44
+ }));
45
+ }
46
+ /**
47
+ * Convert gRPC response to Response object.
48
+ */
49
+ function convertGqlResponse(grpcResponse) {
50
+ const columns = grpcResponse.columns || [];
51
+ const rows = (grpcResponse.rows || []).map((row) => {
52
+ const rawValues = row.values || [];
53
+ const values = rawValues.map((tv) => convertTypedValue(tv));
54
+ const types = rawValues.map((tv) => protoTypeToEnum(tv?.type));
55
+ return new response_1.Row(values, types);
56
+ });
57
+ return new response_1.Response(columns, rows, parseInt(grpcResponse.row_count || '0', 10), grpcResponse.has_more || false, grpcResponse.warnings || [], parseInt(grpcResponse.rows_affected || '0', 10));
58
+ }
59
+ /**
60
+ * Map proto type string or number to PropertyType enum.
61
+ * Handles both string enum names (e.g., 'PROPERTY_TYPE_STRING') and numeric values.
62
+ */
63
+ function protoTypeToEnum(protoType) {
64
+ // Handle numeric enum values directly
65
+ if (typeof protoType === 'number') {
66
+ // If it's already a valid PropertyType number, return it directly
67
+ // PropertyType ranges from UNSET(0) to EDGE(33)
68
+ if (protoType >= types_1.PropertyType.UNSET && protoType <= types_1.PropertyType.EDGE) {
69
+ return protoType;
70
+ }
71
+ return types_1.PropertyType.NULL;
72
+ }
73
+ const typeMap = {
74
+ 'PROPERTY_TYPE_NULL': types_1.PropertyType.NULL,
75
+ 'PROPERTY_TYPE_UNSET': types_1.PropertyType.UNSET,
76
+ 'PROPERTY_TYPE_BOOL': types_1.PropertyType.BOOL,
77
+ 'PROPERTY_TYPE_INT32': types_1.PropertyType.INT32,
78
+ 'PROPERTY_TYPE_UINT32': types_1.PropertyType.UINT32,
79
+ 'PROPERTY_TYPE_INT64': types_1.PropertyType.INT64,
80
+ 'PROPERTY_TYPE_UINT64': types_1.PropertyType.UINT64,
81
+ 'PROPERTY_TYPE_FLOAT': types_1.PropertyType.FLOAT,
82
+ 'PROPERTY_TYPE_DOUBLE': types_1.PropertyType.DOUBLE,
83
+ 'PROPERTY_TYPE_STRING': types_1.PropertyType.STRING,
84
+ 'PROPERTY_TYPE_TEXT': types_1.PropertyType.TEXT,
85
+ 'PROPERTY_TYPE_BLOB': types_1.PropertyType.BLOB,
86
+ 'PROPERTY_TYPE_TIMESTAMP': types_1.PropertyType.TIMESTAMP,
87
+ 'PROPERTY_TYPE_DATETIME': types_1.PropertyType.DATETIME,
88
+ 'PROPERTY_TYPE_DATE': types_1.PropertyType.DATE,
89
+ 'PROPERTY_TYPE_LOCAL_DATETIME': types_1.PropertyType.LOCAL_DATETIME,
90
+ 'PROPERTY_TYPE_ZONED_DATETIME': types_1.PropertyType.ZONED_DATETIME,
91
+ 'PROPERTY_TYPE_LOCAL_TIME': types_1.PropertyType.LOCAL_TIME,
92
+ 'PROPERTY_TYPE_ZONED_TIME': types_1.PropertyType.ZONED_TIME,
93
+ 'PROPERTY_TYPE_YEAR_TO_MONTH': types_1.PropertyType.YEAR_TO_MONTH,
94
+ 'PROPERTY_TYPE_DAY_TO_SECOND': types_1.PropertyType.DAY_TO_SECOND,
95
+ 'PROPERTY_TYPE_DECIMAL': types_1.PropertyType.DECIMAL,
96
+ 'PROPERTY_TYPE_POINT': types_1.PropertyType.POINT,
97
+ 'PROPERTY_TYPE_POINT3D': types_1.PropertyType.POINT3D,
98
+ 'PROPERTY_TYPE_VECTOR': types_1.PropertyType.VECTOR,
99
+ 'PROPERTY_TYPE_LIST': types_1.PropertyType.LIST,
100
+ 'PROPERTY_TYPE_SET': types_1.PropertyType.SET,
101
+ 'PROPERTY_TYPE_MAP': types_1.PropertyType.MAP,
102
+ 'PROPERTY_TYPE_NODE': types_1.PropertyType.NODE,
103
+ 'PROPERTY_TYPE_EDGE': types_1.PropertyType.EDGE,
104
+ 'PROPERTY_TYPE_PATH': types_1.PropertyType.PATH,
105
+ 'PROPERTY_TYPE_RECORD': types_1.PropertyType.RECORD,
106
+ 'PROPERTY_TYPE_TABLE': types_1.PropertyType.TABLE,
107
+ 'PROPERTY_TYPE_ERROR': types_1.PropertyType.ERROR,
108
+ };
109
+ return typeMap[protoType] ?? types_1.PropertyType.NULL;
110
+ }
111
+ /**
112
+ * Convert gRPC TypedValue to JS value.
113
+ * Uses the same decoding logic as typedValueToJS for consistency.
114
+ */
115
+ function convertTypedValue(tv) {
116
+ if (!tv || tv.is_null || tv.isNull)
117
+ return null;
118
+ const data = tv.data;
119
+ const protoType = tv.type;
120
+ // Handle null types (both string and numeric enum values)
121
+ if (protoType === 'PROPERTY_TYPE_NULL' || protoType === 'PROPERTY_TYPE_UNSET' ||
122
+ protoType === types_1.PropertyType.NULL || protoType === types_1.PropertyType.UNSET) {
123
+ return null;
124
+ }
125
+ // Handle empty data - but STRING type with empty data should return ""
126
+ if (!data || data.length === 0) {
127
+ const isStringType = protoType === 'PROPERTY_TYPE_STRING' || protoType === 'PROPERTY_TYPE_TEXT' ||
128
+ protoType === types_1.PropertyType.STRING || protoType === types_1.PropertyType.TEXT;
129
+ const isBlobType = protoType === 'PROPERTY_TYPE_BLOB' || protoType === types_1.PropertyType.BLOB;
130
+ if (isStringType) {
131
+ return '';
132
+ }
133
+ if (isBlobType) {
134
+ return Buffer.alloc(0);
135
+ }
136
+ return null;
137
+ }
138
+ const buf = Buffer.from(data);
139
+ const enumType = protoTypeToEnum(protoType);
140
+ // Use typedValueToJS for consistent decoding
141
+ return (0, types_1.typedValueToJS)({ type: enumType, data: buf, isNull: false });
142
+ }
143
+ /**
144
+ * Convert proto properties map to JS object.
145
+ */
146
+ function convertProtoProperties(protoProps) {
147
+ const result = {};
148
+ for (const [key, tv] of Object.entries(protoProps)) {
149
+ result[key] = convertTypedValue(tv);
150
+ }
151
+ return result;
152
+ }
153
+ /**
154
+ * Convert GraphInfo from proto to JS object.
155
+ */
156
+ function convertGraphInfo(g) {
157
+ return {
158
+ name: g.name || '',
159
+ graphType: protoToGraphType(g.graph_type),
160
+ nodeCount: parseInt(g.node_count || '0', 10),
161
+ edgeCount: parseInt(g.edge_count || '0', 10),
162
+ description: g.description || '',
163
+ };
164
+ }
165
+ /**
166
+ * Map GraphType enum to proto string.
167
+ */
168
+ function graphTypeToProto(graphType) {
169
+ switch (graphType) {
170
+ case types_1.GraphType.OPEN:
171
+ return 'GRAPH_TYPE_OPEN';
172
+ case types_1.GraphType.CLOSED:
173
+ return 'GRAPH_TYPE_CLOSED';
174
+ case types_1.GraphType.ONTOLOGY:
175
+ return 'GRAPH_TYPE_ONTOLOGY';
176
+ default:
177
+ return 'GRAPH_TYPE_OPEN';
178
+ }
179
+ }
180
+ /**
181
+ * Map proto string to GraphType enum.
182
+ */
183
+ function protoToGraphType(proto) {
184
+ switch (proto) {
185
+ case 'GRAPH_TYPE_CLOSED':
186
+ return types_1.GraphType.CLOSED;
187
+ case 'GRAPH_TYPE_ONTOLOGY':
188
+ return types_1.GraphType.ONTOLOGY;
189
+ default:
190
+ return types_1.GraphType.OPEN;
191
+ }
192
+ }
193
+ /**
194
+ * Map proto HealthStatus to enum.
195
+ */
196
+ function protoToHealthStatus(proto) {
197
+ switch (proto) {
198
+ case 'HEALTH_STATUS_SERVING':
199
+ return types_1.HealthStatus.SERVING;
200
+ case 'HEALTH_STATUS_NOT_SERVING':
201
+ return types_1.HealthStatus.NOT_SERVING;
202
+ case 'HEALTH_STATUS_SERVICE_UNKNOWN':
203
+ return types_1.HealthStatus.SERVICE_UNKNOWN;
204
+ default:
205
+ return types_1.HealthStatus.UNKNOWN;
206
+ }
207
+ }
208
+ /**
209
+ * Map CacheType to proto string.
210
+ */
211
+ function cacheTypeToProto(cacheType) {
212
+ switch (cacheType) {
213
+ case types_1.CacheType.AST:
214
+ return 'CACHE_TYPE_AST';
215
+ case types_1.CacheType.PLAN:
216
+ return 'CACHE_TYPE_PLAN';
217
+ default:
218
+ return 'CACHE_TYPE_ALL';
219
+ }
220
+ }
221
+ /**
222
+ * Convert NodeData to proto format.
223
+ */
224
+ function nodeDataToProto(node) {
225
+ const properties = {};
226
+ if (node.properties) {
227
+ for (const [key, value] of Object.entries(node.properties)) {
228
+ properties[key] = (0, types_1.createTypedValue)(value);
229
+ }
230
+ }
231
+ return {
232
+ id: node.id || '',
233
+ labels: node.labels || [],
234
+ properties,
235
+ };
236
+ }
237
+ /**
238
+ * Convert EdgeData to proto format.
239
+ */
240
+ function edgeDataToProto(edge) {
241
+ const properties = {};
242
+ if (edge.properties) {
243
+ for (const [key, value] of Object.entries(edge.properties)) {
244
+ properties[key] = (0, types_1.createTypedValue)(value);
245
+ }
246
+ }
247
+ return {
248
+ label: edge.label || '',
249
+ from_node_id: edge.fromNodeId || '',
250
+ to_node_id: edge.toNodeId || '',
251
+ properties,
252
+ };
253
+ }
254
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"converters.js","sourceRoot":"","sources":["../../src/services/converters.ts"],"names":[],"mappings":";AAAA;;GAEG;;AAmBH,0CAgBC;AAKD,0CAMC;AAKD,gDAgBC;AA4DD,8CAgCC;AAKD,wDAMC;AAKD,4CAQC;AAKD,4CAWC;AAKD,4CASC;AAKD,kDAWC;AAKD,4CASC;AAKD,0CAYC;AAKD,0CAaC;AApRD,0CAA4C;AAC5C,oCAQkB;AAKlB;;GAEG;AACH,SAAgB,eAAe,CAC7B,KAAa,EACb,OAAuB,EACvB,MAAmB,EACnB,WAAyB;IAEzB,OAAO;QACL,GAAG,EAAE,KAAK;QACV,UAAU,EAAE,WAAW,EAAE,SAAS,IAAI,OAAO,EAAE,YAAY,IAAI,MAAM,CAAC,YAAY,IAAI,EAAE;QACxF,UAAU,EAAE,eAAe,CAAC,WAAW,EAAE,UAAU,CAAC;QACpD,UAAU,EAAE,OAAO,EAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,GAAG;QAC1C,cAAc,EAAE,WAAW,EAAE,aAAa,EAAE,QAAQ,EAAE,IAAI,GAAG;QAC7D,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,WAAW,EAAE,OAAO,IAAI,MAAM,CAAC,OAAO,IAAI,KAAK,CAAC,GAAG,IAAI,CAAC,EAAE,iCAAiC;QAChH,SAAS,EAAE,WAAW,EAAE,QAAQ,IAAI,KAAK;QACzC,gBAAgB,EAAE,WAAW,EAAE,cAAc,IAAI,CAAC;KACnD,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,eAAe,CAAC,MAA4B;IAC1D,IAAI,CAAC,MAAM;QAAE,OAAO,EAAE,CAAC;IACvB,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;QACpD,IAAI;QACJ,KAAK,EAAE,IAAA,wBAAgB,EAAC,KAAK,CAAC;KAC/B,CAAC,CAAC,CAAC;AACN,CAAC;AAED;;GAEG;AACH,SAAgB,kBAAkB,CAAC,YAAiB;IAClD,MAAM,OAAO,GAAG,YAAY,CAAC,OAAO,IAAI,EAAE,CAAC;IAC3C,MAAM,IAAI,GAAU,CAAC,YAAY,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE;QAC7D,MAAM,SAAS,GAAG,GAAG,CAAC,MAAM,IAAI,EAAE,CAAC;QACnC,MAAM,MAAM,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAAC,CAAC;QACjE,MAAM,KAAK,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,eAAe,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC,CAAC;QACpE,OAAO,IAAI,cAAG,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;IACH,OAAO,IAAI,mBAAQ,CACjB,OAAO,EACP,IAAI,EACJ,QAAQ,CAAC,YAAY,CAAC,SAAS,IAAI,GAAG,EAAE,EAAE,CAAC,EAC3C,YAAY,CAAC,QAAQ,IAAI,KAAK,EAC9B,YAAY,CAAC,QAAQ,IAAI,EAAE,EAC3B,QAAQ,CAAC,YAAY,CAAC,aAAa,IAAI,GAAG,EAAE,EAAE,CAAC,CAChD,CAAC;AACJ,CAAC;AAED;;;GAGG;AACH,SAAS,eAAe,CAAC,SAA0B;IACjD,sCAAsC;IACtC,IAAI,OAAO,SAAS,KAAK,QAAQ,EAAE,CAAC;QAClC,kEAAkE;QAClE,gDAAgD;QAChD,IAAI,SAAS,IAAI,oBAAY,CAAC,KAAK,IAAI,SAAS,IAAI,oBAAY,CAAC,IAAI,EAAE,CAAC;YACtE,OAAO,SAAyB,CAAC;QACnC,CAAC;QACD,OAAO,oBAAY,CAAC,IAAI,CAAC;IAC3B,CAAC;IAED,MAAM,OAAO,GAAiC;QAC5C,oBAAoB,EAAE,oBAAY,CAAC,IAAI;QACvC,qBAAqB,EAAE,oBAAY,CAAC,KAAK;QACzC,oBAAoB,EAAE,oBAAY,CAAC,IAAI;QACvC,qBAAqB,EAAE,oBAAY,CAAC,KAAK;QACzC,sBAAsB,EAAE,oBAAY,CAAC,MAAM;QAC3C,qBAAqB,EAAE,oBAAY,CAAC,KAAK;QACzC,sBAAsB,EAAE,oBAAY,CAAC,MAAM;QAC3C,qBAAqB,EAAE,oBAAY,CAAC,KAAK;QACzC,sBAAsB,EAAE,oBAAY,CAAC,MAAM;QAC3C,sBAAsB,EAAE,oBAAY,CAAC,MAAM;QAC3C,oBAAoB,EAAE,oBAAY,CAAC,IAAI;QACvC,oBAAoB,EAAE,oBAAY,CAAC,IAAI;QACvC,yBAAyB,EAAE,oBAAY,CAAC,SAAS;QACjD,wBAAwB,EAAE,oBAAY,CAAC,QAAQ;QAC/C,oBAAoB,EAAE,oBAAY,CAAC,IAAI;QACvC,8BAA8B,EAAE,oBAAY,CAAC,cAAc;QAC3D,8BAA8B,EAAE,oBAAY,CAAC,cAAc;QAC3D,0BAA0B,EAAE,oBAAY,CAAC,UAAU;QACnD,0BAA0B,EAAE,oBAAY,CAAC,UAAU;QACnD,6BAA6B,EAAE,oBAAY,CAAC,aAAa;QACzD,6BAA6B,EAAE,oBAAY,CAAC,aAAa;QACzD,uBAAuB,EAAE,oBAAY,CAAC,OAAO;QAC7C,qBAAqB,EAAE,oBAAY,CAAC,KAAK;QACzC,uBAAuB,EAAE,oBAAY,CAAC,OAAO;QAC7C,sBAAsB,EAAE,oBAAY,CAAC,MAAM;QAC3C,oBAAoB,EAAE,oBAAY,CAAC,IAAI;QACvC,mBAAmB,EAAE,oBAAY,CAAC,GAAG;QACrC,mBAAmB,EAAE,oBAAY,CAAC,GAAG;QACrC,oBAAoB,EAAE,oBAAY,CAAC,IAAI;QACvC,oBAAoB,EAAE,oBAAY,CAAC,IAAI;QACvC,oBAAoB,EAAE,oBAAY,CAAC,IAAI;QACvC,sBAAsB,EAAE,oBAAY,CAAC,MAAM;QAC3C,qBAAqB,EAAE,oBAAY,CAAC,KAAK;QACzC,qBAAqB,EAAE,oBAAY,CAAC,KAAK;KAC1C,CAAC;IACF,OAAO,OAAO,CAAC,SAAS,CAAC,IAAI,oBAAY,CAAC,IAAI,CAAC;AACjD,CAAC;AAED;;;GAGG;AACH,SAAgB,iBAAiB,CAAC,EAAO;IACvC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,OAAO,IAAI,EAAE,CAAC,MAAM;QAAE,OAAO,IAAI,CAAC;IAEhD,MAAM,IAAI,GAAG,EAAE,CAAC,IAAI,CAAC;IACrB,MAAM,SAAS,GAAG,EAAE,CAAC,IAAI,CAAC;IAE1B,0DAA0D;IAC1D,IAAI,SAAS,KAAK,oBAAoB,IAAI,SAAS,KAAK,qBAAqB;QACzE,SAAS,KAAK,oBAAY,CAAC,IAAI,IAAI,SAAS,KAAK,oBAAY,CAAC,KAAK,EAAE,CAAC;QACxE,OAAO,IAAI,CAAC;IACd,CAAC;IAED,uEAAuE;IACvE,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC/B,MAAM,YAAY,GAAG,SAAS,KAAK,sBAAsB,IAAI,SAAS,KAAK,oBAAoB;YAC1E,SAAS,KAAK,oBAAY,CAAC,MAAM,IAAI,SAAS,KAAK,oBAAY,CAAC,IAAI,CAAC;QAC1F,MAAM,UAAU,GAAG,SAAS,KAAK,oBAAoB,IAAI,SAAS,KAAK,oBAAY,CAAC,IAAI,CAAC;QAEzF,IAAI,YAAY,EAAE,CAAC;YACjB,OAAO,EAAE,CAAC;QACZ,CAAC;QACD,IAAI,UAAU,EAAE,CAAC;YACf,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACzB,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9B,MAAM,QAAQ,GAAG,eAAe,CAAC,SAAS,CAAC,CAAC;IAE5C,6CAA6C;IAC7C,OAAO,IAAA,sBAAc,EAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;AACtE,CAAC;AAED;;GAEG;AACH,SAAgB,sBAAsB,CAAC,UAA+B;IACpE,MAAM,MAAM,GAAwB,EAAE,CAAC;IACvC,KAAK,MAAM,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,CAAC;QACnD,MAAM,CAAC,GAAG,CAAC,GAAG,iBAAiB,CAAC,EAAE,CAAC,CAAC;IACtC,CAAC;IACD,OAAO,MAAM,CAAC;AAChB,CAAC;AAED;;GAEG;AACH,SAAgB,gBAAgB,CAAC,CAAM;IACrC,OAAO;QACL,IAAI,EAAE,CAAC,CAAC,IAAI,IAAI,EAAE;QAClB,SAAS,EAAE,gBAAgB,CAAC,CAAC,CAAC,UAAU,CAAC;QACzC,SAAS,EAAE,QAAQ,CAAC,CAAC,CAAC,UAAU,IAAI,GAAG,EAAE,EAAE,CAAC;QAC5C,SAAS,EAAE,QAAQ,CAAC,CAAC,CAAC,UAAU,IAAI,GAAG,EAAE,EAAE,CAAC;QAC5C,WAAW,EAAE,CAAC,CAAC,WAAW,IAAI,EAAE;KACjC,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,gBAAgB,CAAC,SAAoB;IACnD,QAAQ,SAAS,EAAE,CAAC;QAClB,KAAK,iBAAS,CAAC,IAAI;YACjB,OAAO,iBAAiB,CAAC;QAC3B,KAAK,iBAAS,CAAC,MAAM;YACnB,OAAO,mBAAmB,CAAC;QAC7B,KAAK,iBAAS,CAAC,QAAQ;YACrB,OAAO,qBAAqB,CAAC;QAC/B;YACE,OAAO,iBAAiB,CAAC;IAC7B,CAAC;AACH,CAAC;AAED;;GAEG;AACH,SAAgB,gBAAgB,CAAC,KAAa;IAC5C,QAAQ,KAAK,EAAE,CAAC;QACd,KAAK,mBAAmB;YACtB,OAAO,iBAAS,CAAC,MAAM,CAAC;QAC1B,KAAK,qBAAqB;YACxB,OAAO,iBAAS,CAAC,QAAQ,CAAC;QAC5B;YACE,OAAO,iBAAS,CAAC,IAAI,CAAC;IAC1B,CAAC;AACH,CAAC;AAED;;GAEG;AACH,SAAgB,mBAAmB,CAAC,KAAa;IAC/C,QAAQ,KAAK,EAAE,CAAC;QACd,KAAK,uBAAuB;YAC1B,OAAO,oBAAY,CAAC,OAAO,CAAC;QAC9B,KAAK,2BAA2B;YAC9B,OAAO,oBAAY,CAAC,WAAW,CAAC;QAClC,KAAK,+BAA+B;YAClC,OAAO,oBAAY,CAAC,eAAe,CAAC;QACtC;YACE,OAAO,oBAAY,CAAC,OAAO,CAAC;IAChC,CAAC;AACH,CAAC;AAED;;GAEG;AACH,SAAgB,gBAAgB,CAAC,SAAoB;IACnD,QAAQ,SAAS,EAAE,CAAC;QAClB,KAAK,iBAAS,CAAC,GAAG;YAChB,OAAO,gBAAgB,CAAC;QAC1B,KAAK,iBAAS,CAAC,IAAI;YACjB,OAAO,iBAAiB,CAAC;QAC3B;YACE,OAAO,gBAAgB,CAAC;IAC5B,CAAC;AACH,CAAC;AAED;;GAEG;AACH,SAAgB,eAAe,CAAC,IAAS;IACvC,MAAM,UAAU,GAAwB,EAAE,CAAC;IAC3C,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YAC3D,UAAU,CAAC,GAAG,CAAC,GAAG,IAAA,wBAAgB,EAAC,KAAK,CAAC,CAAC;QAC5C,CAAC;IACH,CAAC;IACD,OAAO;QACL,EAAE,EAAE,IAAI,CAAC,EAAE,IAAI,EAAE;QACjB,MAAM,EAAE,IAAI,CAAC,MAAM,IAAI,EAAE;QACzB,UAAU;KACX,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,eAAe,CAAC,IAAS;IACvC,MAAM,UAAU,GAAwB,EAAE,CAAC;IAC3C,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YAC3D,UAAU,CAAC,GAAG,CAAC,GAAG,IAAA,wBAAgB,EAAC,KAAK,CAAC,CAAC;QAC5C,CAAC;IACH,CAAC;IACD,OAAO;QACL,KAAK,EAAE,IAAI,CAAC,KAAK,IAAI,EAAE;QACvB,YAAY,EAAE,IAAI,CAAC,UAAU,IAAI,EAAE;QACnC,UAAU,EAAE,IAAI,CAAC,QAAQ,IAAI,EAAE;QAC/B,UAAU;KACX,CAAC;AACJ,CAAC","sourcesContent":["/**\r\n * Type conversion utilities between gRPC proto types and JavaScript types.\r\n */\r\n\r\nimport { Response, Row } from '../response';\r\nimport {\r\n  GraphType,\r\n  HealthStatus,\r\n  CacheType,\r\n  GraphInfo,\r\n  createTypedValue,\r\n  PropertyType,\r\n  typedValueToJS,\r\n} from '../types';\r\nimport { GqldbConfig } from '../config';\r\nimport { Session } from '../session';\r\nimport { QueryConfig } from '../client';\r\n\r\n/**\r\n * Build a GQL request from config.\r\n */\r\nexport function buildGqlRequest(\r\n  query: string,\r\n  session: Session | null,\r\n  config: GqldbConfig,\r\n  queryConfig?: QueryConfig\r\n): any {\r\n  return {\r\n    gql: query,\r\n    graph_name: queryConfig?.graphName || session?.defaultGraph || config.defaultGraph || '',\r\n    parameters: buildParameters(queryConfig?.parameters),\r\n    session_id: session?.id?.toString() || '0',\r\n    transaction_id: queryConfig?.transactionId?.toString() || '0',\r\n    timeout: Math.floor((queryConfig?.timeout || config.timeout || 30000) / 1000), // Convert ms to seconds for gRPC\r\n    read_only: queryConfig?.readOnly || false,\r\n    max_path_results: queryConfig?.maxPathResults || 0,\r\n  };\r\n}\r\n\r\n/**\r\n * Build parameters array for gRPC.\r\n */\r\nexport function buildParameters(params?: Record<string, any>): any[] {\r\n  if (!params) return [];\r\n  return Object.entries(params).map(([name, value]) => ({\r\n    name,\r\n    value: createTypedValue(value),\r\n  }));\r\n}\r\n\r\n/**\r\n * Convert gRPC response to Response object.\r\n */\r\nexport function convertGqlResponse(grpcResponse: any): Response {\r\n  const columns = grpcResponse.columns || [];\r\n  const rows: Row[] = (grpcResponse.rows || []).map((row: any) => {\r\n    const rawValues = row.values || [];\r\n    const values = rawValues.map((tv: any) => convertTypedValue(tv));\r\n    const types = rawValues.map((tv: any) => protoTypeToEnum(tv?.type));\r\n    return new Row(values, types);\r\n  });\r\n  return new Response(\r\n    columns,\r\n    rows,\r\n    parseInt(grpcResponse.row_count || '0', 10),\r\n    grpcResponse.has_more || false,\r\n    grpcResponse.warnings || [],\r\n    parseInt(grpcResponse.rows_affected || '0', 10)\r\n  );\r\n}\r\n\r\n/**\r\n * Map proto type string or number to PropertyType enum.\r\n * Handles both string enum names (e.g., 'PROPERTY_TYPE_STRING') and numeric values.\r\n */\r\nfunction protoTypeToEnum(protoType: string | number): PropertyType {\r\n  // Handle numeric enum values directly\r\n  if (typeof protoType === 'number') {\r\n    // If it's already a valid PropertyType number, return it directly\r\n    // PropertyType ranges from UNSET(0) to EDGE(33)\r\n    if (protoType >= PropertyType.UNSET && protoType <= PropertyType.EDGE) {\r\n      return protoType as PropertyType;\r\n    }\r\n    return PropertyType.NULL;\r\n  }\r\n\r\n  const typeMap: Record<string, PropertyType> = {\r\n    'PROPERTY_TYPE_NULL': PropertyType.NULL,\r\n    'PROPERTY_TYPE_UNSET': PropertyType.UNSET,\r\n    'PROPERTY_TYPE_BOOL': PropertyType.BOOL,\r\n    'PROPERTY_TYPE_INT32': PropertyType.INT32,\r\n    'PROPERTY_TYPE_UINT32': PropertyType.UINT32,\r\n    'PROPERTY_TYPE_INT64': PropertyType.INT64,\r\n    'PROPERTY_TYPE_UINT64': PropertyType.UINT64,\r\n    'PROPERTY_TYPE_FLOAT': PropertyType.FLOAT,\r\n    'PROPERTY_TYPE_DOUBLE': PropertyType.DOUBLE,\r\n    'PROPERTY_TYPE_STRING': PropertyType.STRING,\r\n    'PROPERTY_TYPE_TEXT': PropertyType.TEXT,\r\n    'PROPERTY_TYPE_BLOB': PropertyType.BLOB,\r\n    'PROPERTY_TYPE_TIMESTAMP': PropertyType.TIMESTAMP,\r\n    'PROPERTY_TYPE_DATETIME': PropertyType.DATETIME,\r\n    'PROPERTY_TYPE_DATE': PropertyType.DATE,\r\n    'PROPERTY_TYPE_LOCAL_DATETIME': PropertyType.LOCAL_DATETIME,\r\n    'PROPERTY_TYPE_ZONED_DATETIME': PropertyType.ZONED_DATETIME,\r\n    'PROPERTY_TYPE_LOCAL_TIME': PropertyType.LOCAL_TIME,\r\n    'PROPERTY_TYPE_ZONED_TIME': PropertyType.ZONED_TIME,\r\n    'PROPERTY_TYPE_YEAR_TO_MONTH': PropertyType.YEAR_TO_MONTH,\r\n    'PROPERTY_TYPE_DAY_TO_SECOND': PropertyType.DAY_TO_SECOND,\r\n    'PROPERTY_TYPE_DECIMAL': PropertyType.DECIMAL,\r\n    'PROPERTY_TYPE_POINT': PropertyType.POINT,\r\n    'PROPERTY_TYPE_POINT3D': PropertyType.POINT3D,\r\n    'PROPERTY_TYPE_VECTOR': PropertyType.VECTOR,\r\n    'PROPERTY_TYPE_LIST': PropertyType.LIST,\r\n    'PROPERTY_TYPE_SET': PropertyType.SET,\r\n    'PROPERTY_TYPE_MAP': PropertyType.MAP,\r\n    'PROPERTY_TYPE_NODE': PropertyType.NODE,\r\n    'PROPERTY_TYPE_EDGE': PropertyType.EDGE,\r\n    'PROPERTY_TYPE_PATH': PropertyType.PATH,\r\n    'PROPERTY_TYPE_RECORD': PropertyType.RECORD,\r\n    'PROPERTY_TYPE_TABLE': PropertyType.TABLE,\r\n    'PROPERTY_TYPE_ERROR': PropertyType.ERROR,\r\n  };\r\n  return typeMap[protoType] ?? PropertyType.NULL;\r\n}\r\n\r\n/**\r\n * Convert gRPC TypedValue to JS value.\r\n * Uses the same decoding logic as typedValueToJS for consistency.\r\n */\r\nexport function convertTypedValue(tv: any): any {\r\n  if (!tv || tv.is_null || tv.isNull) return null;\r\n\r\n  const data = tv.data;\r\n  const protoType = tv.type;\r\n\r\n  // Handle null types (both string and numeric enum values)\r\n  if (protoType === 'PROPERTY_TYPE_NULL' || protoType === 'PROPERTY_TYPE_UNSET' ||\r\n      protoType === PropertyType.NULL || protoType === PropertyType.UNSET) {\r\n    return null;\r\n  }\r\n\r\n  // Handle empty data - but STRING type with empty data should return \"\"\r\n  if (!data || data.length === 0) {\r\n    const isStringType = protoType === 'PROPERTY_TYPE_STRING' || protoType === 'PROPERTY_TYPE_TEXT' ||\r\n                         protoType === PropertyType.STRING || protoType === PropertyType.TEXT;\r\n    const isBlobType = protoType === 'PROPERTY_TYPE_BLOB' || protoType === PropertyType.BLOB;\r\n\r\n    if (isStringType) {\r\n      return '';\r\n    }\r\n    if (isBlobType) {\r\n      return Buffer.alloc(0);\r\n    }\r\n    return null;\r\n  }\r\n\r\n  const buf = Buffer.from(data);\r\n  const enumType = protoTypeToEnum(protoType);\r\n\r\n  // Use typedValueToJS for consistent decoding\r\n  return typedValueToJS({ type: enumType, data: buf, isNull: false });\r\n}\r\n\r\n/**\r\n * Convert proto properties map to JS object.\r\n */\r\nexport function convertProtoProperties(protoProps: Record<string, any>): Record<string, any> {\r\n  const result: Record<string, any> = {};\r\n  for (const [key, tv] of Object.entries(protoProps)) {\r\n    result[key] = convertTypedValue(tv);\r\n  }\r\n  return result;\r\n}\r\n\r\n/**\r\n * Convert GraphInfo from proto to JS object.\r\n */\r\nexport function convertGraphInfo(g: any): GraphInfo {\r\n  return {\r\n    name: g.name || '',\r\n    graphType: protoToGraphType(g.graph_type),\r\n    nodeCount: parseInt(g.node_count || '0', 10),\r\n    edgeCount: parseInt(g.edge_count || '0', 10),\r\n    description: g.description || '',\r\n  };\r\n}\r\n\r\n/**\r\n * Map GraphType enum to proto string.\r\n */\r\nexport function graphTypeToProto(graphType: GraphType): string {\r\n  switch (graphType) {\r\n    case GraphType.OPEN:\r\n      return 'GRAPH_TYPE_OPEN';\r\n    case GraphType.CLOSED:\r\n      return 'GRAPH_TYPE_CLOSED';\r\n    case GraphType.ONTOLOGY:\r\n      return 'GRAPH_TYPE_ONTOLOGY';\r\n    default:\r\n      return 'GRAPH_TYPE_OPEN';\r\n  }\r\n}\r\n\r\n/**\r\n * Map proto string to GraphType enum.\r\n */\r\nexport function protoToGraphType(proto: string): GraphType {\r\n  switch (proto) {\r\n    case 'GRAPH_TYPE_CLOSED':\r\n      return GraphType.CLOSED;\r\n    case 'GRAPH_TYPE_ONTOLOGY':\r\n      return GraphType.ONTOLOGY;\r\n    default:\r\n      return GraphType.OPEN;\r\n  }\r\n}\r\n\r\n/**\r\n * Map proto HealthStatus to enum.\r\n */\r\nexport function protoToHealthStatus(proto: string): HealthStatus {\r\n  switch (proto) {\r\n    case 'HEALTH_STATUS_SERVING':\r\n      return HealthStatus.SERVING;\r\n    case 'HEALTH_STATUS_NOT_SERVING':\r\n      return HealthStatus.NOT_SERVING;\r\n    case 'HEALTH_STATUS_SERVICE_UNKNOWN':\r\n      return HealthStatus.SERVICE_UNKNOWN;\r\n    default:\r\n      return HealthStatus.UNKNOWN;\r\n  }\r\n}\r\n\r\n/**\r\n * Map CacheType to proto string.\r\n */\r\nexport function cacheTypeToProto(cacheType: CacheType): string {\r\n  switch (cacheType) {\r\n    case CacheType.AST:\r\n      return 'CACHE_TYPE_AST';\r\n    case CacheType.PLAN:\r\n      return 'CACHE_TYPE_PLAN';\r\n    default:\r\n      return 'CACHE_TYPE_ALL';\r\n  }\r\n}\r\n\r\n/**\r\n * Convert NodeData to proto format.\r\n */\r\nexport function nodeDataToProto(node: any): any {\r\n  const properties: Record<string, any> = {};\r\n  if (node.properties) {\r\n    for (const [key, value] of Object.entries(node.properties)) {\r\n      properties[key] = createTypedValue(value);\r\n    }\r\n  }\r\n  return {\r\n    id: node.id || '',\r\n    labels: node.labels || [],\r\n    properties,\r\n  };\r\n}\r\n\r\n/**\r\n * Convert EdgeData to proto format.\r\n */\r\nexport function edgeDataToProto(edge: any): any {\r\n  const properties: Record<string, any> = {};\r\n  if (edge.properties) {\r\n    for (const [key, value] of Object.entries(edge.properties)) {\r\n      properties[key] = createTypedValue(value);\r\n    }\r\n  }\r\n  return {\r\n    label: edge.label || '',\r\n    from_node_id: edge.fromNodeId || '',\r\n    to_node_id: edge.toNodeId || '',\r\n    properties,\r\n  };\r\n}\r\n"]}
@@ -0,0 +1,44 @@
1
+ /**
2
+ * Data service handles node and edge insert/delete/export operations.
3
+ */
4
+ import { ServiceContext } from './service-context';
5
+ import { InsertNodesResult, InsertEdgesResult, DeleteResult, ExportNodesResult, ExportEdgesResult, ExportConfig, ExportChunk } from '../response';
6
+ import { NodeData, EdgeData } from '../types';
7
+ import { InsertNodesConfig, InsertEdgesConfig } from '../client';
8
+ /**
9
+ * Data service for inserting, deleting, and exporting graph data.
10
+ */
11
+ export declare class DataService {
12
+ private ctx;
13
+ constructor(ctx: ServiceContext);
14
+ /**
15
+ * Insert multiple nodes into a graph.
16
+ */
17
+ insertNodes(graphName: string, nodes: NodeData[], config?: InsertNodesConfig): Promise<InsertNodesResult>;
18
+ /**
19
+ * Insert multiple edges into a graph.
20
+ */
21
+ insertEdges(graphName: string, edges: EdgeData[], config?: InsertEdgesConfig): Promise<InsertEdgesResult>;
22
+ /**
23
+ * Delete nodes from a graph.
24
+ */
25
+ deleteNodes(graphName: string, nodeIds?: string[], labels?: string[], where?: string): Promise<DeleteResult>;
26
+ /**
27
+ * Delete edges from a graph.
28
+ */
29
+ deleteEdges(graphName: string, edgeIds?: string[], label?: string, where?: string): Promise<DeleteResult>;
30
+ /**
31
+ * Export graph data in JSON Lines format (streaming).
32
+ */
33
+ export(config: ExportConfig, callback?: (chunk: ExportChunk) => void): Promise<void>;
34
+ /**
35
+ * Stream nodes from a graph.
36
+ * @deprecated Use export() with ExportConfig instead
37
+ */
38
+ exportNodes(graphName: string, labels?: string[], limit?: number, callback?: (result: ExportNodesResult) => void): Promise<void>;
39
+ /**
40
+ * Stream edges from a graph.
41
+ * @deprecated Use export() with ExportConfig instead
42
+ */
43
+ exportEdges(graphName: string, labels?: string[], limit?: number, callback?: (result: ExportEdgesResult) => void): Promise<void>;
44
+ }
@@ -0,0 +1,206 @@
1
+ "use strict";
2
+ /**
3
+ * Data service handles node and edge insert/delete/export operations.
4
+ */
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.DataService = void 0;
7
+ const services_1 = require("../services");
8
+ const converters_1 = require("./converters");
9
+ /**
10
+ * Data service for inserting, deleting, and exporting graph data.
11
+ */
12
+ class DataService {
13
+ ctx;
14
+ constructor(ctx) {
15
+ this.ctx = ctx;
16
+ }
17
+ /**
18
+ * Insert multiple nodes into a graph.
19
+ */
20
+ async insertNodes(graphName, nodes, config) {
21
+ const request = {
22
+ graph_name: graphName,
23
+ nodes: nodes.map((n) => (0, converters_1.nodeDataToProto)(n)),
24
+ };
25
+ // ALWAYS set options (even when undefined) to avoid deprecated bulk operations error
26
+ request.options = { overwrite: config?.options?.overwrite || false };
27
+ if (config?.bulkImportSessionId) {
28
+ request.bulk_import_session_id = config.bulkImportSessionId;
29
+ }
30
+ const metadata = this.ctx.getSessionMetadata();
31
+ const response = await (0, services_1.promisifyCall)(this.ctx.clients.dataService, 'InsertNodes', request, metadata);
32
+ return {
33
+ success: response.success || false,
34
+ nodeIds: response.node_ids || [],
35
+ nodeCount: parseInt(response.node_count || '0', 10),
36
+ message: response.message || '',
37
+ };
38
+ }
39
+ /**
40
+ * Insert multiple edges into a graph.
41
+ */
42
+ async insertEdges(graphName, edges, config) {
43
+ const request = {
44
+ graph_name: graphName,
45
+ edges: edges.map((e) => (0, converters_1.edgeDataToProto)(e)),
46
+ };
47
+ // ALWAYS set options (even when undefined) to avoid deprecated bulk operations error
48
+ request.options = {
49
+ skip_invalid_nodes: config?.options?.skipInvalidNodes || false,
50
+ };
51
+ if (config?.bulkImportSessionId) {
52
+ request.bulk_import_session_id = config.bulkImportSessionId;
53
+ }
54
+ const metadata = this.ctx.getSessionMetadata();
55
+ const response = await (0, services_1.promisifyCall)(this.ctx.clients.dataService, 'InsertEdges', request, metadata);
56
+ return {
57
+ success: response.success || false,
58
+ edgeIds: response.edge_ids || [],
59
+ edgeCount: parseInt(response.edge_count || '0', 10),
60
+ message: response.message || '',
61
+ skippedCount: parseInt(response.skipped_count || '0', 10),
62
+ };
63
+ }
64
+ /**
65
+ * Delete nodes from a graph.
66
+ */
67
+ async deleteNodes(graphName, nodeIds, labels, where) {
68
+ const request = {
69
+ graph_name: graphName,
70
+ node_ids: nodeIds || [],
71
+ labels: labels || [],
72
+ where: where || '',
73
+ };
74
+ const metadata = this.ctx.getSessionMetadata();
75
+ const response = await (0, services_1.promisifyCall)(this.ctx.clients.dataService, 'DeleteNodes', request, metadata);
76
+ return {
77
+ success: response.success || false,
78
+ deletedCount: parseInt(response.deleted_count || '0', 10),
79
+ message: response.message || '',
80
+ };
81
+ }
82
+ /**
83
+ * Delete edges from a graph.
84
+ */
85
+ async deleteEdges(graphName, edgeIds, label, where) {
86
+ const request = {
87
+ graph_name: graphName,
88
+ edge_ids: edgeIds || [],
89
+ label: label || '',
90
+ where: where || '',
91
+ };
92
+ const metadata = this.ctx.getSessionMetadata();
93
+ const response = await (0, services_1.promisifyCall)(this.ctx.clients.dataService, 'DeleteEdges', request, metadata);
94
+ return {
95
+ success: response.success || false,
96
+ deletedCount: parseInt(response.deleted_count || '0', 10),
97
+ message: response.message || '',
98
+ };
99
+ }
100
+ /**
101
+ * Export graph data in JSON Lines format (streaming).
102
+ */
103
+ async export(config, callback) {
104
+ const request = {
105
+ graph_name: config.graphName,
106
+ batch_size: config.batchSize || 0,
107
+ export_nodes: config.exportNodes !== false,
108
+ export_edges: config.exportEdges !== false,
109
+ node_labels: config.nodeLabels || [],
110
+ edge_labels: config.edgeLabels || [],
111
+ include_metadata: config.includeMetadata || false,
112
+ };
113
+ const metadata = this.ctx.getSessionMetadata();
114
+ return new Promise((resolve, reject) => {
115
+ const stream = this.ctx.clients.dataService.Export(request, metadata);
116
+ stream.on('data', (response) => {
117
+ if (callback) {
118
+ let stats;
119
+ if (response.stats) {
120
+ stats = {
121
+ nodesExported: parseInt(response.stats.nodes_exported || '0', 10),
122
+ edgesExported: parseInt(response.stats.edges_exported || '0', 10),
123
+ bytesWritten: parseInt(response.stats.bytes_written || '0', 10),
124
+ durationMs: parseInt(response.stats.duration_ms || '0', 10),
125
+ };
126
+ }
127
+ const chunk = {
128
+ data: Buffer.from(response.data || []),
129
+ isFinal: response.is_final || false,
130
+ stats,
131
+ };
132
+ callback(chunk);
133
+ }
134
+ if (response.is_final) {
135
+ stream.cancel();
136
+ }
137
+ });
138
+ stream.on('end', () => resolve());
139
+ stream.on('error', (error) => reject(error));
140
+ });
141
+ }
142
+ /**
143
+ * Stream nodes from a graph.
144
+ * @deprecated Use export() with ExportConfig instead
145
+ */
146
+ async exportNodes(graphName, labels, limit = 0, callback) {
147
+ console.warn('exportNodes is deprecated, use export() with ExportConfig instead');
148
+ const request = {
149
+ graph_name: graphName,
150
+ labels: labels || [],
151
+ limit: limit.toString(),
152
+ };
153
+ const metadata = this.ctx.getSessionMetadata();
154
+ return new Promise((resolve, reject) => {
155
+ const stream = this.ctx.clients.dataService.ExportNodes(request, metadata);
156
+ stream.on('data', (response) => {
157
+ if (callback) {
158
+ callback({
159
+ nodes: (response.nodes || []).map((n) => ({
160
+ id: n.id || '',
161
+ labels: n.labels || [],
162
+ properties: (0, converters_1.convertProtoProperties)(n.properties || {}),
163
+ })),
164
+ hasMore: response.has_more || false,
165
+ });
166
+ }
167
+ });
168
+ stream.on('end', () => resolve());
169
+ stream.on('error', (error) => reject(error));
170
+ });
171
+ }
172
+ /**
173
+ * Stream edges from a graph.
174
+ * @deprecated Use export() with ExportConfig instead
175
+ */
176
+ async exportEdges(graphName, labels, limit = 0, callback) {
177
+ console.warn('exportEdges is deprecated, use export() with ExportConfig instead');
178
+ const request = {
179
+ graph_name: graphName,
180
+ labels: labels || [],
181
+ limit: limit.toString(),
182
+ };
183
+ const metadata = this.ctx.getSessionMetadata();
184
+ return new Promise((resolve, reject) => {
185
+ const stream = this.ctx.clients.dataService.ExportEdges(request, metadata);
186
+ stream.on('data', (response) => {
187
+ if (callback) {
188
+ callback({
189
+ edges: (response.edges || []).map((e) => ({
190
+ id: e.id || '',
191
+ label: e.label || '',
192
+ fromNodeId: e.from_node_id || '',
193
+ toNodeId: e.to_node_id || '',
194
+ properties: (0, converters_1.convertProtoProperties)(e.properties || {}),
195
+ })),
196
+ hasMore: response.has_more || false,
197
+ });
198
+ }
199
+ });
200
+ stream.on('end', () => resolve());
201
+ stream.on('error', (error) => reject(error));
202
+ });
203
+ }
204
+ }
205
+ exports.DataService = DataService;
206
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-service.js","sourceRoot":"","sources":["../../src/services/data-service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Data service handles node and edge insert/delete/export operations.\r\n */\r\n\r\nimport { ServiceContext } from './service-context';\r\nimport {\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 { NodeData, EdgeData } from '../types';\r\nimport { promisifyCall } from '../services';\r\nimport { nodeDataToProto, edgeDataToProto, convertProtoProperties } from './converters';\r\nimport { InsertNodesConfig, InsertEdgesConfig } from '../client';\r\n\r\n/**\r\n * Data service for inserting, deleting, and exporting graph data.\r\n */\r\nexport class DataService {\r\n  constructor(private ctx: ServiceContext) {}\r\n\r\n  /**\r\n   * Insert multiple nodes into a graph.\r\n   */\r\n  async insertNodes(\r\n    graphName: string,\r\n    nodes: NodeData[],\r\n    config?: InsertNodesConfig\r\n  ): Promise<InsertNodesResult> {\r\n    const request: any = {\r\n      graph_name: graphName,\r\n      nodes: nodes.map((n) => nodeDataToProto(n)),\r\n    };\r\n\r\n    // ALWAYS set options (even when undefined) to avoid deprecated bulk operations error\r\n    request.options = { overwrite: config?.options?.overwrite || false };\r\n\r\n    if (config?.bulkImportSessionId) {\r\n      request.bulk_import_session_id = config.bulkImportSessionId;\r\n    }\r\n\r\n    const metadata = this.ctx.getSessionMetadata();\r\n    const response: any = await promisifyCall(\r\n      this.ctx.clients.dataService,\r\n      'InsertNodes',\r\n      request,\r\n      metadata\r\n    );\r\n\r\n    return {\r\n      success: response.success || false,\r\n      nodeIds: response.node_ids || [],\r\n      nodeCount: parseInt(response.node_count || '0', 10),\r\n      message: response.message || '',\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Insert multiple edges into a graph.\r\n   */\r\n  async insertEdges(\r\n    graphName: string,\r\n    edges: EdgeData[],\r\n    config?: InsertEdgesConfig\r\n  ): Promise<InsertEdgesResult> {\r\n    const request: any = {\r\n      graph_name: graphName,\r\n      edges: edges.map((e) => edgeDataToProto(e)),\r\n    };\r\n\r\n    // ALWAYS set options (even when undefined) to avoid deprecated bulk operations error\r\n    request.options = {\r\n      skip_invalid_nodes: config?.options?.skipInvalidNodes || false,\r\n    };\r\n\r\n    if (config?.bulkImportSessionId) {\r\n      request.bulk_import_session_id = config.bulkImportSessionId;\r\n    }\r\n\r\n    const metadata = this.ctx.getSessionMetadata();\r\n    const response: any = await promisifyCall(\r\n      this.ctx.clients.dataService,\r\n      'InsertEdges',\r\n      request,\r\n      metadata\r\n    );\r\n\r\n    return {\r\n      success: response.success || false,\r\n      edgeIds: response.edge_ids || [],\r\n      edgeCount: parseInt(response.edge_count || '0', 10),\r\n      message: response.message || '',\r\n      skippedCount: parseInt(response.skipped_count || '0', 10),\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Delete nodes from a graph.\r\n   */\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    const request = {\r\n      graph_name: graphName,\r\n      node_ids: nodeIds || [],\r\n      labels: labels || [],\r\n      where: where || '',\r\n    };\r\n\r\n    const metadata = this.ctx.getSessionMetadata();\r\n    const response: any = await promisifyCall(\r\n      this.ctx.clients.dataService,\r\n      'DeleteNodes',\r\n      request,\r\n      metadata\r\n    );\r\n\r\n    return {\r\n      success: response.success || false,\r\n      deletedCount: parseInt(response.deleted_count || '0', 10),\r\n      message: response.message || '',\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Delete edges from a graph.\r\n   */\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    const request = {\r\n      graph_name: graphName,\r\n      edge_ids: edgeIds || [],\r\n      label: label || '',\r\n      where: where || '',\r\n    };\r\n\r\n    const metadata = this.ctx.getSessionMetadata();\r\n    const response: any = await promisifyCall(\r\n      this.ctx.clients.dataService,\r\n      'DeleteEdges',\r\n      request,\r\n      metadata\r\n    );\r\n\r\n    return {\r\n      success: response.success || false,\r\n      deletedCount: parseInt(response.deleted_count || '0', 10),\r\n      message: response.message || '',\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Export graph data in JSON Lines format (streaming).\r\n   */\r\n  async export(\r\n    config: ExportConfig,\r\n    callback?: (chunk: ExportChunk) => void\r\n  ): Promise<void> {\r\n    const request = {\r\n      graph_name: config.graphName,\r\n      batch_size: config.batchSize || 0,\r\n      export_nodes: config.exportNodes !== false,\r\n      export_edges: config.exportEdges !== false,\r\n      node_labels: config.nodeLabels || [],\r\n      edge_labels: config.edgeLabels || [],\r\n      include_metadata: config.includeMetadata || false,\r\n    };\r\n\r\n    const metadata = this.ctx.getSessionMetadata();\r\n\r\n    return new Promise((resolve, reject) => {\r\n      const stream = (this.ctx.clients.dataService as any).Export(request, metadata);\r\n\r\n      stream.on('data', (response: any) => {\r\n        if (callback) {\r\n          let stats: ExportStats | undefined;\r\n          if (response.stats) {\r\n            stats = {\r\n              nodesExported: parseInt(response.stats.nodes_exported || '0', 10),\r\n              edgesExported: parseInt(response.stats.edges_exported || '0', 10),\r\n              bytesWritten: parseInt(response.stats.bytes_written || '0', 10),\r\n              durationMs: parseInt(response.stats.duration_ms || '0', 10),\r\n            };\r\n          }\r\n\r\n          const chunk: ExportChunk = {\r\n            data: Buffer.from(response.data || []),\r\n            isFinal: response.is_final || false,\r\n            stats,\r\n          };\r\n\r\n          callback(chunk);\r\n        }\r\n\r\n        if (response.is_final) {\r\n          stream.cancel();\r\n        }\r\n      });\r\n\r\n      stream.on('end', () => resolve());\r\n      stream.on('error', (error: any) => reject(error));\r\n    });\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    console.warn('exportNodes is deprecated, use export() with ExportConfig instead');\r\n\r\n    const request = {\r\n      graph_name: graphName,\r\n      labels: labels || [],\r\n      limit: limit.toString(),\r\n    };\r\n\r\n    const metadata = this.ctx.getSessionMetadata();\r\n\r\n    return new Promise((resolve, reject) => {\r\n      const stream = (this.ctx.clients.dataService as any).ExportNodes(request, metadata);\r\n\r\n      stream.on('data', (response: any) => {\r\n        if (callback) {\r\n          callback({\r\n            nodes: (response.nodes || []).map((n: any) => ({\r\n              id: n.id || '',\r\n              labels: n.labels || [],\r\n              properties: convertProtoProperties(n.properties || {}),\r\n            })),\r\n            hasMore: response.has_more || false,\r\n          });\r\n        }\r\n      });\r\n\r\n      stream.on('end', () => resolve());\r\n      stream.on('error', (error: any) => reject(error));\r\n    });\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    console.warn('exportEdges is deprecated, use export() with ExportConfig instead');\r\n\r\n    const request = {\r\n      graph_name: graphName,\r\n      labels: labels || [],\r\n      limit: limit.toString(),\r\n    };\r\n\r\n    const metadata = this.ctx.getSessionMetadata();\r\n\r\n    return new Promise((resolve, reject) => {\r\n      const stream = (this.ctx.clients.dataService as any).ExportEdges(request, metadata);\r\n\r\n      stream.on('data', (response: any) => {\r\n        if (callback) {\r\n          callback({\r\n            edges: (response.edges || []).map((e: any) => ({\r\n              id: e.id || '',\r\n              label: e.label || '',\r\n              fromNodeId: e.from_node_id || '',\r\n              toNodeId: e.to_node_id || '',\r\n              properties: convertProtoProperties(e.properties || {}),\r\n            })),\r\n            hasMore: response.has_more || false,\r\n          });\r\n        }\r\n      });\r\n\r\n      stream.on('end', () => resolve());\r\n      stream.on('error', (error: any) => reject(error));\r\n    });\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,32 @@
1
+ /**
2
+ * Graph service handles graph management operations.
3
+ */
4
+ import { ServiceContext } from './service-context';
5
+ import { GraphInfo, GraphType } from '../types';
6
+ /**
7
+ * Graph service for managing graphs.
8
+ */
9
+ export declare class GraphService {
10
+ private ctx;
11
+ constructor(ctx: ServiceContext);
12
+ /**
13
+ * Create a new graph.
14
+ */
15
+ createGraph(name: string, graphType?: GraphType, description?: string): Promise<void>;
16
+ /**
17
+ * Delete a graph.
18
+ */
19
+ dropGraph(name: string, ifExists?: boolean): Promise<void>;
20
+ /**
21
+ * Set the current graph for the session.
22
+ */
23
+ useGraph(name: string): Promise<void>;
24
+ /**
25
+ * Return all available graphs.
26
+ */
27
+ listGraphs(): Promise<GraphInfo[]>;
28
+ /**
29
+ * Return information about a specific graph.
30
+ */
31
+ getGraphInfo(name: string): Promise<GraphInfo>;
32
+ }