@ultipa-graph/ultipa-driver 5.1.4-s5.1 → 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 -5
- package/dist/index.js +88 -39
- 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 -5
- package/dist/types/index.js +36 -37
- 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 +40 -53
- package/dist/connection/connection.final.d.ts +0 -14
- package/dist/connection/connection.final.js +0 -96
- package/dist/connection/connection.final.js.map +0 -1
- package/dist/connection/connection.pool.d.ts +0 -21
- package/dist/connection/connection.pool.js +0 -103
- package/dist/connection/connection.pool.js.map +0 -1
- package/dist/connection/extra/base.extra.d.ts +0 -18
- package/dist/connection/extra/base.extra.js +0 -111
- package/dist/connection/extra/base.extra.js.map +0 -1
- package/dist/connection/extra/batch.insert.extra.d.ts +0 -58
- package/dist/connection/extra/batch.insert.extra.js +0 -353
- package/dist/connection/extra/batch.insert.extra.js.map +0 -1
- package/dist/connection/extra/connection.base.d.ts +0 -112
- package/dist/connection/extra/connection.base.js +0 -528
- package/dist/connection/extra/connection.base.js.map +0 -1
- package/dist/connection/extra/connection.d.ts +0 -17
- package/dist/connection/extra/connection.js +0 -44
- package/dist/connection/extra/connection.js.map +0 -1
- package/dist/connection/extra/graph.extra.d.ts +0 -54
- package/dist/connection/extra/graph.extra.js +0 -151
- package/dist/connection/extra/graph.extra.js.map +0 -1
- package/dist/connection/extra/hdc.extra.d.ts +0 -89
- package/dist/connection/extra/hdc.extra.js +0 -322
- package/dist/connection/extra/hdc.extra.js.map +0 -1
- package/dist/connection/extra/index.extra.d.ts +0 -102
- package/dist/connection/extra/index.extra.js +0 -210
- package/dist/connection/extra/index.extra.js.map +0 -1
- package/dist/connection/extra/job.extra.d.ts +0 -32
- package/dist/connection/extra/job.extra.js +0 -122
- package/dist/connection/extra/job.extra.js.map +0 -1
- package/dist/connection/extra/policy.extra.d.ts +0 -32
- package/dist/connection/extra/policy.extra.js +0 -114
- package/dist/connection/extra/policy.extra.js.map +0 -1
- package/dist/connection/extra/privilege.extra.d.ts +0 -8
- package/dist/connection/extra/privilege.extra.js +0 -20
- package/dist/connection/extra/privilege.extra.js.map +0 -1
- package/dist/connection/extra/property.extra.d.ts +0 -66
- package/dist/connection/extra/property.extra.js +0 -190
- package/dist/connection/extra/property.extra.js.map +0 -1
- package/dist/connection/extra/schema.extra.d.ts +0 -108
- package/dist/connection/extra/schema.extra.js +0 -253
- package/dist/connection/extra/schema.extra.js.map +0 -1
- package/dist/connection/extra/user.extra.d.ts +0 -28
- package/dist/connection/extra/user.extra.js +0 -91
- package/dist/connection/extra/user.extra.js.map +0 -1
- package/dist/connection/index.d.ts +0 -5
- package/dist/connection/index.js +0 -13
- package/dist/connection/index.js.map +0 -1
- package/dist/connection/network.manager.d.ts +0 -28
- package/dist/connection/network.manager.js +0 -179
- package/dist/connection/network.manager.js.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/printers/alias.d.ts +0 -2
- package/dist/printers/alias.js +0 -39
- package/dist/printers/alias.js.map +0 -1
- package/dist/printers/any.d.ts +0 -2
- package/dist/printers/any.js +0 -63
- package/dist/printers/any.js.map +0 -1
- package/dist/printers/array.aio.d.ts +0 -3
- package/dist/printers/array.aio.js +0 -259
- package/dist/printers/array.aio.js.map +0 -1
- package/dist/printers/edge.d.ts +0 -5
- package/dist/printers/edge.js +0 -78
- package/dist/printers/edge.js.map +0 -1
- package/dist/printers/explain.plan.d.ts +0 -2
- package/dist/printers/explain.plan.js +0 -46
- package/dist/printers/explain.plan.js.map +0 -1
- package/dist/printers/index.d.ts +0 -24
- package/dist/printers/index.js +0 -43
- package/dist/printers/index.js.map +0 -1
- package/dist/printers/node.d.ts +0 -5
- package/dist/printers/node.js +0 -77
- package/dist/printers/node.js.map +0 -1
- package/dist/printers/path.d.ts +0 -3
- package/dist/printers/path.js +0 -62
- package/dist/printers/path.js.map +0 -1
- package/dist/printers/status.d.ts +0 -3
- package/dist/printers/status.js +0 -68
- package/dist/printers/status.js.map +0 -1
- package/dist/printers/table.d.ts +0 -2
- package/dist/printers/table.js +0 -56
- package/dist/printers/table.js.map +0 -1
- package/dist/proto/tmp.js +0 -366
- package/dist/proto/ultipa_grpc_pb.d.ts +0 -258
- package/dist/proto/ultipa_grpc_pb.js +0 -366
- package/dist/proto/ultipa_grpc_pb.js.map +0 -1
- package/dist/proto/ultipa_pb.d.ts +0 -1
- package/dist/proto/ultipa_pb.js +0 -11002
- package/dist/proto/ultipa_pb.js.map +0 -1
- package/dist/types/index.js.map +0 -1
- package/dist/types/types.algos.params.d.ts +0 -545
- package/dist/types/types.algos.params.js +0 -16
- package/dist/types/types.algos.params.js.map +0 -1
- package/dist/types/types.d.ts +0 -1204
- package/dist/types/types.extra.d.ts +0 -146
- package/dist/types/types.extra.js +0 -27
- package/dist/types/types.extra.js.map +0 -1
- package/dist/types/types.js +0 -1596
- package/dist/types/types.js.map +0 -1
- package/dist/types/util.d.ts +0 -15
- package/dist/types/util.js +0 -136
- package/dist/types/util.js.map +0 -1
- package/dist/utils/common.d.ts +0 -3
- package/dist/utils/common.js +0 -22
- package/dist/utils/common.js.map +0 -1
- package/dist/utils/format.d.ts +0 -45
- package/dist/utils/format.js +0 -877
- package/dist/utils/format.js.map +0 -1
- package/dist/utils/index.d.ts +0 -10
- package/dist/utils/index.js +0 -30
- package/dist/utils/index.js.map +0 -1
- package/dist/utils/property.d.ts +0 -18
- package/dist/utils/property.js +0 -153
- package/dist/utils/property.js.map +0 -1
- package/dist/utils/serialize/commont.d.ts +0 -12
- package/dist/utils/serialize/commont.js +0 -46
- package/dist/utils/serialize/commont.js.map +0 -1
- package/dist/utils/serialize/deserialize.d.ts +0 -9
- package/dist/utils/serialize/deserialize.js +0 -166
- package/dist/utils/serialize/deserialize.js.map +0 -1
- package/dist/utils/serialize/null.d.ts +0 -25
- package/dist/utils/serialize/null.js +0 -136
- package/dist/utils/serialize/null.js.map +0 -1
- package/dist/utils/serialize/serialize.d.ts +0 -10
- package/dist/utils/serialize/serialize.js +0 -144
- package/dist/utils/serialize/serialize.js.map +0 -1
- package/dist/utils/stream.helper.d.ts +0 -10
- package/dist/utils/stream.helper.js +0 -71
- package/dist/utils/stream.helper.js.map +0 -1
- package/dist/utils/time.record.d.ts +0 -15
- package/dist/utils/time.record.js +0 -52
- package/dist/utils/time.record.js.map +0 -1
- package/dist/utils/ultipa.datetime.d.ts +0 -14
- package/dist/utils/ultipa.datetime.js +0 -160
- package/dist/utils/ultipa.datetime.js.map +0 -1
- package/dist/utils/uql-maker.d.ts +0 -165
- package/dist/utils/uql-maker.js +0 -402
- package/dist/utils/uql-maker.js.map +0 -1
- package/dist/utils/uql.parse.d.ts +0 -27
- package/dist/utils/uql.parse.js +0 -205
- package/dist/utils/uql.parse.js.map +0 -1
- package/readme.md +0 -65
- package/src/proto/build.sh +0 -41
- package/src/proto/build_windows.sh +0 -40
- package/src/proto/ultipa.proto +0 -492
- package/src/proto/ultipa_grpc_pb.d.ts +0 -92
- package/src/proto/ultipa_grpc_pb.js +0 -414
- package/src/proto/ultipa_pb.d.ts +0 -1806
- package/src/proto/ultipa_pb.js +0 -13499
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Numeric type wrappers for explicit type specification.
|
|
3
|
+
*/
|
|
4
|
+
/** Wrapper for explicit 32-bit signed integer */
|
|
5
|
+
export declare class Int32 {
|
|
6
|
+
readonly value: number;
|
|
7
|
+
constructor(value: number);
|
|
8
|
+
}
|
|
9
|
+
/** Wrapper for explicit 32-bit unsigned integer */
|
|
10
|
+
export declare class UInt32 {
|
|
11
|
+
readonly value: number;
|
|
12
|
+
constructor(value: number);
|
|
13
|
+
}
|
|
14
|
+
/** Wrapper for explicit 32-bit float */
|
|
15
|
+
export declare class Float32 {
|
|
16
|
+
readonly value: number;
|
|
17
|
+
constructor(value: number);
|
|
18
|
+
}
|
|
19
|
+
/** Wrapper for explicit 64-bit unsigned integer */
|
|
20
|
+
export declare class UInt64 {
|
|
21
|
+
readonly value: bigint;
|
|
22
|
+
constructor(value: bigint);
|
|
23
|
+
}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Numeric type wrappers for explicit type specification.
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.UInt64 = exports.Float32 = exports.UInt32 = exports.Int32 = void 0;
|
|
7
|
+
/** Wrapper for explicit 32-bit signed integer */
|
|
8
|
+
class Int32 {
|
|
9
|
+
value;
|
|
10
|
+
constructor(value) {
|
|
11
|
+
this.value = value;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
exports.Int32 = Int32;
|
|
15
|
+
/** Wrapper for explicit 32-bit unsigned integer */
|
|
16
|
+
class UInt32 {
|
|
17
|
+
value;
|
|
18
|
+
constructor(value) {
|
|
19
|
+
this.value = value;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
exports.UInt32 = UInt32;
|
|
23
|
+
/** Wrapper for explicit 32-bit float */
|
|
24
|
+
class Float32 {
|
|
25
|
+
value;
|
|
26
|
+
constructor(value) {
|
|
27
|
+
this.value = value;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
exports.Float32 = Float32;
|
|
31
|
+
/** Wrapper for explicit 64-bit unsigned integer */
|
|
32
|
+
class UInt64 {
|
|
33
|
+
value;
|
|
34
|
+
constructor(value) {
|
|
35
|
+
this.value = value;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
exports.UInt64 = UInt64;
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid3JhcHBlcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHlwZXMvd3JhcHBlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOztHQUVHOzs7QUFFSCxpREFBaUQ7QUFDakQsTUFBYSxLQUFLO0lBQ1k7SUFBNUIsWUFBNEIsS0FBYTtRQUFiLFVBQUssR0FBTCxLQUFLLENBQVE7SUFBRyxDQUFDO0NBQzlDO0FBRkQsc0JBRUM7QUFFRCxtREFBbUQ7QUFDbkQsTUFBYSxNQUFNO0lBQ1c7SUFBNUIsWUFBNEIsS0FBYTtRQUFiLFVBQUssR0FBTCxLQUFLLENBQVE7SUFBRyxDQUFDO0NBQzlDO0FBRkQsd0JBRUM7QUFFRCx3Q0FBd0M7QUFDeEMsTUFBYSxPQUFPO0lBQ1U7SUFBNUIsWUFBNEIsS0FBYTtRQUFiLFVBQUssR0FBTCxLQUFLLENBQVE7SUFBRyxDQUFDO0NBQzlDO0FBRkQsMEJBRUM7QUFFRCxtREFBbUQ7QUFDbkQsTUFBYSxNQUFNO0lBQ1c7SUFBNUIsWUFBNEIsS0FBYTtRQUFiLFVBQUssR0FBTCxLQUFLLENBQVE7SUFBRyxDQUFDO0NBQzlDO0FBRkQsd0JBRUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogTnVtZXJpYyB0eXBlIHdyYXBwZXJzIGZvciBleHBsaWNpdCB0eXBlIHNwZWNpZmljYXRpb24uXHJcbiAqL1xyXG5cclxuLyoqIFdyYXBwZXIgZm9yIGV4cGxpY2l0IDMyLWJpdCBzaWduZWQgaW50ZWdlciAqL1xyXG5leHBvcnQgY2xhc3MgSW50MzIge1xyXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyByZWFkb25seSB2YWx1ZTogbnVtYmVyKSB7fVxyXG59XHJcblxyXG4vKiogV3JhcHBlciBmb3IgZXhwbGljaXQgMzItYml0IHVuc2lnbmVkIGludGVnZXIgKi9cclxuZXhwb3J0IGNsYXNzIFVJbnQzMiB7XHJcbiAgY29uc3RydWN0b3IocHVibGljIHJlYWRvbmx5IHZhbHVlOiBudW1iZXIpIHt9XHJcbn1cclxuXHJcbi8qKiBXcmFwcGVyIGZvciBleHBsaWNpdCAzMi1iaXQgZmxvYXQgKi9cclxuZXhwb3J0IGNsYXNzIEZsb2F0MzIge1xyXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyByZWFkb25seSB2YWx1ZTogbnVtYmVyKSB7fVxyXG59XHJcblxyXG4vKiogV3JhcHBlciBmb3IgZXhwbGljaXQgNjQtYml0IHVuc2lnbmVkIGludGVnZXIgKi9cclxuZXhwb3J0IGNsYXNzIFVJbnQ2NCB7XHJcbiAgY29uc3RydWN0b3IocHVibGljIHJlYWRvbmx5IHZhbHVlOiBiaWdpbnQpIHt9XHJcbn1cclxuIl19
|
package/dist/types.d.ts
ADDED
package/dist/types.js
ADDED
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Type definitions for GQLDB Node.js driver.
|
|
4
|
+
*
|
|
5
|
+
* This file re-exports all types from the types/ subdirectory for backward compatibility.
|
|
6
|
+
* @deprecated Import directly from types/ subdirectory for better tree-shaking.
|
|
7
|
+
*/
|
|
8
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
9
|
+
if (k2 === undefined) k2 = k;
|
|
10
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
11
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
12
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
13
|
+
}
|
|
14
|
+
Object.defineProperty(o, k2, desc);
|
|
15
|
+
}) : (function(o, m, k, k2) {
|
|
16
|
+
if (k2 === undefined) k2 = k;
|
|
17
|
+
o[k2] = m[k];
|
|
18
|
+
}));
|
|
19
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
20
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
21
|
+
};
|
|
22
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
23
|
+
__exportStar(require("./types/index"), exports);
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7OztHQUtHOzs7Ozs7Ozs7Ozs7Ozs7O0FBRUgsZ0RBQThCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIFR5cGUgZGVmaW5pdGlvbnMgZm9yIEdRTERCIE5vZGUuanMgZHJpdmVyLlxyXG4gKlxyXG4gKiBUaGlzIGZpbGUgcmUtZXhwb3J0cyBhbGwgdHlwZXMgZnJvbSB0aGUgdHlwZXMvIHN1YmRpcmVjdG9yeSBmb3IgYmFja3dhcmQgY29tcGF0aWJpbGl0eS5cclxuICogQGRlcHJlY2F0ZWQgSW1wb3J0IGRpcmVjdGx5IGZyb20gdHlwZXMvIHN1YmRpcmVjdG9yeSBmb3IgYmV0dGVyIHRyZWUtc2hha2luZy5cclxuICovXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL3R5cGVzL2luZGV4JztcclxuIl19
|
package/package.json
CHANGED
|
@@ -1,63 +1,50 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ultipa-graph/ultipa-driver",
|
|
3
|
-
"version": "
|
|
4
|
-
"description": "NodeJS SDK for
|
|
5
|
-
"keywords": [
|
|
6
|
-
"ultipa",
|
|
7
|
-
"graph database",
|
|
8
|
-
"UQL",
|
|
9
|
-
"GQL",
|
|
10
|
-
"SDK",
|
|
11
|
-
"driver"
|
|
12
|
-
],
|
|
3
|
+
"version": "6.0.0",
|
|
4
|
+
"description": "NodeJS SDK for Ultipa GQL",
|
|
13
5
|
"main": "dist/index.js",
|
|
6
|
+
"types": "dist/index.d.ts",
|
|
14
7
|
"scripts": {
|
|
15
|
-
"build": "
|
|
16
|
-
"
|
|
17
|
-
"
|
|
18
|
-
"
|
|
19
|
-
"test": "
|
|
20
|
-
"
|
|
21
|
-
"
|
|
22
|
-
"
|
|
23
|
-
"
|
|
8
|
+
"build": "tsc -p tsconfig.build.json && npm run copy-proto",
|
|
9
|
+
"copy-proto": "node -e \"require('fs').mkdirSync('dist/proto', {recursive: true}); require('fs').copyFileSync('src/proto/gqldb.proto', 'dist/proto/gqldb.proto');\"",
|
|
10
|
+
"sync-proto": "node -e \"require('fs').copyFileSync('../proto/gqldb.proto', 'src/proto/gqldb.proto');\"",
|
|
11
|
+
"generate": "./generate.sh",
|
|
12
|
+
"test": "jest",
|
|
13
|
+
"test:unit": "jest tests/unit",
|
|
14
|
+
"test:integration": "jest tests/integration",
|
|
15
|
+
"test:coverage": "jest --coverage",
|
|
16
|
+
"lint": "eslint src/**/*.ts",
|
|
17
|
+
"prepublishOnly": "npm run build"
|
|
24
18
|
},
|
|
25
|
-
"repository": {
|
|
26
|
-
"type": "git",
|
|
27
|
-
"url": "git@repo.ultipa.com:SDKS/ultipa-node-sdk.git"
|
|
28
|
-
},
|
|
29
|
-
"files": [
|
|
30
|
-
"dist/**/*",
|
|
31
|
-
"src/proto/**/*"
|
|
32
|
-
],
|
|
33
|
-
"author": "jiansong ZHANG",
|
|
34
|
-
"license": "ISC",
|
|
35
19
|
"dependencies": {
|
|
36
|
-
"@grpc/grpc-js": "1.
|
|
37
|
-
"
|
|
38
|
-
"
|
|
39
|
-
"
|
|
40
|
-
"grpc-tools": "1.11.3",
|
|
41
|
-
"lodash": "^4.17.15",
|
|
42
|
-
"md5": "^2.3.0",
|
|
43
|
-
"moment-timezone": "^0.5.33",
|
|
44
|
-
"print-tree": "^0.1.5",
|
|
45
|
-
"ts-protoc-gen": "^0.15.0",
|
|
46
|
-
"typescript": "^4.8.4"
|
|
20
|
+
"@grpc/grpc-js": "^1.9.0",
|
|
21
|
+
"@grpc/proto-loader": "^0.8.0",
|
|
22
|
+
"cli-table3": "^0.6.5",
|
|
23
|
+
"google-protobuf": "^3.21.0"
|
|
47
24
|
},
|
|
48
25
|
"devDependencies": {
|
|
49
|
-
"@types/
|
|
50
|
-
"@types/
|
|
51
|
-
"@types/
|
|
52
|
-
"
|
|
53
|
-
"
|
|
54
|
-
"
|
|
55
|
-
"
|
|
56
|
-
"
|
|
57
|
-
"
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
"
|
|
61
|
-
|
|
26
|
+
"@types/google-protobuf": "^3.15.0",
|
|
27
|
+
"@types/jest": "^29.5.0",
|
|
28
|
+
"@types/node": "^20.10.0",
|
|
29
|
+
"grpc_tools_node_protoc_ts": "^5.3.0",
|
|
30
|
+
"grpc-tools": "^1.12.0",
|
|
31
|
+
"jest": "^29.7.0",
|
|
32
|
+
"jest-junit": "^16.0.0",
|
|
33
|
+
"ts-jest": "^29.1.0",
|
|
34
|
+
"typescript": "^5.3.0"
|
|
35
|
+
},
|
|
36
|
+
"files": [
|
|
37
|
+
"dist/**/*"
|
|
38
|
+
],
|
|
39
|
+
"keywords": [
|
|
40
|
+
"gqldb",
|
|
41
|
+
"graph",
|
|
42
|
+
"database",
|
|
43
|
+
"grpc",
|
|
44
|
+
"driver"
|
|
45
|
+
],
|
|
46
|
+
"license": "MIT",
|
|
47
|
+
"engines": {
|
|
48
|
+
"node": ">=18.0.0"
|
|
62
49
|
}
|
|
63
50
|
}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { Connection } from "./extra/connection";
|
|
2
|
-
import { UltipaConfig } from "../types/types";
|
|
3
|
-
/**
|
|
4
|
-
* Extra api
|
|
5
|
-
*/
|
|
6
|
-
export declare class ConnectionFinal extends Connection {
|
|
7
|
-
testConnectResult: boolean;
|
|
8
|
-
setGraph(graphName: string): void;
|
|
9
|
-
}
|
|
10
|
-
export declare class UltipaDriver extends ConnectionFinal {
|
|
11
|
-
private connectionPool;
|
|
12
|
-
constructor(config: UltipaConfig);
|
|
13
|
-
setGraph(graphName: string): void;
|
|
14
|
-
}
|
|
@@ -1,96 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.UltipaDriver = exports.ConnectionFinal = void 0;
|
|
7
|
-
const connection_1 = require("./extra/connection");
|
|
8
|
-
const connection_pool_1 = require("./connection.pool");
|
|
9
|
-
const fs_1 = __importDefault(require("fs"));
|
|
10
|
-
/**
|
|
11
|
-
* Extra api
|
|
12
|
-
*/
|
|
13
|
-
class ConnectionFinal extends connection_1.Connection {
|
|
14
|
-
testConnectResult;
|
|
15
|
-
setGraph(graphName) {
|
|
16
|
-
this.defaultConfig.defaultGraph = graphName;
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
exports.ConnectionFinal = ConnectionFinal;
|
|
20
|
-
class UltipaDriver extends ConnectionFinal {
|
|
21
|
-
// private hosts: string[]
|
|
22
|
-
// private connections: Map<string, ConnectionFinal> = new Map();
|
|
23
|
-
connectionPool;
|
|
24
|
-
constructor(config) {
|
|
25
|
-
let crt;
|
|
26
|
-
if (config.crt && config.crt.length !== 0) {
|
|
27
|
-
crt = fs_1.default.readFileSync(config.crt);
|
|
28
|
-
}
|
|
29
|
-
super(config.hosts[0], config.username, config.password, crt, config);
|
|
30
|
-
this.connectionPool = new connection_pool_1.ConnectionPool(config.hosts, config.username, config.password, crt, config);
|
|
31
|
-
}
|
|
32
|
-
setGraph(graphName) {
|
|
33
|
-
this.defaultConfig.defaultGraph = graphName;
|
|
34
|
-
this.connectionPool.setGraph(graphName);
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
exports.UltipaDriver = UltipaDriver;
|
|
38
|
-
// export class UltipaDriver extends ConnectionFinal {
|
|
39
|
-
// private _instance: ConnectionFinal = null;
|
|
40
|
-
// private _initPromise: Promise<ConnectionFinal> = null;
|
|
41
|
-
// constructor(config: UltipaConfig) {
|
|
42
|
-
// let crt: Buffer;
|
|
43
|
-
// if (config.crt && config.crt.length !== 0) {
|
|
44
|
-
// crt = fs.readFileSync(config.crt)
|
|
45
|
-
// }
|
|
46
|
-
// super(config.hosts[0], config.username, config.password,
|
|
47
|
-
// crt,
|
|
48
|
-
// config);
|
|
49
|
-
// function withTimeout(promise: Promise<ConnectionFinal>, ms: number): Promise<ConnectionFinal> {
|
|
50
|
-
// const timeoutPromise = new Promise<ConnectionFinal>((_, reject) => {
|
|
51
|
-
// const timeoutId = setTimeout(() => {
|
|
52
|
-
// clearTimeout(timeoutId);
|
|
53
|
-
// reject(new Error('Connection timeout'));
|
|
54
|
-
// }, ms);
|
|
55
|
-
// });
|
|
56
|
-
// return Promise.race([promise, timeoutPromise]);
|
|
57
|
-
// }
|
|
58
|
-
// return new Proxy(this, {
|
|
59
|
-
// get: (target: UltipaDriver, prop: string) => {
|
|
60
|
-
// if (typeof target[prop] === 'function') {
|
|
61
|
-
// return target[prop].bind(target);
|
|
62
|
-
// }
|
|
63
|
-
// if (prop in target) {
|
|
64
|
-
// return target[prop];
|
|
65
|
-
// }
|
|
66
|
-
// return async (...args: any[]) => {
|
|
67
|
-
// if (!target._initPromise) {
|
|
68
|
-
// target._initPromise = (async () => {
|
|
69
|
-
// const pool = new ConnectionPool(
|
|
70
|
-
// config.hosts,
|
|
71
|
-
// config.username,
|
|
72
|
-
// config.password,
|
|
73
|
-
// crt,
|
|
74
|
-
// config
|
|
75
|
-
// );
|
|
76
|
-
// target._instance = await withTimeout(
|
|
77
|
-
// pool.getActive(),
|
|
78
|
-
// config?.timeout * 1000 || Number.MAX_SAFE_INTEGER
|
|
79
|
-
// );
|
|
80
|
-
// return target._instance;
|
|
81
|
-
// })();
|
|
82
|
-
// }
|
|
83
|
-
// try {
|
|
84
|
-
// await target._initPromise;
|
|
85
|
-
// return target._instance[prop](...args);
|
|
86
|
-
// } catch (error) {
|
|
87
|
-
// target._initPromise = null;
|
|
88
|
-
// target._instance = null;
|
|
89
|
-
// throw error;
|
|
90
|
-
// }
|
|
91
|
-
// };
|
|
92
|
-
// }
|
|
93
|
-
// });
|
|
94
|
-
// }
|
|
95
|
-
// }
|
|
96
|
-
//# sourceMappingURL=connection.final.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"connection.final.js","sourceRoot":"","sources":["../../src/connection/connection.final.ts"],"names":[],"mappings":";;;;;;AACA,mDAA+C;AAE/C,uDAAkD;AAElD,4CAAmB;AAEnB;;GAEG;AACH,MAAa,eAAgB,SAAQ,uBAAU;IAC3C,iBAAiB,CAAS;IAC1B,QAAQ,CAAC,SAAiB;QACtB,IAAI,CAAC,aAAa,CAAC,YAAY,GAAG,SAAS,CAAA;IAC/C,CAAC;CACJ;AALD,0CAKC;AAED,MAAa,YAAa,SAAQ,eAAe;IAC7C,0BAA0B;IAC1B,iEAAiE;IACzD,cAAc,CAAiB;IACvC,YAAY,MAAoB;QAC5B,IAAI,GAAW,CAAC;QAChB,IAAI,MAAM,CAAC,GAAG,IAAI,MAAM,CAAC,GAAG,CAAC,MAAM,KAAK,CAAC,EAAE;YACvC,GAAG,GAAG,YAAE,CAAC,YAAY,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;SACpC;QACD,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,QAAQ,EACnD,GAAG,EACH,MAAM,CAAC,CAAC;QACZ,IAAI,CAAC,cAAc,GAAG,IAAI,gCAAc,CACpC,MAAM,CAAC,KAAK,EACZ,MAAM,CAAC,QAAQ,EACf,MAAM,CAAC,QAAQ,EACf,GAAG,EACH,MAAM,CACT,CAAC;IACN,CAAC;IACD,QAAQ,CAAC,SAAiB;QACtB,IAAI,CAAC,aAAa,CAAC,YAAY,GAAG,SAAS,CAAA;QAC3C,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;IAC5C,CAAC;CAEJ;AAzBD,oCAyBC;AAGD,sDAAsD;AACtD,iDAAiD;AACjD,6DAA6D;AAE7D,0CAA0C;AAC1C,2BAA2B;AAC3B,uDAAuD;AACvD,gDAAgD;AAChD,YAAY;AAEZ,mEAAmE;AACnE,mBAAmB;AACnB,uBAAuB;AAEvB,0GAA0G;AAC1G,mFAAmF;AACnF,uDAAuD;AACvD,+CAA+C;AAC/C,+DAA+D;AAC/D,0BAA0B;AAC1B,kBAAkB;AAClB,8DAA8D;AAC9D,YAAY;AAEZ,mCAAmC;AACnC,6DAA6D;AAC7D,4DAA4D;AAC5D,wDAAwD;AACxD,oBAAoB;AACpB,wCAAwC;AACxC,2CAA2C;AAC3C,oBAAoB;AACpB,qDAAqD;AACrD,kDAAkD;AAClD,+DAA+D;AAC/D,+DAA+D;AAC/D,gDAAgD;AAChD,mDAAmD;AACnD,mDAAmD;AACnD,uCAAuC;AACvC,yCAAyC;AACzC,iCAAiC;AACjC,oEAAoE;AACpE,oDAAoD;AACpD,oFAAoF;AACpF,iCAAiC;AACjC,uDAAuD;AACvD,gCAAgC;AAChC,wBAAwB;AACxB,4BAA4B;AAC5B,qDAAqD;AACrD,kEAAkE;AAClE,wCAAwC;AACxC,sDAAsD;AACtD,mDAAmD;AACnD,uCAAuC;AACvC,wBAAwB;AACxB,qBAAqB;AACrB,gBAAgB;AAChB,cAAc;AACd,QAAQ;AACR,IAAI"}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
/// <reference types="node" />
|
|
2
|
-
import { UltipaConfig } from "../types/types";
|
|
3
|
-
import { ConnectionFinal } from "./connection.final";
|
|
4
|
-
/** Ultipa connection pool */
|
|
5
|
-
export declare class ConnectionPool {
|
|
6
|
-
hosts: string[];
|
|
7
|
-
username: string;
|
|
8
|
-
password: string;
|
|
9
|
-
crt?: Buffer;
|
|
10
|
-
defaultConfig: UltipaConfig;
|
|
11
|
-
currentIndex: number;
|
|
12
|
-
private connectionCache;
|
|
13
|
-
constructor(hosts: string[], username: string, password: string, crt?: Buffer, defaultConfig?: UltipaConfig);
|
|
14
|
-
private getOrCreateConnection;
|
|
15
|
-
/** Get active client */
|
|
16
|
-
getActive(hosts?: string[]): Promise<ConnectionFinal>;
|
|
17
|
-
private _getActive;
|
|
18
|
-
_testActiveMaybeSlow(noBalanced?: boolean): Promise<ConnectionFinal>;
|
|
19
|
-
test(): Promise<boolean>;
|
|
20
|
-
setGraph(graphName: string): void;
|
|
21
|
-
}
|
|
@@ -1,103 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.ConnectionPool = void 0;
|
|
7
|
-
const connection_final_1 = require("./connection.final");
|
|
8
|
-
const bluebird_1 = __importDefault(require("bluebird"));
|
|
9
|
-
/** Ultipa connection pool */
|
|
10
|
-
class ConnectionPool {
|
|
11
|
-
hosts;
|
|
12
|
-
username;
|
|
13
|
-
password;
|
|
14
|
-
crt;
|
|
15
|
-
defaultConfig;
|
|
16
|
-
currentIndex;
|
|
17
|
-
connectionCache = new Map();
|
|
18
|
-
constructor(hosts, username, password, crt, defaultConfig) {
|
|
19
|
-
this.hosts = hosts;
|
|
20
|
-
this.username = username;
|
|
21
|
-
this.password = password;
|
|
22
|
-
this.crt = crt;
|
|
23
|
-
this.defaultConfig = defaultConfig;
|
|
24
|
-
this.currentIndex = 0;
|
|
25
|
-
}
|
|
26
|
-
getOrCreateConnection(host, crt) {
|
|
27
|
-
const cacheKey = `${host}-${crt ? 'https' : 'http'}`;
|
|
28
|
-
if (!this.connectionCache.has(cacheKey)) {
|
|
29
|
-
const client = new connection_final_1.ConnectionFinal(host, this.username, this.password, crt || this.crt, this.defaultConfig);
|
|
30
|
-
this.connectionCache.set(cacheKey, client);
|
|
31
|
-
}
|
|
32
|
-
return this.connectionCache.get(cacheKey);
|
|
33
|
-
}
|
|
34
|
-
/** Get active client */
|
|
35
|
-
async getActive(hosts) {
|
|
36
|
-
hosts = hosts || this.hosts;
|
|
37
|
-
let client = await this._getActive(hosts);
|
|
38
|
-
if (!client.testConnectResult && !this.crt) {
|
|
39
|
-
try {
|
|
40
|
-
// https
|
|
41
|
-
let client_https = await this._getActive(hosts, this.crt);
|
|
42
|
-
console.log("try https:", hosts);
|
|
43
|
-
if (client_https.testConnectResult) {
|
|
44
|
-
return client_https;
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
catch (error) {
|
|
48
|
-
console.log(error);
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
return client;
|
|
52
|
-
}
|
|
53
|
-
async _getActive(hosts, crt) {
|
|
54
|
-
const availableClients = [];
|
|
55
|
-
await bluebird_1.default.map(hosts, async (host) => {
|
|
56
|
-
const client = this.getOrCreateConnection(host, crt);
|
|
57
|
-
const test = await client.test();
|
|
58
|
-
client.testConnectResult = test;
|
|
59
|
-
if (test) {
|
|
60
|
-
availableClients.push(client);
|
|
61
|
-
}
|
|
62
|
-
});
|
|
63
|
-
if (availableClients.length === 0) {
|
|
64
|
-
return this.getOrCreateConnection(hosts[hosts.length - 1], crt);
|
|
65
|
-
}
|
|
66
|
-
const randomIndex = Math.floor(Math.random() * availableClients.length);
|
|
67
|
-
return availableClients[randomIndex];
|
|
68
|
-
}
|
|
69
|
-
async _testActiveMaybeSlow(noBalanced = false) {
|
|
70
|
-
let m = noBalanced ? 0 : 1;
|
|
71
|
-
let client = null;
|
|
72
|
-
for (let index = 0; index < this.hosts.length; index++) {
|
|
73
|
-
let i = (index + this.currentIndex + m) % this.hosts.length;
|
|
74
|
-
let host = this.hosts[i];
|
|
75
|
-
client = this.getOrCreateConnection(host);
|
|
76
|
-
let test = await client.test();
|
|
77
|
-
if (test) {
|
|
78
|
-
this.currentIndex = i;
|
|
79
|
-
return client;
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
return client;
|
|
83
|
-
}
|
|
84
|
-
async test() {
|
|
85
|
-
let v = false;
|
|
86
|
-
await bluebird_1.default.map(this.hosts, async (host) => {
|
|
87
|
-
let client = await this.getActive([host]);
|
|
88
|
-
let test = await client.test_has_message({
|
|
89
|
-
host: host,
|
|
90
|
-
});
|
|
91
|
-
v = test.connect;
|
|
92
|
-
});
|
|
93
|
-
return v;
|
|
94
|
-
}
|
|
95
|
-
setGraph(graphName) {
|
|
96
|
-
this.defaultConfig.defaultGraph = graphName;
|
|
97
|
-
this.connectionCache.forEach((client) => {
|
|
98
|
-
client.setGraph(graphName);
|
|
99
|
-
});
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
exports.ConnectionPool = ConnectionPool;
|
|
103
|
-
//# sourceMappingURL=connection.pool.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"connection.pool.js","sourceRoot":"","sources":["../../src/connection/connection.pool.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { ConnectionBase } from "./connection.base";
|
|
2
|
-
import { RequestType } from "../../types";
|
|
3
|
-
import { ExportRequest } from "../../proto/ultipa_pb";
|
|
4
|
-
import { RequestConfig, Response } from "../../types/types";
|
|
5
|
-
export declare class BaseExtra extends ConnectionBase {
|
|
6
|
-
/**
|
|
7
|
-
* Checking database server statistics.
|
|
8
|
-
*/
|
|
9
|
-
stats(config?: RequestConfig): Promise<Response>;
|
|
10
|
-
/**
|
|
11
|
-
* Download file from server.
|
|
12
|
-
*/
|
|
13
|
-
download(fileName: string, config: RequestType.CommonStreamRequire): Promise<import("@grpc/grpc-js").ClientReadableStream<import("../../proto/ultipa_pb").DownloadFileReply>>;
|
|
14
|
-
/**
|
|
15
|
-
* Exports nodes and edges from the current graph.
|
|
16
|
-
*/
|
|
17
|
-
export(exportRequest: ExportRequest, listener: RequestType.ExportListener): Promise<void>;
|
|
18
|
-
}
|
|
@@ -1,111 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.BaseExtra = void 0;
|
|
4
|
-
const connection_base_1 = require("./connection.base");
|
|
5
|
-
const utils_1 = require("../../utils");
|
|
6
|
-
const ultipa_pb_1 = require("../../proto/ultipa_pb");
|
|
7
|
-
const types_1 = require("../../types/types");
|
|
8
|
-
const { CommandList } = utils_1.UQLMAKER;
|
|
9
|
-
class BaseExtra extends connection_base_1.ConnectionBase {
|
|
10
|
-
/**
|
|
11
|
-
* Checking database server statistics.
|
|
12
|
-
*/
|
|
13
|
-
async stats(config) {
|
|
14
|
-
// let command = CommandList.stats
|
|
15
|
-
let command = CommandList.licenseDump;
|
|
16
|
-
let uqlMaker = new utils_1.UQLMAKER(command, config);
|
|
17
|
-
return await this.uql(uqlMaker.toString(), config);
|
|
18
|
-
}
|
|
19
|
-
/**
|
|
20
|
-
* Download file from server.
|
|
21
|
-
*/
|
|
22
|
-
async download(fileName, config) {
|
|
23
|
-
let req = new ultipa_pb_1.DownloadFileRequest();
|
|
24
|
-
req.setFileName(fileName);
|
|
25
|
-
let clientInfo = await this.getClientInfo({
|
|
26
|
-
graphSetName: config?.graph,
|
|
27
|
-
timezone: config?.timezone,
|
|
28
|
-
timezoneOffset: config?.timezoneOffset,
|
|
29
|
-
});
|
|
30
|
-
let stream = clientInfo.client.controlsClient.downloadFile(req, clientInfo.metadata);
|
|
31
|
-
utils_1.streamHelper.commonDeal(stream, config?.stream, (chunkData) => {
|
|
32
|
-
let status = utils_1.FormatType.status(chunkData.getStatus());
|
|
33
|
-
if (status.code != types_1.ErrorCode.SUCCESS) {
|
|
34
|
-
let err = new Error(status.message);
|
|
35
|
-
err.code = status.code;
|
|
36
|
-
throw err;
|
|
37
|
-
}
|
|
38
|
-
let data = Buffer.from(chunkData.getChunk());
|
|
39
|
-
return data;
|
|
40
|
-
});
|
|
41
|
-
return stream;
|
|
42
|
-
}
|
|
43
|
-
/**
|
|
44
|
-
* Exports nodes and edges from the current graph.
|
|
45
|
-
*/
|
|
46
|
-
async export(exportRequest, listener) {
|
|
47
|
-
let clientInfo = await this.getClientInfo({
|
|
48
|
-
graphSetName: exportRequest.getGraph() || listener?.graph,
|
|
49
|
-
timezone: listener?.timezone,
|
|
50
|
-
timezoneOffset: listener?.timezoneOffset,
|
|
51
|
-
});
|
|
52
|
-
await new Promise((resolve, reject) => {
|
|
53
|
-
const originalCb = listener?.stream;
|
|
54
|
-
const wrappedCb = {
|
|
55
|
-
onData: async (data) => {
|
|
56
|
-
try {
|
|
57
|
-
await originalCb.onData(data);
|
|
58
|
-
}
|
|
59
|
-
catch (error) {
|
|
60
|
-
reject(error);
|
|
61
|
-
}
|
|
62
|
-
},
|
|
63
|
-
onEnd: () => {
|
|
64
|
-
originalCb.onEnd();
|
|
65
|
-
resolve();
|
|
66
|
-
},
|
|
67
|
-
onClose: () => {
|
|
68
|
-
resolve();
|
|
69
|
-
originalCb.onClose?.();
|
|
70
|
-
},
|
|
71
|
-
onError: (err) => {
|
|
72
|
-
reject(err);
|
|
73
|
-
originalCb.onError?.(err);
|
|
74
|
-
},
|
|
75
|
-
onPause: () => {
|
|
76
|
-
originalCb.onPause?.();
|
|
77
|
-
},
|
|
78
|
-
onReadable: () => {
|
|
79
|
-
originalCb.onReadable?.();
|
|
80
|
-
},
|
|
81
|
-
onResume: () => {
|
|
82
|
-
originalCb.onResume?.();
|
|
83
|
-
},
|
|
84
|
-
onStart: () => {
|
|
85
|
-
originalCb.onStart?.();
|
|
86
|
-
},
|
|
87
|
-
};
|
|
88
|
-
// config.stream = wrappedCb;
|
|
89
|
-
let stream = clientInfo.client.controlsClient.export(exportRequest, clientInfo.metadata);
|
|
90
|
-
utils_1.streamHelper.commonDeal(stream, wrappedCb, (chunkData) => {
|
|
91
|
-
let status = utils_1.FormatType.status(chunkData.getStatus());
|
|
92
|
-
if (status.code != types_1.ErrorCode.SUCCESS) {
|
|
93
|
-
let err = new Error(status.message);
|
|
94
|
-
err.code = status.code;
|
|
95
|
-
throw err;
|
|
96
|
-
}
|
|
97
|
-
if (exportRequest.getDbType() == ultipa_pb_1.DBType.DBNODE) {
|
|
98
|
-
let nodes = chunkData.getNodeTable();
|
|
99
|
-
return utils_1.FormatType.nodeTable(nodes, { timezone: listener.timezone });
|
|
100
|
-
}
|
|
101
|
-
else {
|
|
102
|
-
let edges = chunkData.getEdgeTable();
|
|
103
|
-
return utils_1.FormatType.edgeTable(edges, { timezone: listener.timezone });
|
|
104
|
-
}
|
|
105
|
-
});
|
|
106
|
-
});
|
|
107
|
-
// let req = new ExportRequest()
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
exports.BaseExtra = BaseExtra;
|
|
111
|
-
//# sourceMappingURL=base.extra.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"base.extra.js","sourceRoot":"","sources":["../../../src/connection/extra/base.extra.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
import { EntityTable } from "../../proto/ultipa_pb";
|
|
2
|
-
import { InsertRequestConfig, InsertResponse, Edge, Response, Schema, Node } from "../../types/types";
|
|
3
|
-
import { SchemaExra } from "./schema.extra";
|
|
4
|
-
export declare class BatchInsertExtra extends SchemaExra {
|
|
5
|
-
/**
|
|
6
|
-
* Inserts new nodes of a schema into the current graph through gRPC. The properties within the node values must be consistent with those declared in the schema structure.
|
|
7
|
-
* @param table
|
|
8
|
-
* @param config
|
|
9
|
-
* @returns
|
|
10
|
-
*/
|
|
11
|
-
insertNodesBatch(table: EntityTable, config?: InsertRequestConfig): Promise<InsertResponse>;
|
|
12
|
-
/**
|
|
13
|
-
* Inserts new nodes of a schema into the current graph through gRPC. The properties within the node values must be consistent with those declared in the schema structure.
|
|
14
|
-
* @param schema
|
|
15
|
-
* @param nodes
|
|
16
|
-
* @param config
|
|
17
|
-
* @returns InsertResponse
|
|
18
|
-
*/
|
|
19
|
-
insertNodesBatchBySchema(schema: Schema, nodes: Node[], config: InsertRequestConfig): Promise<InsertResponse>;
|
|
20
|
-
/**
|
|
21
|
-
* Insert node list to shcem by schemaName
|
|
22
|
-
*/
|
|
23
|
-
insertNodes(schemaName: string, nodes: Node[], config?: InsertRequestConfig): Promise<Response>;
|
|
24
|
-
/**
|
|
25
|
-
* Insert edge list to shcem by schemaName
|
|
26
|
-
*/
|
|
27
|
-
insertEdges(schemaName: string, edges: Edge[], config?: InsertRequestConfig): Promise<Response>;
|
|
28
|
-
/**
|
|
29
|
-
* Inserts new nodes of one or multiple schemas to the current graph through gRPC. The properties within node values must be consistent with those defined in the corresponding schema structure.
|
|
30
|
-
* @param nodes
|
|
31
|
-
* @param config
|
|
32
|
-
* @returns
|
|
33
|
-
*/
|
|
34
|
-
insertNodesBatchAuto(nodes: Node[], config: InsertRequestConfig): Promise<Map<string, InsertResponse>>;
|
|
35
|
-
/**
|
|
36
|
-
* Inserts new edges of a schema into the current graph through gRPC. The properties within the edge values must be consistent with those declared in the schema structure.
|
|
37
|
-
* @param table
|
|
38
|
-
* @param config
|
|
39
|
-
* @returns
|
|
40
|
-
*/
|
|
41
|
-
insertEdgesBatch(table: EntityTable, config?: InsertRequestConfig): Promise<InsertResponse>;
|
|
42
|
-
/**
|
|
43
|
-
* Inserts new edges of a schema into the current graph through gRPC. The properties within the edge values must be consistent with those declared in the schema structure.
|
|
44
|
-
*/
|
|
45
|
-
insertEdgesBatchBySchema(schema: Schema, edges: Edge[], config: InsertRequestConfig): Promise<InsertResponse>;
|
|
46
|
-
validEdgeRows(rows: Edge[]): {
|
|
47
|
-
ok: boolean;
|
|
48
|
-
msg?: string;
|
|
49
|
-
failedIndex?: number;
|
|
50
|
-
};
|
|
51
|
-
/**
|
|
52
|
-
* Inserts new edges of one or multiple schemas to the current graph through gRPC. The properties within edge values must be consistent with those defined in the corresponding schema structure.
|
|
53
|
-
* @param edges
|
|
54
|
-
* @param config
|
|
55
|
-
* @returns
|
|
56
|
-
*/
|
|
57
|
-
insertEdgesBatchAuto(edges: Edge[], config: InsertRequestConfig): Promise<Map<string, InsertResponse>>;
|
|
58
|
-
}
|