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/config.js
ADDED
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Configuration for GQLDB Node.js driver.
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.ConfigBuilder = exports.DEFAULT_CONFIG = void 0;
|
|
7
|
+
exports.validateConfig = validateConfig;
|
|
8
|
+
exports.createConfig = createConfig;
|
|
9
|
+
/** Default configuration values */
|
|
10
|
+
exports.DEFAULT_CONFIG = {
|
|
11
|
+
hosts: ['localhost:9000'],
|
|
12
|
+
timeout: 30000, // 30 seconds (in milliseconds)
|
|
13
|
+
maxRecvSize: 64 * 1024 * 1024, // 64MB
|
|
14
|
+
poolSize: 10,
|
|
15
|
+
healthCheckInterval: 30000, // 30 seconds (in milliseconds)
|
|
16
|
+
retryCount: 3,
|
|
17
|
+
retryDelay: 100, // 100ms
|
|
18
|
+
};
|
|
19
|
+
/** Builder for creating GqldbConfig */
|
|
20
|
+
class ConfigBuilder {
|
|
21
|
+
config = {};
|
|
22
|
+
/** Set the server hosts */
|
|
23
|
+
hosts(...hosts) {
|
|
24
|
+
this.config.hosts = hosts;
|
|
25
|
+
return this;
|
|
26
|
+
}
|
|
27
|
+
/** Set the username for authentication */
|
|
28
|
+
username(username) {
|
|
29
|
+
this.config.username = username;
|
|
30
|
+
return this;
|
|
31
|
+
}
|
|
32
|
+
/** Set the password for authentication */
|
|
33
|
+
password(password) {
|
|
34
|
+
this.config.password = password;
|
|
35
|
+
return this;
|
|
36
|
+
}
|
|
37
|
+
/** Set the default graph */
|
|
38
|
+
defaultGraph(graph) {
|
|
39
|
+
this.config.defaultGraph = graph;
|
|
40
|
+
return this;
|
|
41
|
+
}
|
|
42
|
+
/** Set the query timeout in milliseconds */
|
|
43
|
+
timeout(ms) {
|
|
44
|
+
this.config.timeout = ms;
|
|
45
|
+
return this;
|
|
46
|
+
}
|
|
47
|
+
/** Set the query timeout in seconds (convenience method) */
|
|
48
|
+
timeoutSeconds(seconds) {
|
|
49
|
+
this.config.timeout = seconds * 1000;
|
|
50
|
+
return this;
|
|
51
|
+
}
|
|
52
|
+
/** Set the maximum receive message size */
|
|
53
|
+
maxRecvSize(bytes) {
|
|
54
|
+
this.config.maxRecvSize = bytes;
|
|
55
|
+
return this;
|
|
56
|
+
}
|
|
57
|
+
/** Set TLS options */
|
|
58
|
+
tls(options) {
|
|
59
|
+
this.config.tlsOptions = options;
|
|
60
|
+
return this;
|
|
61
|
+
}
|
|
62
|
+
/** Set the connection pool size per host */
|
|
63
|
+
poolSize(size) {
|
|
64
|
+
this.config.poolSize = size;
|
|
65
|
+
return this;
|
|
66
|
+
}
|
|
67
|
+
/** Set the health check interval in milliseconds */
|
|
68
|
+
healthCheckInterval(ms) {
|
|
69
|
+
this.config.healthCheckInterval = ms;
|
|
70
|
+
return this;
|
|
71
|
+
}
|
|
72
|
+
/** Set the number of retries */
|
|
73
|
+
retryCount(count) {
|
|
74
|
+
this.config.retryCount = count;
|
|
75
|
+
return this;
|
|
76
|
+
}
|
|
77
|
+
/** Set the delay between retries in milliseconds */
|
|
78
|
+
retryDelay(ms) {
|
|
79
|
+
this.config.retryDelay = ms;
|
|
80
|
+
return this;
|
|
81
|
+
}
|
|
82
|
+
/** Build and return the configuration */
|
|
83
|
+
build() {
|
|
84
|
+
const config = {
|
|
85
|
+
hosts: this.config.hosts ?? exports.DEFAULT_CONFIG.hosts,
|
|
86
|
+
username: this.config.username,
|
|
87
|
+
password: this.config.password,
|
|
88
|
+
defaultGraph: this.config.defaultGraph,
|
|
89
|
+
timeout: this.config.timeout ?? exports.DEFAULT_CONFIG.timeout,
|
|
90
|
+
maxRecvSize: this.config.maxRecvSize ?? exports.DEFAULT_CONFIG.maxRecvSize,
|
|
91
|
+
tlsOptions: this.config.tlsOptions,
|
|
92
|
+
poolSize: this.config.poolSize ?? exports.DEFAULT_CONFIG.poolSize,
|
|
93
|
+
healthCheckInterval: this.config.healthCheckInterval ?? exports.DEFAULT_CONFIG.healthCheckInterval,
|
|
94
|
+
retryCount: this.config.retryCount ?? exports.DEFAULT_CONFIG.retryCount,
|
|
95
|
+
retryDelay: this.config.retryDelay ?? exports.DEFAULT_CONFIG.retryDelay,
|
|
96
|
+
};
|
|
97
|
+
validateConfig(config);
|
|
98
|
+
return config;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
exports.ConfigBuilder = ConfigBuilder;
|
|
102
|
+
/** Validate the configuration */
|
|
103
|
+
function validateConfig(config) {
|
|
104
|
+
if (!config.hosts || config.hosts.length === 0) {
|
|
105
|
+
throw new Error('No hosts configured');
|
|
106
|
+
}
|
|
107
|
+
if (config.timeout !== undefined && config.timeout < 0) {
|
|
108
|
+
throw new Error('Invalid timeout value');
|
|
109
|
+
}
|
|
110
|
+
if (config.maxRecvSize !== undefined && config.maxRecvSize <= 0) {
|
|
111
|
+
config.maxRecvSize = exports.DEFAULT_CONFIG.maxRecvSize;
|
|
112
|
+
}
|
|
113
|
+
if (config.poolSize !== undefined && config.poolSize <= 0) {
|
|
114
|
+
config.poolSize = exports.DEFAULT_CONFIG.poolSize;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
/** Create a configuration with defaults */
|
|
118
|
+
function createConfig(options = {}) {
|
|
119
|
+
const config = {
|
|
120
|
+
hosts: options.hosts ?? exports.DEFAULT_CONFIG.hosts,
|
|
121
|
+
username: options.username,
|
|
122
|
+
password: options.password,
|
|
123
|
+
defaultGraph: options.defaultGraph,
|
|
124
|
+
timeout: options.timeout ?? exports.DEFAULT_CONFIG.timeout,
|
|
125
|
+
maxRecvSize: options.maxRecvSize ?? exports.DEFAULT_CONFIG.maxRecvSize,
|
|
126
|
+
tlsOptions: options.tlsOptions,
|
|
127
|
+
poolSize: options.poolSize ?? exports.DEFAULT_CONFIG.poolSize,
|
|
128
|
+
healthCheckInterval: options.healthCheckInterval ?? exports.DEFAULT_CONFIG.healthCheckInterval,
|
|
129
|
+
retryCount: options.retryCount ?? exports.DEFAULT_CONFIG.retryCount,
|
|
130
|
+
retryDelay: options.retryDelay ?? exports.DEFAULT_CONFIG.retryDelay,
|
|
131
|
+
};
|
|
132
|
+
validateConfig(config);
|
|
133
|
+
return config;
|
|
134
|
+
}
|
|
135
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Configuration for GQLDB Node.js driver.\r\n */\r\n\r\nimport * as tls from 'tls';\r\n\r\n/** Configuration options for GqldbClient */\r\nexport interface GqldbConfig {\r\n  /** Server hosts in format \"host:port\" */\r\n  hosts: string[];\r\n  /** Username for authentication */\r\n  username?: string;\r\n  /** Password for authentication */\r\n  password?: string;\r\n  /** Default graph to use */\r\n  defaultGraph?: string;\r\n  /** Query timeout in milliseconds (default 30000ms = 30s) */\r\n  timeout?: number;\r\n  /** Maximum receive message size in bytes (default 64MB) */\r\n  maxRecvSize?: number;\r\n  /** TLS options for secure connections */\r\n  tlsOptions?: tls.ConnectionOptions;\r\n  /** Connection pool size per host */\r\n  poolSize?: number;\r\n  /** Health check interval in milliseconds (default 30000ms = 30s) */\r\n  healthCheckInterval?: number;\r\n  /** Number of retries for failed requests */\r\n  retryCount?: number;\r\n  /** Delay between retries in milliseconds (default 100ms) */\r\n  retryDelay?: number;\r\n}\r\n\r\n/** Default configuration values */\r\nexport const DEFAULT_CONFIG: Required<Omit<GqldbConfig, 'username' | 'password' | 'defaultGraph' | 'tlsOptions'>> = {\r\n  hosts: ['localhost:9000'],\r\n  timeout: 30000, // 30 seconds (in milliseconds)\r\n  maxRecvSize: 64 * 1024 * 1024, // 64MB\r\n  poolSize: 10,\r\n  healthCheckInterval: 30000, // 30 seconds (in milliseconds)\r\n  retryCount: 3,\r\n  retryDelay: 100, // 100ms\r\n};\r\n\r\n/** Builder for creating GqldbConfig */\r\nexport class ConfigBuilder {\r\n  private config: Partial<GqldbConfig> = {};\r\n\r\n  /** Set the server hosts */\r\n  hosts(...hosts: string[]): this {\r\n    this.config.hosts = hosts;\r\n    return this;\r\n  }\r\n\r\n  /** Set the username for authentication */\r\n  username(username: string): this {\r\n    this.config.username = username;\r\n    return this;\r\n  }\r\n\r\n  /** Set the password for authentication */\r\n  password(password: string): this {\r\n    this.config.password = password;\r\n    return this;\r\n  }\r\n\r\n  /** Set the default graph */\r\n  defaultGraph(graph: string): this {\r\n    this.config.defaultGraph = graph;\r\n    return this;\r\n  }\r\n\r\n  /** Set the query timeout in milliseconds */\r\n  timeout(ms: number): this {\r\n    this.config.timeout = ms;\r\n    return this;\r\n  }\r\n\r\n  /** Set the query timeout in seconds (convenience method) */\r\n  timeoutSeconds(seconds: number): this {\r\n    this.config.timeout = seconds * 1000;\r\n    return this;\r\n  }\r\n\r\n  /** Set the maximum receive message size */\r\n  maxRecvSize(bytes: number): this {\r\n    this.config.maxRecvSize = bytes;\r\n    return this;\r\n  }\r\n\r\n  /** Set TLS options */\r\n  tls(options: tls.ConnectionOptions): this {\r\n    this.config.tlsOptions = options;\r\n    return this;\r\n  }\r\n\r\n  /** Set the connection pool size per host */\r\n  poolSize(size: number): this {\r\n    this.config.poolSize = size;\r\n    return this;\r\n  }\r\n\r\n  /** Set the health check interval in milliseconds */\r\n  healthCheckInterval(ms: number): this {\r\n    this.config.healthCheckInterval = ms;\r\n    return this;\r\n  }\r\n\r\n  /** Set the number of retries */\r\n  retryCount(count: number): this {\r\n    this.config.retryCount = count;\r\n    return this;\r\n  }\r\n\r\n  /** Set the delay between retries in milliseconds */\r\n  retryDelay(ms: number): this {\r\n    this.config.retryDelay = ms;\r\n    return this;\r\n  }\r\n\r\n  /** Build and return the configuration */\r\n  build(): GqldbConfig {\r\n    const config: GqldbConfig = {\r\n      hosts: this.config.hosts ?? DEFAULT_CONFIG.hosts,\r\n      username: this.config.username,\r\n      password: this.config.password,\r\n      defaultGraph: this.config.defaultGraph,\r\n      timeout: this.config.timeout ?? DEFAULT_CONFIG.timeout,\r\n      maxRecvSize: this.config.maxRecvSize ?? DEFAULT_CONFIG.maxRecvSize,\r\n      tlsOptions: this.config.tlsOptions,\r\n      poolSize: this.config.poolSize ?? DEFAULT_CONFIG.poolSize,\r\n      healthCheckInterval: this.config.healthCheckInterval ?? DEFAULT_CONFIG.healthCheckInterval,\r\n      retryCount: this.config.retryCount ?? DEFAULT_CONFIG.retryCount,\r\n      retryDelay: this.config.retryDelay ?? DEFAULT_CONFIG.retryDelay,\r\n    };\r\n\r\n    validateConfig(config);\r\n    return config;\r\n  }\r\n}\r\n\r\n/** Validate the configuration */\r\nexport function validateConfig(config: GqldbConfig): void {\r\n  if (!config.hosts || config.hosts.length === 0) {\r\n    throw new Error('No hosts configured');\r\n  }\r\n\r\n  if (config.timeout !== undefined && config.timeout < 0) {\r\n    throw new Error('Invalid timeout value');\r\n  }\r\n\r\n  if (config.maxRecvSize !== undefined && config.maxRecvSize <= 0) {\r\n    config.maxRecvSize = DEFAULT_CONFIG.maxRecvSize;\r\n  }\r\n\r\n  if (config.poolSize !== undefined && config.poolSize <= 0) {\r\n    config.poolSize = DEFAULT_CONFIG.poolSize;\r\n  }\r\n}\r\n\r\n/** Create a configuration with defaults */\r\nexport function createConfig(options: Partial<GqldbConfig> = {}): GqldbConfig {\r\n  const config: GqldbConfig = {\r\n    hosts: options.hosts ?? DEFAULT_CONFIG.hosts,\r\n    username: options.username,\r\n    password: options.password,\r\n    defaultGraph: options.defaultGraph,\r\n    timeout: options.timeout ?? DEFAULT_CONFIG.timeout,\r\n    maxRecvSize: options.maxRecvSize ?? DEFAULT_CONFIG.maxRecvSize,\r\n    tlsOptions: options.tlsOptions,\r\n    poolSize: options.poolSize ?? DEFAULT_CONFIG.poolSize,\r\n    healthCheckInterval: options.healthCheckInterval ?? DEFAULT_CONFIG.healthCheckInterval,\r\n    retryCount: options.retryCount ?? DEFAULT_CONFIG.retryCount,\r\n    retryDelay: options.retryDelay ?? DEFAULT_CONFIG.retryDelay,\r\n  };\r\n\r\n  validateConfig(config);\r\n  return config;\r\n}\r\n"]}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Connection management for GQLDB Node.js driver.
|
|
3
|
+
*/
|
|
4
|
+
import * as grpc from '@grpc/grpc-js';
|
|
5
|
+
import { GqldbConfig } from './config';
|
|
6
|
+
/** Manages a pool of connections to GQLDB servers */
|
|
7
|
+
export declare class ConnectionPool {
|
|
8
|
+
private config;
|
|
9
|
+
private connections;
|
|
10
|
+
private closed;
|
|
11
|
+
private healthCheckTimer?;
|
|
12
|
+
constructor(config: GqldbConfig);
|
|
13
|
+
private initConnections;
|
|
14
|
+
private createConnection;
|
|
15
|
+
/** Get a healthy connection from the pool */
|
|
16
|
+
getConnection(): grpc.Client;
|
|
17
|
+
/** Get a connection for a specific host */
|
|
18
|
+
getConnectionForHost(host: string): grpc.Client;
|
|
19
|
+
private startHealthCheck;
|
|
20
|
+
private checkHealth;
|
|
21
|
+
private reconnect;
|
|
22
|
+
/** Close all connections in the pool */
|
|
23
|
+
close(): void;
|
|
24
|
+
/** Get the number of healthy hosts */
|
|
25
|
+
healthyHostCount(): number;
|
|
26
|
+
/** Get the list of configured hosts */
|
|
27
|
+
hosts(): string[];
|
|
28
|
+
/** Check if the pool is closed */
|
|
29
|
+
isClosed(): boolean;
|
|
30
|
+
}
|
|
@@ -0,0 +1,190 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Connection management for GQLDB Node.js driver.
|
|
4
|
+
*/
|
|
5
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
8
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
9
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
10
|
+
}
|
|
11
|
+
Object.defineProperty(o, k2, desc);
|
|
12
|
+
}) : (function(o, m, k, k2) {
|
|
13
|
+
if (k2 === undefined) k2 = k;
|
|
14
|
+
o[k2] = m[k];
|
|
15
|
+
}));
|
|
16
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
17
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
18
|
+
}) : function(o, v) {
|
|
19
|
+
o["default"] = v;
|
|
20
|
+
});
|
|
21
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
22
|
+
var ownKeys = function(o) {
|
|
23
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
24
|
+
var ar = [];
|
|
25
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
26
|
+
return ar;
|
|
27
|
+
};
|
|
28
|
+
return ownKeys(o);
|
|
29
|
+
};
|
|
30
|
+
return function (mod) {
|
|
31
|
+
if (mod && mod.__esModule) return mod;
|
|
32
|
+
var result = {};
|
|
33
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
34
|
+
__setModuleDefault(result, mod);
|
|
35
|
+
return result;
|
|
36
|
+
};
|
|
37
|
+
})();
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
exports.ConnectionPool = void 0;
|
|
40
|
+
const grpc = __importStar(require("@grpc/grpc-js"));
|
|
41
|
+
const errors_1 = require("./errors");
|
|
42
|
+
/** Manages a pool of connections to GQLDB servers */
|
|
43
|
+
class ConnectionPool {
|
|
44
|
+
config;
|
|
45
|
+
connections = new Map();
|
|
46
|
+
closed = false;
|
|
47
|
+
healthCheckTimer;
|
|
48
|
+
constructor(config) {
|
|
49
|
+
this.config = config;
|
|
50
|
+
this.initConnections();
|
|
51
|
+
this.startHealthCheck();
|
|
52
|
+
}
|
|
53
|
+
initConnections() {
|
|
54
|
+
for (const host of this.config.hosts) {
|
|
55
|
+
try {
|
|
56
|
+
const conn = this.createConnection(host);
|
|
57
|
+
this.connections.set(host, conn);
|
|
58
|
+
}
|
|
59
|
+
catch (e) {
|
|
60
|
+
// Continue with other hosts
|
|
61
|
+
console.error(`Failed to connect to ${host}:`, e);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
if (this.connections.size === 0) {
|
|
65
|
+
throw new errors_1.AllHostsFailedError();
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
createConnection(host) {
|
|
69
|
+
let credentials;
|
|
70
|
+
if (this.config.tlsOptions) {
|
|
71
|
+
credentials = grpc.credentials.createSsl();
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
credentials = grpc.credentials.createInsecure();
|
|
75
|
+
}
|
|
76
|
+
const options = {
|
|
77
|
+
'grpc.max_receive_message_length': this.config.maxRecvSize ?? 4 * 1024 * 1024,
|
|
78
|
+
'grpc.keepalive_time_ms': 30000,
|
|
79
|
+
'grpc.keepalive_timeout_ms': 10000,
|
|
80
|
+
'grpc.keepalive_permit_without_calls': 1,
|
|
81
|
+
};
|
|
82
|
+
// Create a generic client for the channel
|
|
83
|
+
const client = new grpc.Client(host, credentials, options);
|
|
84
|
+
return {
|
|
85
|
+
host,
|
|
86
|
+
client,
|
|
87
|
+
healthy: true,
|
|
88
|
+
lastPing: Date.now(),
|
|
89
|
+
};
|
|
90
|
+
}
|
|
91
|
+
/** Get a healthy connection from the pool */
|
|
92
|
+
getConnection() {
|
|
93
|
+
if (this.closed) {
|
|
94
|
+
throw new errors_1.ConnectionClosedError();
|
|
95
|
+
}
|
|
96
|
+
for (const conn of this.connections.values()) {
|
|
97
|
+
if (conn.healthy) {
|
|
98
|
+
return conn.client;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
throw new errors_1.NoConnectionError();
|
|
102
|
+
}
|
|
103
|
+
/** Get a connection for a specific host */
|
|
104
|
+
getConnectionForHost(host) {
|
|
105
|
+
const conn = this.connections.get(host);
|
|
106
|
+
if (!conn || !conn.healthy) {
|
|
107
|
+
throw new errors_1.NoConnectionError();
|
|
108
|
+
}
|
|
109
|
+
return conn.client;
|
|
110
|
+
}
|
|
111
|
+
startHealthCheck() {
|
|
112
|
+
const interval = this.config.healthCheckInterval ?? 30000;
|
|
113
|
+
if (interval > 0) {
|
|
114
|
+
this.healthCheckTimer = setInterval(() => this.checkHealth(), interval);
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
checkHealth() {
|
|
118
|
+
for (const [host, conn] of this.connections) {
|
|
119
|
+
const state = conn.client.getChannel().getConnectivityState(false);
|
|
120
|
+
const healthy = state === grpc.connectivityState.READY ||
|
|
121
|
+
state === grpc.connectivityState.IDLE;
|
|
122
|
+
conn.healthy = healthy;
|
|
123
|
+
if (healthy) {
|
|
124
|
+
conn.lastPing = Date.now();
|
|
125
|
+
}
|
|
126
|
+
else {
|
|
127
|
+
this.reconnect(host);
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
async reconnect(host) {
|
|
132
|
+
if (this.closed)
|
|
133
|
+
return;
|
|
134
|
+
const oldConn = this.connections.get(host);
|
|
135
|
+
if (oldConn) {
|
|
136
|
+
try {
|
|
137
|
+
oldConn.client.close();
|
|
138
|
+
}
|
|
139
|
+
catch (e) {
|
|
140
|
+
// Ignore
|
|
141
|
+
}
|
|
142
|
+
this.connections.delete(host);
|
|
143
|
+
}
|
|
144
|
+
try {
|
|
145
|
+
const newConn = this.createConnection(host);
|
|
146
|
+
this.connections.set(host, newConn);
|
|
147
|
+
}
|
|
148
|
+
catch (e) {
|
|
149
|
+
// Log and continue
|
|
150
|
+
console.error(`Failed to reconnect to ${host}:`, e);
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
/** Close all connections in the pool */
|
|
154
|
+
close() {
|
|
155
|
+
if (this.closed)
|
|
156
|
+
return;
|
|
157
|
+
this.closed = true;
|
|
158
|
+
if (this.healthCheckTimer) {
|
|
159
|
+
clearInterval(this.healthCheckTimer);
|
|
160
|
+
}
|
|
161
|
+
for (const conn of this.connections.values()) {
|
|
162
|
+
try {
|
|
163
|
+
conn.client.close();
|
|
164
|
+
}
|
|
165
|
+
catch (e) {
|
|
166
|
+
// Ignore
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
this.connections.clear();
|
|
170
|
+
}
|
|
171
|
+
/** Get the number of healthy hosts */
|
|
172
|
+
healthyHostCount() {
|
|
173
|
+
let count = 0;
|
|
174
|
+
for (const conn of this.connections.values()) {
|
|
175
|
+
if (conn.healthy)
|
|
176
|
+
count++;
|
|
177
|
+
}
|
|
178
|
+
return count;
|
|
179
|
+
}
|
|
180
|
+
/** Get the list of configured hosts */
|
|
181
|
+
hosts() {
|
|
182
|
+
return Array.from(this.connections.keys());
|
|
183
|
+
}
|
|
184
|
+
/** Check if the pool is closed */
|
|
185
|
+
isClosed() {
|
|
186
|
+
return this.closed;
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
exports.ConnectionPool = ConnectionPool;
|
|
190
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"connection.js","sourceRoot":"","sources":["../src/connection.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Connection management for GQLDB Node.js driver.\r\n */\r\n\r\nimport * as grpc from '@grpc/grpc-js';\r\nimport { GqldbConfig } from './config';\r\nimport { AllHostsFailedError, ConnectionClosedError, NoConnectionError } from './errors';\r\n\r\n/** Represents a single gRPC connection */\r\ninterface Connection {\r\n  host: string;\r\n  client: grpc.Client;\r\n  healthy: boolean;\r\n  lastPing: number;\r\n}\r\n\r\n/** Manages a pool of connections to GQLDB servers */\r\nexport class ConnectionPool {\r\n  private config: GqldbConfig;\r\n  private connections: Map<string, Connection> = new Map();\r\n  private closed = false;\r\n  private healthCheckTimer?: NodeJS.Timeout;\r\n\r\n  constructor(config: GqldbConfig) {\r\n    this.config = config;\r\n    this.initConnections();\r\n    this.startHealthCheck();\r\n  }\r\n\r\n  private initConnections(): void {\r\n    for (const host of this.config.hosts) {\r\n      try {\r\n        const conn = this.createConnection(host);\r\n        this.connections.set(host, conn);\r\n      } catch (e) {\r\n        // Continue with other hosts\r\n        console.error(`Failed to connect to ${host}:`, e);\r\n      }\r\n    }\r\n\r\n    if (this.connections.size === 0) {\r\n      throw new AllHostsFailedError();\r\n    }\r\n  }\r\n\r\n  private createConnection(host: string): Connection {\r\n    let credentials: grpc.ChannelCredentials;\r\n\r\n    if (this.config.tlsOptions) {\r\n      credentials = grpc.credentials.createSsl();\r\n    } else {\r\n      credentials = grpc.credentials.createInsecure();\r\n    }\r\n\r\n    const options: grpc.ChannelOptions = {\r\n      'grpc.max_receive_message_length': this.config.maxRecvSize ?? 4 * 1024 * 1024,\r\n      'grpc.keepalive_time_ms': 30000,\r\n      'grpc.keepalive_timeout_ms': 10000,\r\n      'grpc.keepalive_permit_without_calls': 1,\r\n    };\r\n\r\n    // Create a generic client for the channel\r\n    const client = new grpc.Client(host, credentials, options);\r\n\r\n    return {\r\n      host,\r\n      client,\r\n      healthy: true,\r\n      lastPing: Date.now(),\r\n    };\r\n  }\r\n\r\n  /** Get a healthy connection from the pool */\r\n  getConnection(): grpc.Client {\r\n    if (this.closed) {\r\n      throw new ConnectionClosedError();\r\n    }\r\n\r\n    for (const conn of this.connections.values()) {\r\n      if (conn.healthy) {\r\n        return conn.client;\r\n      }\r\n    }\r\n\r\n    throw new NoConnectionError();\r\n  }\r\n\r\n  /** Get a connection for a specific host */\r\n  getConnectionForHost(host: string): grpc.Client {\r\n    const conn = this.connections.get(host);\r\n    if (!conn || !conn.healthy) {\r\n      throw new NoConnectionError();\r\n    }\r\n    return conn.client;\r\n  }\r\n\r\n  private startHealthCheck(): void {\r\n    const interval = this.config.healthCheckInterval ?? 30000;\r\n    if (interval > 0) {\r\n      this.healthCheckTimer = setInterval(() => this.checkHealth(), interval);\r\n    }\r\n  }\r\n\r\n  private checkHealth(): void {\r\n    for (const [host, conn] of this.connections) {\r\n      const state = conn.client.getChannel().getConnectivityState(false);\r\n      const healthy = state === grpc.connectivityState.READY ||\r\n                     state === grpc.connectivityState.IDLE;\r\n\r\n      conn.healthy = healthy;\r\n      if (healthy) {\r\n        conn.lastPing = Date.now();\r\n      } else {\r\n        this.reconnect(host);\r\n      }\r\n    }\r\n  }\r\n\r\n  private async reconnect(host: string): Promise<void> {\r\n    if (this.closed) return;\r\n\r\n    const oldConn = this.connections.get(host);\r\n    if (oldConn) {\r\n      try {\r\n        oldConn.client.close();\r\n      } catch (e) {\r\n        // Ignore\r\n      }\r\n      this.connections.delete(host);\r\n    }\r\n\r\n    try {\r\n      const newConn = this.createConnection(host);\r\n      this.connections.set(host, newConn);\r\n    } catch (e) {\r\n      // Log and continue\r\n      console.error(`Failed to reconnect to ${host}:`, e);\r\n    }\r\n  }\r\n\r\n  /** Close all connections in the pool */\r\n  close(): void {\r\n    if (this.closed) return;\r\n\r\n    this.closed = true;\r\n\r\n    if (this.healthCheckTimer) {\r\n      clearInterval(this.healthCheckTimer);\r\n    }\r\n\r\n    for (const conn of this.connections.values()) {\r\n      try {\r\n        conn.client.close();\r\n      } catch (e) {\r\n        // Ignore\r\n      }\r\n    }\r\n\r\n    this.connections.clear();\r\n  }\r\n\r\n  /** Get the number of healthy hosts */\r\n  healthyHostCount(): number {\r\n    let count = 0;\r\n    for (const conn of this.connections.values()) {\r\n      if (conn.healthy) count++;\r\n    }\r\n    return count;\r\n  }\r\n\r\n  /** Get the list of configured hosts */\r\n  hosts(): string[] {\r\n    return Array.from(this.connections.keys());\r\n  }\r\n\r\n  /** Check if the pool is closed */\r\n  isClosed(): boolean {\r\n    return this.closed;\r\n  }\r\n}\r\n"]}
|
package/dist/errors.d.ts
ADDED
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Error definitions for GQLDB Node.js driver.
|
|
3
|
+
*/
|
|
4
|
+
/** Base error class for GQLDB errors */
|
|
5
|
+
export declare class GqldbError extends Error {
|
|
6
|
+
readonly code: number;
|
|
7
|
+
readonly cause?: Error | undefined;
|
|
8
|
+
constructor(message: string, code?: number, cause?: Error | undefined);
|
|
9
|
+
}
|
|
10
|
+
export declare class NoHostsError extends GqldbError {
|
|
11
|
+
constructor();
|
|
12
|
+
}
|
|
13
|
+
export declare class InvalidTimeoutError extends GqldbError {
|
|
14
|
+
constructor();
|
|
15
|
+
}
|
|
16
|
+
export declare class NoConnectionError extends GqldbError {
|
|
17
|
+
constructor();
|
|
18
|
+
}
|
|
19
|
+
export declare class ConnectionClosedError extends GqldbError {
|
|
20
|
+
constructor();
|
|
21
|
+
}
|
|
22
|
+
export declare class ConnectionFailedError extends GqldbError {
|
|
23
|
+
constructor(message?: string, cause?: Error);
|
|
24
|
+
}
|
|
25
|
+
export declare class AllHostsFailedError extends GqldbError {
|
|
26
|
+
constructor();
|
|
27
|
+
}
|
|
28
|
+
export declare class HealthCheckFailedError extends GqldbError {
|
|
29
|
+
constructor();
|
|
30
|
+
}
|
|
31
|
+
export declare class NotLoggedInError extends GqldbError {
|
|
32
|
+
constructor();
|
|
33
|
+
}
|
|
34
|
+
export declare class LoginFailedError extends GqldbError {
|
|
35
|
+
constructor(message?: string, cause?: Error);
|
|
36
|
+
}
|
|
37
|
+
export declare class LogoutFailedError extends GqldbError {
|
|
38
|
+
constructor(message?: string, cause?: Error);
|
|
39
|
+
}
|
|
40
|
+
export declare class SessionExpiredError extends GqldbError {
|
|
41
|
+
constructor();
|
|
42
|
+
}
|
|
43
|
+
export declare class InvalidSessionError extends GqldbError {
|
|
44
|
+
constructor();
|
|
45
|
+
}
|
|
46
|
+
export declare class NoTransactionError extends GqldbError {
|
|
47
|
+
constructor();
|
|
48
|
+
}
|
|
49
|
+
export declare class TransactionFailedError extends GqldbError {
|
|
50
|
+
constructor(message?: string, cause?: Error);
|
|
51
|
+
}
|
|
52
|
+
export declare class TransactionNotFoundError extends GqldbError {
|
|
53
|
+
constructor();
|
|
54
|
+
}
|
|
55
|
+
export declare class TransactionAlreadyOpenError extends GqldbError {
|
|
56
|
+
constructor();
|
|
57
|
+
}
|
|
58
|
+
export declare class QueryFailedError extends GqldbError {
|
|
59
|
+
constructor(message?: string, cause?: Error);
|
|
60
|
+
}
|
|
61
|
+
export declare class QueryTimeoutError extends GqldbError {
|
|
62
|
+
constructor();
|
|
63
|
+
}
|
|
64
|
+
export declare class InvalidQueryError extends GqldbError {
|
|
65
|
+
constructor(message?: string);
|
|
66
|
+
}
|
|
67
|
+
export declare class EmptyQueryError extends GqldbError {
|
|
68
|
+
constructor();
|
|
69
|
+
}
|
|
70
|
+
export declare class GraphNotFoundError extends GqldbError {
|
|
71
|
+
constructor(graphName?: string);
|
|
72
|
+
}
|
|
73
|
+
export declare class GraphExistsError extends GqldbError {
|
|
74
|
+
constructor(graphName?: string);
|
|
75
|
+
}
|
|
76
|
+
export declare class CreateGraphFailedError extends GqldbError {
|
|
77
|
+
constructor(message?: string, cause?: Error);
|
|
78
|
+
}
|
|
79
|
+
export declare class DropGraphFailedError extends GqldbError {
|
|
80
|
+
constructor(message?: string, cause?: Error);
|
|
81
|
+
}
|
|
82
|
+
export declare class InsertFailedError extends GqldbError {
|
|
83
|
+
constructor(message?: string, cause?: Error);
|
|
84
|
+
}
|
|
85
|
+
export declare class DeleteFailedError extends GqldbError {
|
|
86
|
+
constructor(message?: string, cause?: Error);
|
|
87
|
+
}
|
|
88
|
+
export declare class ExportFailedError extends GqldbError {
|
|
89
|
+
constructor(message?: string, cause?: Error);
|
|
90
|
+
}
|
|
91
|
+
export declare class InvalidTypeError extends GqldbError {
|
|
92
|
+
constructor(message?: string);
|
|
93
|
+
}
|
|
94
|
+
export declare class TypeConversionError extends GqldbError {
|
|
95
|
+
constructor(message?: string);
|
|
96
|
+
}
|
|
97
|
+
export declare class UnsupportedTypeError extends GqldbError {
|
|
98
|
+
constructor(typeName?: string);
|
|
99
|
+
}
|