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
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Admin service handles administrative operations.
|
|
3
|
+
*/
|
|
4
|
+
import { ServiceContext } from './service-context';
|
|
5
|
+
import { CacheStats, CacheType, Statistics, CompactResult, ComputeTopologyResult } from '../types';
|
|
6
|
+
/**
|
|
7
|
+
* Admin service for administrative operations.
|
|
8
|
+
*/
|
|
9
|
+
export declare class AdminService {
|
|
10
|
+
private ctx;
|
|
11
|
+
constructor(ctx: ServiceContext);
|
|
12
|
+
/**
|
|
13
|
+
* Pre-allocate parser instances.
|
|
14
|
+
*/
|
|
15
|
+
warmupParser(count: number): Promise<void>;
|
|
16
|
+
/**
|
|
17
|
+
* Return cache statistics.
|
|
18
|
+
*/
|
|
19
|
+
getCacheStats(cacheType?: CacheType): Promise<CacheStats>;
|
|
20
|
+
/**
|
|
21
|
+
* Clear the specified cache.
|
|
22
|
+
*/
|
|
23
|
+
clearCache(cacheType?: CacheType): Promise<void>;
|
|
24
|
+
/**
|
|
25
|
+
* Return database statistics.
|
|
26
|
+
*/
|
|
27
|
+
getStatistics(graphName?: string): Promise<Statistics>;
|
|
28
|
+
/**
|
|
29
|
+
* Invalidate the RBAC permission cache.
|
|
30
|
+
*/
|
|
31
|
+
invalidatePermissionCache(username?: string): Promise<void>;
|
|
32
|
+
/**
|
|
33
|
+
* Trigger manual compaction of the database storage.
|
|
34
|
+
*/
|
|
35
|
+
compact(): Promise<CompactResult>;
|
|
36
|
+
/**
|
|
37
|
+
* Wait for the computing engine topology to be ready.
|
|
38
|
+
*/
|
|
39
|
+
waitForComputeTopology(graphName: string, timeoutMs?: number): Promise<ComputeTopologyResult>;
|
|
40
|
+
}
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Admin service handles administrative operations.
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.AdminService = void 0;
|
|
7
|
+
const types_1 = require("../types");
|
|
8
|
+
const services_1 = require("../services");
|
|
9
|
+
const converters_1 = require("./converters");
|
|
10
|
+
/**
|
|
11
|
+
* Admin service for administrative operations.
|
|
12
|
+
*/
|
|
13
|
+
class AdminService {
|
|
14
|
+
ctx;
|
|
15
|
+
constructor(ctx) {
|
|
16
|
+
this.ctx = ctx;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Pre-allocate parser instances.
|
|
20
|
+
*/
|
|
21
|
+
async warmupParser(count) {
|
|
22
|
+
const metadata = this.ctx.getSessionMetadata();
|
|
23
|
+
await (0, services_1.promisifyCall)(this.ctx.clients.adminService, 'WarmupParser', { count }, metadata);
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Return cache statistics.
|
|
27
|
+
*/
|
|
28
|
+
async getCacheStats(cacheType = types_1.CacheType.ALL) {
|
|
29
|
+
const metadata = this.ctx.getSessionMetadata();
|
|
30
|
+
const response = await (0, services_1.promisifyCall)(this.ctx.clients.adminService, 'GetCacheStats', { cache_type: (0, converters_1.cacheTypeToProto)(cacheType) }, metadata);
|
|
31
|
+
return {
|
|
32
|
+
astStats: response.ast_stats
|
|
33
|
+
? {
|
|
34
|
+
hits: parseInt(response.ast_stats.hits || '0', 10),
|
|
35
|
+
misses: parseInt(response.ast_stats.misses || '0', 10),
|
|
36
|
+
evictions: parseInt(response.ast_stats.evictions || '0', 10),
|
|
37
|
+
entries: response.ast_stats.entries || 0,
|
|
38
|
+
hitRate: response.ast_stats.hit_rate || 0,
|
|
39
|
+
}
|
|
40
|
+
: undefined,
|
|
41
|
+
planStats: response.plan_stats
|
|
42
|
+
? {
|
|
43
|
+
size: response.plan_stats.size || 0,
|
|
44
|
+
capacity: response.plan_stats.capacity || 0,
|
|
45
|
+
hits: parseInt(response.plan_stats.hits || '0', 10),
|
|
46
|
+
misses: parseInt(response.plan_stats.misses || '0', 10),
|
|
47
|
+
hitRate: response.plan_stats.hit_rate || 0,
|
|
48
|
+
}
|
|
49
|
+
: undefined,
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Clear the specified cache.
|
|
54
|
+
*/
|
|
55
|
+
async clearCache(cacheType = types_1.CacheType.ALL) {
|
|
56
|
+
const metadata = this.ctx.getSessionMetadata();
|
|
57
|
+
await (0, services_1.promisifyCall)(this.ctx.clients.adminService, 'ClearCache', { cache_type: (0, converters_1.cacheTypeToProto)(cacheType) }, metadata);
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Return database statistics.
|
|
61
|
+
*/
|
|
62
|
+
async getStatistics(graphName = '') {
|
|
63
|
+
const metadata = this.ctx.getSessionMetadata();
|
|
64
|
+
const response = await (0, services_1.promisifyCall)(this.ctx.clients.adminService, 'GetStatistics', { graph_name: graphName }, metadata);
|
|
65
|
+
const labelCounts = {};
|
|
66
|
+
const edgeLabelCounts = {};
|
|
67
|
+
if (response.label_counts) {
|
|
68
|
+
for (const [key, value] of Object.entries(response.label_counts)) {
|
|
69
|
+
labelCounts[key] = parseInt(value, 10);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
if (response.edge_label_counts) {
|
|
73
|
+
for (const [key, value] of Object.entries(response.edge_label_counts)) {
|
|
74
|
+
edgeLabelCounts[key] = parseInt(value, 10);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
return {
|
|
78
|
+
nodeCount: parseInt(response.node_count || '0', 10),
|
|
79
|
+
edgeCount: parseInt(response.edge_count || '0', 10),
|
|
80
|
+
labelCounts,
|
|
81
|
+
edgeLabelCounts,
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Invalidate the RBAC permission cache.
|
|
86
|
+
*/
|
|
87
|
+
async invalidatePermissionCache(username = '') {
|
|
88
|
+
const metadata = this.ctx.getSessionMetadata();
|
|
89
|
+
await (0, services_1.promisifyCall)(this.ctx.clients.adminService, 'InvalidatePermissionCache', { username }, metadata);
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* Trigger manual compaction of the database storage.
|
|
93
|
+
*/
|
|
94
|
+
async compact() {
|
|
95
|
+
const metadata = this.ctx.getSessionMetadata();
|
|
96
|
+
const response = await (0, services_1.promisifyCall)(this.ctx.clients.adminService, 'Compact', {}, metadata);
|
|
97
|
+
return {
|
|
98
|
+
success: response.success || false,
|
|
99
|
+
message: response.message || '',
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
/**
|
|
103
|
+
* Wait for the computing engine topology to be ready.
|
|
104
|
+
*/
|
|
105
|
+
async waitForComputeTopology(graphName, timeoutMs = 0) {
|
|
106
|
+
const metadata = this.ctx.getSessionMetadata();
|
|
107
|
+
const response = await (0, services_1.promisifyCall)(this.ctx.clients.adminService, 'WaitForComputeTopology', { graph_name: graphName, timeout_ms: timeoutMs }, metadata);
|
|
108
|
+
return {
|
|
109
|
+
ready: response.ready || false,
|
|
110
|
+
message: response.message || '',
|
|
111
|
+
};
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
exports.AdminService = AdminService;
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin-service.js","sourceRoot":"","sources":["../../src/services/admin-service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Admin service handles administrative operations.\r\n */\r\n\r\nimport { ServiceContext } from './service-context';\r\nimport { CacheStats, CacheType, Statistics, CompactResult, ComputeTopologyResult } from '../types';\r\nimport { promisifyCall } from '../services';\r\nimport { cacheTypeToProto } from './converters';\r\n\r\n/**\r\n * Admin service for administrative operations.\r\n */\r\nexport class AdminService {\r\n  constructor(private ctx: ServiceContext) {}\r\n\r\n  /**\r\n   * Pre-allocate parser instances.\r\n   */\r\n  async warmupParser(count: number): Promise<void> {\r\n    const metadata = this.ctx.getSessionMetadata();\r\n    await promisifyCall(\r\n      this.ctx.clients.adminService,\r\n      'WarmupParser',\r\n      { count },\r\n      metadata\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Return cache statistics.\r\n   */\r\n  async getCacheStats(cacheType: CacheType = CacheType.ALL): Promise<CacheStats> {\r\n    const metadata = this.ctx.getSessionMetadata();\r\n    const response: any = await promisifyCall(\r\n      this.ctx.clients.adminService,\r\n      'GetCacheStats',\r\n      { cache_type: cacheTypeToProto(cacheType) },\r\n      metadata\r\n    );\r\n\r\n    return {\r\n      astStats: response.ast_stats\r\n        ? {\r\n            hits: parseInt(response.ast_stats.hits || '0', 10),\r\n            misses: parseInt(response.ast_stats.misses || '0', 10),\r\n            evictions: parseInt(response.ast_stats.evictions || '0', 10),\r\n            entries: response.ast_stats.entries || 0,\r\n            hitRate: response.ast_stats.hit_rate || 0,\r\n          }\r\n        : undefined,\r\n      planStats: response.plan_stats\r\n        ? {\r\n            size: response.plan_stats.size || 0,\r\n            capacity: response.plan_stats.capacity || 0,\r\n            hits: parseInt(response.plan_stats.hits || '0', 10),\r\n            misses: parseInt(response.plan_stats.misses || '0', 10),\r\n            hitRate: response.plan_stats.hit_rate || 0,\r\n          }\r\n        : undefined,\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Clear the specified cache.\r\n   */\r\n  async clearCache(cacheType: CacheType = CacheType.ALL): Promise<void> {\r\n    const metadata = this.ctx.getSessionMetadata();\r\n    await promisifyCall(\r\n      this.ctx.clients.adminService,\r\n      'ClearCache',\r\n      { cache_type: cacheTypeToProto(cacheType) },\r\n      metadata\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Return database statistics.\r\n   */\r\n  async getStatistics(graphName: string = ''): Promise<Statistics> {\r\n    const metadata = this.ctx.getSessionMetadata();\r\n    const response: any = await promisifyCall(\r\n      this.ctx.clients.adminService,\r\n      'GetStatistics',\r\n      { graph_name: graphName },\r\n      metadata\r\n    );\r\n\r\n    const labelCounts: Record<string, number> = {};\r\n    const edgeLabelCounts: Record<string, number> = {};\r\n\r\n    if (response.label_counts) {\r\n      for (const [key, value] of Object.entries(response.label_counts)) {\r\n        labelCounts[key] = parseInt(value as string, 10);\r\n      }\r\n    }\r\n\r\n    if (response.edge_label_counts) {\r\n      for (const [key, value] of Object.entries(response.edge_label_counts)) {\r\n        edgeLabelCounts[key] = parseInt(value as string, 10);\r\n      }\r\n    }\r\n\r\n    return {\r\n      nodeCount: parseInt(response.node_count || '0', 10),\r\n      edgeCount: parseInt(response.edge_count || '0', 10),\r\n      labelCounts,\r\n      edgeLabelCounts,\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Invalidate the RBAC permission cache.\r\n   */\r\n  async invalidatePermissionCache(username: string = ''): Promise<void> {\r\n    const metadata = this.ctx.getSessionMetadata();\r\n    await promisifyCall(\r\n      this.ctx.clients.adminService,\r\n      'InvalidatePermissionCache',\r\n      { username },\r\n      metadata\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Trigger manual compaction of the database storage.\r\n   */\r\n  async compact(): Promise<CompactResult> {\r\n    const metadata = this.ctx.getSessionMetadata();\r\n    const response: any = await promisifyCall(\r\n      this.ctx.clients.adminService,\r\n      'Compact',\r\n      {},\r\n      metadata\r\n    );\r\n    return {\r\n      success: response.success || false,\r\n      message: response.message || '',\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Wait for the computing engine topology to be ready.\r\n   */\r\n  async waitForComputeTopology(graphName: string, timeoutMs: number = 0): Promise<ComputeTopologyResult> {\r\n    const metadata = this.ctx.getSessionMetadata();\r\n    const response: any = await promisifyCall(\r\n      this.ctx.clients.adminService,\r\n      'WaitForComputeTopology',\r\n      { graph_name: graphName, timeout_ms: timeoutMs },\r\n      metadata\r\n    );\r\n    return {\r\n      ready: response.ready || false,\r\n      message: response.message || '',\r\n    };\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Bulk import service handles bulk import session management.
|
|
3
|
+
*/
|
|
4
|
+
import { ServiceContext } from './service-context';
|
|
5
|
+
import { BulkImportOptions, BulkImportSession, CheckpointResult, EndBulkImportResult, AbortBulkImportResult, BulkImportStatus } from '../types';
|
|
6
|
+
/**
|
|
7
|
+
* Bulk import service for managing bulk import sessions.
|
|
8
|
+
*/
|
|
9
|
+
export declare class BulkImportService {
|
|
10
|
+
private ctx;
|
|
11
|
+
constructor(ctx: ServiceContext);
|
|
12
|
+
/**
|
|
13
|
+
* Start a bulk import session for optimized high-throughput inserts.
|
|
14
|
+
* @param graphName Target graph name
|
|
15
|
+
* @param options Optional bulk import configuration
|
|
16
|
+
*/
|
|
17
|
+
startBulkImport(graphName: string, options?: BulkImportOptions): Promise<BulkImportSession>;
|
|
18
|
+
/** @deprecated Checkpoint is no longer needed. */
|
|
19
|
+
checkpoint(sessionId: string): Promise<CheckpointResult>;
|
|
20
|
+
/**
|
|
21
|
+
* End the bulk import session with a final checkpoint.
|
|
22
|
+
* @param sessionId Bulk import session ID
|
|
23
|
+
*/
|
|
24
|
+
endBulkImport(sessionId: string): Promise<EndBulkImportResult>;
|
|
25
|
+
/**
|
|
26
|
+
* Cancel the bulk import session without final sync.
|
|
27
|
+
* @param sessionId Bulk import session ID
|
|
28
|
+
*/
|
|
29
|
+
abortBulkImport(sessionId: string): Promise<AbortBulkImportResult>;
|
|
30
|
+
/**
|
|
31
|
+
* Return the current status of a bulk import session.
|
|
32
|
+
* @param sessionId Bulk import session ID
|
|
33
|
+
*/
|
|
34
|
+
getBulkImportStatus(sessionId: string): Promise<BulkImportStatus>;
|
|
35
|
+
}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Bulk import service handles bulk import session management.
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.BulkImportService = void 0;
|
|
7
|
+
const services_1 = require("../services");
|
|
8
|
+
/**
|
|
9
|
+
* Bulk import service for managing bulk import sessions.
|
|
10
|
+
*/
|
|
11
|
+
class BulkImportService {
|
|
12
|
+
ctx;
|
|
13
|
+
constructor(ctx) {
|
|
14
|
+
this.ctx = ctx;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Start a bulk import session for optimized high-throughput inserts.
|
|
18
|
+
* @param graphName Target graph name
|
|
19
|
+
* @param options Optional bulk import configuration
|
|
20
|
+
*/
|
|
21
|
+
async startBulkImport(graphName, options) {
|
|
22
|
+
const request = {
|
|
23
|
+
graph_name: graphName,
|
|
24
|
+
};
|
|
25
|
+
if (options) {
|
|
26
|
+
if (options.checkpointEvery !== undefined) {
|
|
27
|
+
request.checkpoint_every = options.checkpointEvery.toString();
|
|
28
|
+
}
|
|
29
|
+
if (options.estimatedNodes !== undefined) {
|
|
30
|
+
request.estimated_nodes = options.estimatedNodes.toString();
|
|
31
|
+
}
|
|
32
|
+
if (options.estimatedEdges !== undefined) {
|
|
33
|
+
request.estimated_edges = options.estimatedEdges.toString();
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
const metadata = this.ctx.getSessionMetadata();
|
|
37
|
+
const response = await (0, services_1.promisifyCall)(this.ctx.clients.bulkImportService, 'StartBulkImport', request, metadata);
|
|
38
|
+
if (!response.success) {
|
|
39
|
+
throw new Error(`Start bulk import failed: ${response.message || 'unknown error'}`);
|
|
40
|
+
}
|
|
41
|
+
return {
|
|
42
|
+
success: true,
|
|
43
|
+
sessionId: response.session_id || '',
|
|
44
|
+
message: response.message || '',
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
/** @deprecated Checkpoint is no longer needed. */
|
|
48
|
+
async checkpoint(sessionId) {
|
|
49
|
+
return {
|
|
50
|
+
success: true,
|
|
51
|
+
recordCount: 0,
|
|
52
|
+
lastCheckpointCount: 0,
|
|
53
|
+
message: 'Checkpoint has been removed; use endBulkImport which performs a final flush',
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* End the bulk import session with a final checkpoint.
|
|
58
|
+
* @param sessionId Bulk import session ID
|
|
59
|
+
*/
|
|
60
|
+
async endBulkImport(sessionId) {
|
|
61
|
+
const request = {
|
|
62
|
+
session_id: sessionId,
|
|
63
|
+
};
|
|
64
|
+
const metadata = this.ctx.getSessionMetadata();
|
|
65
|
+
const response = await (0, services_1.promisifyCall)(this.ctx.clients.bulkImportService, 'EndBulkImport', request, metadata);
|
|
66
|
+
return {
|
|
67
|
+
success: response.success || false,
|
|
68
|
+
totalRecords: parseInt(response.total_records || '0', 10),
|
|
69
|
+
message: response.message || '',
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* Cancel the bulk import session without final sync.
|
|
74
|
+
* @param sessionId Bulk import session ID
|
|
75
|
+
*/
|
|
76
|
+
async abortBulkImport(sessionId) {
|
|
77
|
+
const request = {
|
|
78
|
+
session_id: sessionId,
|
|
79
|
+
};
|
|
80
|
+
const metadata = this.ctx.getSessionMetadata();
|
|
81
|
+
const response = await (0, services_1.promisifyCall)(this.ctx.clients.bulkImportService, 'AbortBulkImport', request, metadata);
|
|
82
|
+
return {
|
|
83
|
+
success: response.success || false,
|
|
84
|
+
message: response.message || '',
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Return the current status of a bulk import session.
|
|
89
|
+
* @param sessionId Bulk import session ID
|
|
90
|
+
*/
|
|
91
|
+
async getBulkImportStatus(sessionId) {
|
|
92
|
+
const request = {
|
|
93
|
+
session_id: sessionId,
|
|
94
|
+
};
|
|
95
|
+
const metadata = this.ctx.getSessionMetadata();
|
|
96
|
+
const response = await (0, services_1.promisifyCall)(this.ctx.clients.bulkImportService, 'GetBulkImportStatus', request, metadata);
|
|
97
|
+
return {
|
|
98
|
+
isActive: response.is_active || false,
|
|
99
|
+
graphName: response.graph_name || '',
|
|
100
|
+
recordCount: parseInt(response.record_count || '0', 10),
|
|
101
|
+
lastCheckpointCount: parseInt(response.last_checkpoint_count || '0', 10),
|
|
102
|
+
createdAt: parseInt(response.created_at || '0', 10),
|
|
103
|
+
lastActivity: parseInt(response.last_activity || '0', 10),
|
|
104
|
+
};
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
exports.BulkImportService = BulkImportService;
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bulk-import-service.js","sourceRoot":"","sources":["../../src/services/bulk-import-service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Bulk import service handles bulk import session management.\r\n */\r\n\r\nimport { ServiceContext } from './service-context';\r\nimport {\r\n  BulkImportOptions,\r\n  BulkImportSession,\r\n  CheckpointResult,\r\n  EndBulkImportResult,\r\n  AbortBulkImportResult,\r\n  BulkImportStatus,\r\n} from '../types';\r\nimport { promisifyCall } from '../services';\r\n\r\n/**\r\n * Bulk import service for managing bulk import sessions.\r\n */\r\nexport class BulkImportService {\r\n  constructor(private ctx: ServiceContext) {}\r\n\r\n  /**\r\n   * Start a bulk import session for optimized high-throughput inserts.\r\n   * @param graphName Target graph name\r\n   * @param options Optional bulk import configuration\r\n   */\r\n  async startBulkImport(graphName: string, options?: BulkImportOptions): Promise<BulkImportSession> {\r\n    const request: any = {\r\n      graph_name: graphName,\r\n    };\r\n\r\n    if (options) {\r\n      if (options.checkpointEvery !== undefined) {\r\n        request.checkpoint_every = options.checkpointEvery.toString();\r\n      }\r\n      if (options.estimatedNodes !== undefined) {\r\n        request.estimated_nodes = options.estimatedNodes.toString();\r\n      }\r\n      if (options.estimatedEdges !== undefined) {\r\n        request.estimated_edges = options.estimatedEdges.toString();\r\n      }\r\n    }\r\n\r\n    const metadata = this.ctx.getSessionMetadata();\r\n    const response: any = await promisifyCall(\r\n      this.ctx.clients.bulkImportService,\r\n      'StartBulkImport',\r\n      request,\r\n      metadata\r\n    );\r\n\r\n    if (!response.success) {\r\n      throw new Error(`Start bulk import failed: ${response.message || 'unknown error'}`);\r\n    }\r\n\r\n    return {\r\n      success: true,\r\n      sessionId: response.session_id || '',\r\n      message: response.message || '',\r\n    };\r\n  }\r\n\r\n  /** @deprecated Checkpoint is no longer needed. */\r\n  async checkpoint(sessionId: string): Promise<CheckpointResult> {\r\n    return {\r\n      success: true,\r\n      recordCount: 0,\r\n      lastCheckpointCount: 0,\r\n      message: 'Checkpoint has been removed; use endBulkImport which performs a final flush',\r\n    };\r\n  }\r\n\r\n  /**\r\n   * End the bulk import session with a final checkpoint.\r\n   * @param sessionId Bulk import session ID\r\n   */\r\n  async endBulkImport(sessionId: string): Promise<EndBulkImportResult> {\r\n    const request = {\r\n      session_id: sessionId,\r\n    };\r\n\r\n    const metadata = this.ctx.getSessionMetadata();\r\n    const response: any = await promisifyCall(\r\n      this.ctx.clients.bulkImportService,\r\n      'EndBulkImport',\r\n      request,\r\n      metadata\r\n    );\r\n\r\n    return {\r\n      success: response.success || false,\r\n      totalRecords: parseInt(response.total_records || '0', 10),\r\n      message: response.message || '',\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Cancel the bulk import session without final sync.\r\n   * @param sessionId Bulk import session ID\r\n   */\r\n  async abortBulkImport(sessionId: string): Promise<AbortBulkImportResult> {\r\n    const request = {\r\n      session_id: sessionId,\r\n    };\r\n\r\n    const metadata = this.ctx.getSessionMetadata();\r\n    const response: any = await promisifyCall(\r\n      this.ctx.clients.bulkImportService,\r\n      'AbortBulkImport',\r\n      request,\r\n      metadata\r\n    );\r\n\r\n    return {\r\n      success: response.success || false,\r\n      message: response.message || '',\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Return the current status of a bulk import session.\r\n   * @param sessionId Bulk import session ID\r\n   */\r\n  async getBulkImportStatus(sessionId: string): Promise<BulkImportStatus> {\r\n    const request = {\r\n      session_id: sessionId,\r\n    };\r\n\r\n    const metadata = this.ctx.getSessionMetadata();\r\n    const response: any = await promisifyCall(\r\n      this.ctx.clients.bulkImportService,\r\n      'GetBulkImportStatus',\r\n      request,\r\n      metadata\r\n    );\r\n\r\n    return {\r\n      isActive: response.is_active || false,\r\n      graphName: response.graph_name || '',\r\n      recordCount: parseInt(response.record_count || '0', 10),\r\n      lastCheckpointCount: parseInt(response.last_checkpoint_count || '0', 10),\r\n      createdAt: parseInt(response.created_at || '0', 10),\r\n      lastActivity: parseInt(response.last_activity || '0', 10),\r\n    };\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Type conversion utilities between gRPC proto types and JavaScript types.
|
|
3
|
+
*/
|
|
4
|
+
import { Response } from '../response';
|
|
5
|
+
import { GraphType, HealthStatus, CacheType, GraphInfo } from '../types';
|
|
6
|
+
import { GqldbConfig } from '../config';
|
|
7
|
+
import { Session } from '../session';
|
|
8
|
+
import { QueryConfig } from '../client';
|
|
9
|
+
/**
|
|
10
|
+
* Build a GQL request from config.
|
|
11
|
+
*/
|
|
12
|
+
export declare function buildGqlRequest(query: string, session: Session | null, config: GqldbConfig, queryConfig?: QueryConfig): any;
|
|
13
|
+
/**
|
|
14
|
+
* Build parameters array for gRPC.
|
|
15
|
+
*/
|
|
16
|
+
export declare function buildParameters(params?: Record<string, any>): any[];
|
|
17
|
+
/**
|
|
18
|
+
* Convert gRPC response to Response object.
|
|
19
|
+
*/
|
|
20
|
+
export declare function convertGqlResponse(grpcResponse: any): Response;
|
|
21
|
+
/**
|
|
22
|
+
* Convert gRPC TypedValue to JS value.
|
|
23
|
+
* Uses the same decoding logic as typedValueToJS for consistency.
|
|
24
|
+
*/
|
|
25
|
+
export declare function convertTypedValue(tv: any): any;
|
|
26
|
+
/**
|
|
27
|
+
* Convert proto properties map to JS object.
|
|
28
|
+
*/
|
|
29
|
+
export declare function convertProtoProperties(protoProps: Record<string, any>): Record<string, any>;
|
|
30
|
+
/**
|
|
31
|
+
* Convert GraphInfo from proto to JS object.
|
|
32
|
+
*/
|
|
33
|
+
export declare function convertGraphInfo(g: any): GraphInfo;
|
|
34
|
+
/**
|
|
35
|
+
* Map GraphType enum to proto string.
|
|
36
|
+
*/
|
|
37
|
+
export declare function graphTypeToProto(graphType: GraphType): string;
|
|
38
|
+
/**
|
|
39
|
+
* Map proto string to GraphType enum.
|
|
40
|
+
*/
|
|
41
|
+
export declare function protoToGraphType(proto: string): GraphType;
|
|
42
|
+
/**
|
|
43
|
+
* Map proto HealthStatus to enum.
|
|
44
|
+
*/
|
|
45
|
+
export declare function protoToHealthStatus(proto: string): HealthStatus;
|
|
46
|
+
/**
|
|
47
|
+
* Map CacheType to proto string.
|
|
48
|
+
*/
|
|
49
|
+
export declare function cacheTypeToProto(cacheType: CacheType): string;
|
|
50
|
+
/**
|
|
51
|
+
* Convert NodeData to proto format.
|
|
52
|
+
*/
|
|
53
|
+
export declare function nodeDataToProto(node: any): any;
|
|
54
|
+
/**
|
|
55
|
+
* Convert EdgeData to proto format.
|
|
56
|
+
*/
|
|
57
|
+
export declare function edgeDataToProto(edge: any): any;
|