@snowtop/ent 0.1.0-alpha16 → 0.1.0-alpha160-test1
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/action/action.d.ts +25 -14
- package/action/action.js +22 -7
- package/action/executor.d.ts +16 -3
- package/action/executor.js +89 -28
- package/action/experimental_action.d.ts +25 -16
- package/action/experimental_action.js +34 -14
- package/action/index.d.ts +4 -1
- package/action/index.js +7 -1
- package/action/operations.d.ts +126 -0
- package/action/operations.js +686 -0
- package/action/orchestrator.d.ts +43 -12
- package/action/orchestrator.js +461 -101
- package/action/relative_value.d.ts +47 -0
- package/action/relative_value.js +125 -0
- package/action/transaction.d.ts +10 -0
- package/action/transaction.js +23 -0
- package/auth/auth.d.ts +1 -1
- package/core/base.d.ts +56 -23
- package/core/base.js +7 -1
- package/core/clause.d.ts +103 -39
- package/core/clause.js +430 -66
- package/core/config.d.ts +13 -3
- package/core/config.js +10 -1
- package/core/const.d.ts +3 -0
- package/core/const.js +6 -0
- package/core/context.d.ts +6 -3
- package/core/context.js +22 -3
- package/core/convert.d.ts +1 -1
- package/core/date.js +1 -5
- package/core/db.d.ts +12 -8
- package/core/db.js +21 -9
- package/core/ent.d.ts +99 -95
- package/core/ent.js +550 -602
- package/core/global_schema.d.ts +7 -0
- package/core/global_schema.js +51 -0
- package/core/loaders/assoc_count_loader.d.ts +5 -2
- package/core/loaders/assoc_count_loader.js +19 -3
- package/core/loaders/assoc_edge_loader.d.ts +2 -3
- package/core/loaders/assoc_edge_loader.js +23 -17
- package/core/loaders/index.d.ts +1 -2
- package/core/loaders/index.js +1 -5
- package/core/loaders/loader.d.ts +3 -3
- package/core/loaders/loader.js +4 -21
- package/core/loaders/object_loader.d.ts +30 -9
- package/core/loaders/object_loader.js +226 -79
- package/core/loaders/query_loader.d.ts +7 -13
- package/core/loaders/query_loader.js +60 -24
- package/core/loaders/raw_count_loader.d.ts +1 -0
- package/core/loaders/raw_count_loader.js +8 -3
- package/core/logger.d.ts +1 -1
- package/core/logger.js +1 -0
- package/core/privacy.d.ts +26 -16
- package/core/privacy.js +68 -51
- package/core/query/assoc_query.d.ts +3 -2
- package/core/query/assoc_query.js +10 -2
- package/core/query/custom_clause_query.d.ts +29 -0
- package/core/query/custom_clause_query.js +105 -0
- package/core/query/custom_query.d.ts +19 -2
- package/core/query/custom_query.js +111 -13
- package/core/query/index.d.ts +1 -0
- package/core/query/index.js +3 -1
- package/core/query/query.d.ts +18 -4
- package/core/query/query.js +135 -58
- package/core/query/shared_assoc_test.d.ts +2 -1
- package/core/query/shared_assoc_test.js +186 -55
- package/core/query/shared_test.d.ts +9 -2
- package/core/query/shared_test.js +529 -236
- package/core/query_impl.d.ts +8 -0
- package/core/query_impl.js +28 -0
- package/core/viewer.d.ts +2 -0
- package/core/viewer.js +3 -1
- package/graphql/graphql.d.ts +108 -22
- package/graphql/graphql.js +183 -137
- package/graphql/graphql_field_helpers.d.ts +9 -3
- package/graphql/graphql_field_helpers.js +22 -2
- package/graphql/index.d.ts +2 -2
- package/graphql/index.js +5 -5
- package/graphql/query/connection_type.d.ts +9 -9
- package/graphql/query/shared_assoc_test.js +1 -1
- package/graphql/query/shared_edge_connection.js +1 -19
- package/graphql/scalars/orderby_direction.d.ts +2 -0
- package/graphql/scalars/orderby_direction.js +15 -0
- package/imports/dataz/example1/_auth.js +128 -47
- package/imports/dataz/example1/_viewer.js +87 -39
- package/imports/index.d.ts +7 -2
- package/imports/index.js +20 -5
- package/index.d.ts +23 -5
- package/index.js +35 -10
- package/package.json +19 -19
- package/parse_schema/parse.d.ts +33 -9
- package/parse_schema/parse.js +182 -33
- package/schema/base_schema.d.ts +13 -3
- package/schema/base_schema.js +13 -0
- package/schema/field.d.ts +78 -21
- package/schema/field.js +232 -72
- package/schema/index.d.ts +2 -2
- package/schema/index.js +7 -2
- package/schema/json_field.d.ts +16 -4
- package/schema/json_field.js +32 -2
- package/schema/schema.d.ts +109 -20
- package/schema/schema.js +42 -53
- package/schema/struct_field.d.ts +15 -3
- package/schema/struct_field.js +117 -22
- package/schema/union_field.d.ts +1 -1
- package/scripts/custom_compiler.js +12 -8
- package/scripts/custom_graphql.js +171 -64
- package/scripts/migrate_v0.1.js +36 -0
- package/scripts/move_types.js +120 -0
- package/scripts/read_schema.js +22 -7
- package/testutils/action/complex_schemas.d.ts +69 -0
- package/testutils/action/complex_schemas.js +405 -0
- package/testutils/builder.d.ts +37 -41
- package/testutils/builder.js +66 -46
- package/testutils/db/fixture.d.ts +10 -0
- package/testutils/db/fixture.js +26 -0
- package/testutils/db/{test_db.d.ts → temp_db.d.ts} +32 -8
- package/testutils/db/{test_db.js → temp_db.js} +251 -48
- package/testutils/db/value.d.ts +7 -0
- package/testutils/db/value.js +251 -0
- package/testutils/db_mock.d.ts +16 -4
- package/testutils/db_mock.js +52 -9
- package/testutils/db_time_zone.d.ts +4 -0
- package/testutils/db_time_zone.js +41 -0
- package/testutils/ent-graphql-tests/index.d.ts +7 -1
- package/testutils/ent-graphql-tests/index.js +56 -26
- package/testutils/fake_comms.js +1 -1
- package/testutils/fake_data/const.d.ts +2 -1
- package/testutils/fake_data/const.js +3 -0
- package/testutils/fake_data/fake_contact.d.ts +7 -3
- package/testutils/fake_data/fake_contact.js +13 -7
- package/testutils/fake_data/fake_event.d.ts +4 -1
- package/testutils/fake_data/fake_event.js +7 -6
- package/testutils/fake_data/fake_tag.d.ts +36 -0
- package/testutils/fake_data/fake_tag.js +89 -0
- package/testutils/fake_data/fake_user.d.ts +8 -5
- package/testutils/fake_data/fake_user.js +31 -19
- package/testutils/fake_data/index.js +5 -1
- package/testutils/fake_data/internal.d.ts +2 -0
- package/testutils/fake_data/internal.js +7 -1
- package/testutils/fake_data/tag_query.d.ts +13 -0
- package/testutils/fake_data/tag_query.js +48 -0
- package/testutils/fake_data/test_helpers.d.ts +14 -6
- package/testutils/fake_data/test_helpers.js +31 -15
- package/testutils/fake_data/user_query.d.ts +16 -6
- package/testutils/fake_data/user_query.js +72 -23
- package/testutils/fake_log.js +1 -1
- package/testutils/parse_sql.d.ts +6 -0
- package/testutils/parse_sql.js +16 -2
- package/testutils/test_edge_global_schema.d.ts +15 -0
- package/testutils/test_edge_global_schema.js +62 -0
- package/testutils/write.d.ts +2 -2
- package/testutils/write.js +33 -7
- package/tsc/ast.d.ts +15 -3
- package/tsc/ast.js +114 -23
- package/tsc/compilerOptions.js +5 -1
- package/tsc/move_generated.d.ts +1 -0
- package/tsc/move_generated.js +164 -0
- package/tsc/transform.d.ts +22 -0
- package/tsc/transform.js +182 -0
- package/tsc/transform_action.d.ts +22 -0
- package/tsc/transform_action.js +183 -0
- package/tsc/transform_ent.d.ts +17 -0
- package/tsc/transform_ent.js +60 -0
- package/tsc/transform_schema.d.ts +27 -0
- package/{scripts → tsc}/transform_schema.js +146 -117
- package/core/loaders/index_loader.d.ts +0 -14
- package/core/loaders/index_loader.js +0 -27
- package/graphql/enums.d.ts +0 -3
- package/graphql/enums.js +0 -25
- package/scripts/move_generated.js +0 -141
- package/scripts/transform_actions.js +0 -266
- package/scripts/transform_code.d.ts +0 -1
- package/scripts/transform_code.js +0 -111
- package/scripts/transform_schema.d.ts +0 -1
- /package/scripts/{move_generated.d.ts → migrate_v0.1.d.ts} +0 -0
- /package/scripts/{transform_actions.d.ts → move_types.d.ts} +0 -0
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Field, GlobalSchema } from "../schema/schema";
|
|
2
|
+
export declare function setGlobalSchema(val: GlobalSchema): void;
|
|
3
|
+
export declare function clearGlobalSchema(): void;
|
|
4
|
+
export declare function __hasGlobalSchema(): boolean;
|
|
5
|
+
export declare function __getGlobalSchema(): GlobalSchema | undefined;
|
|
6
|
+
export declare function __getGlobalSchemaFields(): Map<string, Field>;
|
|
7
|
+
export declare function __getGlobalSchemaField(type: string): Field | undefined;
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.__getGlobalSchemaField = exports.__getGlobalSchemaFields = exports.__getGlobalSchema = exports.__hasGlobalSchema = exports.clearGlobalSchema = exports.setGlobalSchema = void 0;
|
|
4
|
+
const schema_1 = require("../schema/schema");
|
|
5
|
+
let globalSchema;
|
|
6
|
+
let globalSchemaFields = new Map();
|
|
7
|
+
function isGlobalSchemaField(f) {
|
|
8
|
+
switch (f.type.dbType) {
|
|
9
|
+
case schema_1.DBType.Enum:
|
|
10
|
+
case schema_1.DBType.StringEnum:
|
|
11
|
+
case schema_1.DBType.IntEnum:
|
|
12
|
+
case schema_1.DBType.JSON:
|
|
13
|
+
case schema_1.DBType.JSONB:
|
|
14
|
+
return true;
|
|
15
|
+
}
|
|
16
|
+
return false;
|
|
17
|
+
}
|
|
18
|
+
function setGlobalSchema(val) {
|
|
19
|
+
globalSchema = val;
|
|
20
|
+
if (val.fields) {
|
|
21
|
+
for (const [k, v] of Object.entries(val.fields)) {
|
|
22
|
+
if (isGlobalSchemaField(v) && v.type.type) {
|
|
23
|
+
globalSchemaFields.set(v.type.type, v);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
exports.setGlobalSchema = setGlobalSchema;
|
|
29
|
+
function clearGlobalSchema() {
|
|
30
|
+
globalSchema = undefined;
|
|
31
|
+
globalSchemaFields.clear();
|
|
32
|
+
}
|
|
33
|
+
exports.clearGlobalSchema = clearGlobalSchema;
|
|
34
|
+
// used by tests. no guarantee will always exist
|
|
35
|
+
function __hasGlobalSchema() {
|
|
36
|
+
return globalSchema !== undefined;
|
|
37
|
+
}
|
|
38
|
+
exports.__hasGlobalSchema = __hasGlobalSchema;
|
|
39
|
+
// used by tests. no guarantee will always exist
|
|
40
|
+
function __getGlobalSchema() {
|
|
41
|
+
return globalSchema;
|
|
42
|
+
}
|
|
43
|
+
exports.__getGlobalSchema = __getGlobalSchema;
|
|
44
|
+
function __getGlobalSchemaFields() {
|
|
45
|
+
return globalSchemaFields;
|
|
46
|
+
}
|
|
47
|
+
exports.__getGlobalSchemaFields = __getGlobalSchemaFields;
|
|
48
|
+
function __getGlobalSchemaField(type) {
|
|
49
|
+
return globalSchemaFields.get(type);
|
|
50
|
+
}
|
|
51
|
+
exports.__getGlobalSchemaField = __getGlobalSchemaField;
|
|
@@ -1,10 +1,11 @@
|
|
|
1
|
-
import { ID, Context, Loader, LoaderFactory } from "../base";
|
|
1
|
+
import { ID, Context, Loader, LoaderFactory, EdgeQueryableDataOptionsConfigureLoader } from "../base";
|
|
2
2
|
export declare class AssocEdgeCountLoader implements Loader<ID, number> {
|
|
3
3
|
private edgeType;
|
|
4
4
|
context?: Context<import("../base").Viewer<import("../base").Ent<any> | null, ID | null>> | undefined;
|
|
5
|
+
private options?;
|
|
5
6
|
private loaderFn;
|
|
6
7
|
private loader;
|
|
7
|
-
constructor(edgeType: string, context?: Context<import("../base").Viewer<import("../base").Ent<any> | null, ID | null>> | undefined);
|
|
8
|
+
constructor(edgeType: string, context?: Context<import("../base").Viewer<import("../base").Ent<any> | null, ID | null>> | undefined, options?: EdgeQueryableDataOptionsConfigureLoader | undefined);
|
|
8
9
|
private getLoader;
|
|
9
10
|
load(id: ID): Promise<number>;
|
|
10
11
|
clearAll(): void;
|
|
@@ -13,5 +14,7 @@ export declare class AssocEdgeCountLoaderFactory implements LoaderFactory<ID, nu
|
|
|
13
14
|
private edgeType;
|
|
14
15
|
name: string;
|
|
15
16
|
constructor(edgeType: string);
|
|
17
|
+
getEdgeType(): string;
|
|
16
18
|
createLoader(context?: Context): AssocEdgeCountLoader;
|
|
19
|
+
createConfigurableLoader(options: EdgeQueryableDataOptionsConfigureLoader, context?: Context): AssocEdgeCountLoader;
|
|
17
20
|
}
|
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
3
|
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
5
9
|
}) : (function(o, m, k, k2) {
|
|
6
10
|
if (k2 === undefined) k2 = k;
|
|
7
11
|
o[k2] = m[k];
|
|
@@ -29,9 +33,10 @@ const loader_1 = require("./loader");
|
|
|
29
33
|
const raw_count_loader_1 = require("./raw_count_loader");
|
|
30
34
|
const memoizee_1 = __importDefault(require("memoizee"));
|
|
31
35
|
class AssocEdgeCountLoader {
|
|
32
|
-
constructor(edgeType, context) {
|
|
36
|
+
constructor(edgeType, context, options) {
|
|
33
37
|
this.edgeType = edgeType;
|
|
34
38
|
this.context = context;
|
|
39
|
+
this.options = options;
|
|
35
40
|
if (context) {
|
|
36
41
|
this.loaderFn = (0, memoizee_1.default)(this.getLoader);
|
|
37
42
|
}
|
|
@@ -41,10 +46,13 @@ class AssocEdgeCountLoader {
|
|
|
41
46
|
if (!edgeData) {
|
|
42
47
|
throw new Error(`error loading edge data for ${this.edgeType}`);
|
|
43
48
|
}
|
|
49
|
+
const { cls } = (0, ent_1.getEdgeClauseAndFields)(clause.Eq("edge_type", this.edgeType), {
|
|
50
|
+
queryOptions: this.options,
|
|
51
|
+
});
|
|
44
52
|
this.loader = (0, raw_count_loader_1.createCountDataLoader)({
|
|
45
53
|
tableName: edgeData.edgeTable,
|
|
46
54
|
groupCol: "id1",
|
|
47
|
-
clause:
|
|
55
|
+
clause: cls,
|
|
48
56
|
});
|
|
49
57
|
return this.loader;
|
|
50
58
|
}
|
|
@@ -53,6 +61,7 @@ class AssocEdgeCountLoader {
|
|
|
53
61
|
return (0, ent_1.loadRawEdgeCountX)({
|
|
54
62
|
id1: id,
|
|
55
63
|
edgeType: this.edgeType,
|
|
64
|
+
queryOptions: this.options,
|
|
56
65
|
});
|
|
57
66
|
}
|
|
58
67
|
const loader = await this.loaderFn();
|
|
@@ -68,8 +77,15 @@ class AssocEdgeCountLoaderFactory {
|
|
|
68
77
|
this.edgeType = edgeType;
|
|
69
78
|
this.name = `assocEdgeLoader:count:${edgeType}`;
|
|
70
79
|
}
|
|
80
|
+
getEdgeType() {
|
|
81
|
+
return this.edgeType;
|
|
82
|
+
}
|
|
71
83
|
createLoader(context) {
|
|
72
84
|
return (0, loader_1.getLoader)(this, () => new AssocEdgeCountLoader(this.edgeType, context), context);
|
|
73
85
|
}
|
|
86
|
+
createConfigurableLoader(options, context) {
|
|
87
|
+
const key = `${this.name}:disableTransformations:${options.disableTransformations}`;
|
|
88
|
+
return (0, loader_1.getCustomLoader)(key, () => new AssocEdgeCountLoader(this.edgeType, context, options), context);
|
|
89
|
+
}
|
|
74
90
|
}
|
|
75
91
|
exports.AssocEdgeCountLoaderFactory = AssocEdgeCountLoaderFactory;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Context, ID, EdgeQueryableDataOptions, Loader, LoaderFactory } from "../base";
|
|
2
2
|
import { AssocEdge, AssocEdgeConstructor } from "../ent";
|
|
3
|
-
interface AssocLoader<T extends AssocEdge> extends Loader<ID, T[]> {
|
|
3
|
+
export interface AssocLoader<T extends AssocEdge> extends Loader<ID, T[]> {
|
|
4
4
|
loadEdgeForID2(id: ID, id2: ID): Promise<T | undefined>;
|
|
5
5
|
}
|
|
6
6
|
export declare class AssocEdgeLoader<T extends AssocEdge> implements Loader<ID, T[]> {
|
|
@@ -21,7 +21,7 @@ export declare class AssocDirectEdgeLoader<T extends AssocEdge> implements Loade
|
|
|
21
21
|
private edgeCtr;
|
|
22
22
|
private options?;
|
|
23
23
|
context?: Context<import("../base").Viewer<import("../base").Ent<any> | null, ID | null>> | undefined;
|
|
24
|
-
constructor(edgeType: string, edgeCtr: AssocEdgeConstructor<T>, options?: Partial<Pick<import("../base").QueryableDataOptions, "limit" | "orderby" | "
|
|
24
|
+
constructor(edgeType: string, edgeCtr: AssocEdgeConstructor<T>, options?: Partial<Pick<import("../base").QueryableDataOptions, "clause" | "limit" | "orderby" | "disableTransformations">> | undefined, context?: Context<import("../base").Viewer<import("../base").Ent<any> | null, ID | null>> | undefined);
|
|
25
25
|
load(id: ID): Promise<T[]>;
|
|
26
26
|
loadEdgeForID2(id: ID, id2: ID): Promise<T | undefined>;
|
|
27
27
|
clearAll(): void;
|
|
@@ -35,4 +35,3 @@ export declare class AssocEdgeLoaderFactory<T extends AssocEdge> implements Load
|
|
|
35
35
|
private isConstructor;
|
|
36
36
|
createConfigurableLoader(options: EdgeQueryableDataOptions, context?: Context): AssocLoader<T>;
|
|
37
37
|
}
|
|
38
|
-
export {};
|
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
3
|
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
5
9
|
}) : (function(o, m, k, k2) {
|
|
6
10
|
if (k2 === undefined) k2 = k;
|
|
7
11
|
o[k2] = m[k];
|
|
@@ -32,7 +36,7 @@ const memoizee_1 = __importDefault(require("memoizee"));
|
|
|
32
36
|
function createLoader(options, edgeType, edgeCtr, edgeData) {
|
|
33
37
|
const loaderOptions = {};
|
|
34
38
|
if ((0, logger_1.logEnabled)("query")) {
|
|
35
|
-
loaderOptions.cacheMap = new loader_1.
|
|
39
|
+
loaderOptions.cacheMap = new loader_1.CacheMap({
|
|
36
40
|
tableName: edgeData.edgeTable,
|
|
37
41
|
});
|
|
38
42
|
}
|
|
@@ -55,26 +59,26 @@ function createLoader(options, edgeType, edgeCtr, edgeData) {
|
|
|
55
59
|
// store the index....
|
|
56
60
|
m.set(keys[i], i);
|
|
57
61
|
}
|
|
58
|
-
options.orderby = options.orderby ||
|
|
62
|
+
options.orderby = options.orderby || [
|
|
63
|
+
{
|
|
64
|
+
column: "time",
|
|
65
|
+
direction: "DESC",
|
|
66
|
+
},
|
|
67
|
+
];
|
|
59
68
|
// TODO defaultEdgeQueryOptions
|
|
60
|
-
options.limit = options.limit || ent_1.
|
|
69
|
+
options.limit = options.limit || (0, ent_1.getDefaultLimit)();
|
|
61
70
|
const tableName = edgeData.edgeTable;
|
|
71
|
+
const { cls: cls1, fields } = (0, ent_1.getEdgeClauseAndFields)(clause.Eq("edge_type", edgeType), {
|
|
72
|
+
queryOptions: options,
|
|
73
|
+
});
|
|
62
74
|
const [query, cls] = (0, ent_1.buildGroupQuery)({
|
|
63
75
|
tableName: tableName,
|
|
64
|
-
fields
|
|
65
|
-
"id1",
|
|
66
|
-
"id2",
|
|
67
|
-
"edge_type",
|
|
68
|
-
"id1_type",
|
|
69
|
-
"id2_type",
|
|
70
|
-
"data",
|
|
71
|
-
"time",
|
|
72
|
-
],
|
|
76
|
+
fields,
|
|
73
77
|
values: keys,
|
|
74
78
|
orderby: options.orderby,
|
|
75
|
-
limit: options.limit || ent_1.
|
|
79
|
+
limit: options.limit || (0, ent_1.getDefaultLimit)(),
|
|
76
80
|
groupColumn: "id1",
|
|
77
|
-
clause:
|
|
81
|
+
clause: cls1,
|
|
78
82
|
});
|
|
79
83
|
const rows = await (0, ent_1.performRawQuery)(query, cls.values(), cls.logValues());
|
|
80
84
|
for (const row of rows) {
|
|
@@ -117,6 +121,7 @@ class AssocEdgeLoader {
|
|
|
117
121
|
id2,
|
|
118
122
|
context: this.context,
|
|
119
123
|
ctr: this.edgeCtr,
|
|
124
|
+
queryOptions: this.options,
|
|
120
125
|
});
|
|
121
126
|
}
|
|
122
127
|
clearAll() {
|
|
@@ -132,7 +137,7 @@ class AssocDirectEdgeLoader {
|
|
|
132
137
|
this.context = context;
|
|
133
138
|
}
|
|
134
139
|
async load(id) {
|
|
135
|
-
return
|
|
140
|
+
return (0, ent_1.loadCustomEdges)({
|
|
136
141
|
id1: id,
|
|
137
142
|
edgeType: this.edgeType,
|
|
138
143
|
context: this.context,
|
|
@@ -146,6 +151,7 @@ class AssocDirectEdgeLoader {
|
|
|
146
151
|
edgeType: this.edgeType,
|
|
147
152
|
id2,
|
|
148
153
|
context: this.context,
|
|
154
|
+
queryOptions: this.options,
|
|
149
155
|
ctr: this.edgeCtr,
|
|
150
156
|
});
|
|
151
157
|
}
|
|
@@ -184,7 +190,7 @@ class AssocEdgeLoaderFactory {
|
|
|
184
190
|
return new AssocDirectEdgeLoader(this.edgeType, edgeCtr, options, context);
|
|
185
191
|
}
|
|
186
192
|
// we create a loader which can combine first X queries in the same fetch
|
|
187
|
-
const key = `${this.name}:limit:${options.limit}:orderby:${options.orderby}`;
|
|
193
|
+
const key = `${this.name}:limit:${options.limit}:orderby:${options.orderby}:disableTransformations:${options.disableTransformations}`;
|
|
188
194
|
return (0, loader_1.getCustomLoader)(key, () => new AssocEdgeLoader(this.edgeType, ctr, options, context), context);
|
|
189
195
|
}
|
|
190
196
|
}
|
package/core/loaders/index.d.ts
CHANGED
|
@@ -2,5 +2,4 @@ export { ObjectLoader, ObjectLoaderFactory } from "./object_loader";
|
|
|
2
2
|
export { RawCountLoader, RawCountLoaderFactory } from "./raw_count_loader";
|
|
3
3
|
export { AssocEdgeCountLoader, AssocEdgeCountLoaderFactory, } from "./assoc_count_loader";
|
|
4
4
|
export { AssocDirectEdgeLoader, AssocEdgeLoader, AssocEdgeLoaderFactory, } from "./assoc_edge_loader";
|
|
5
|
-
export {
|
|
6
|
-
export { QueryLoader, QueryDirectLoader, QueryLoaderFactory, } from "./query_loader";
|
|
5
|
+
export { QueryLoaderFactory } from "./query_loader";
|
package/core/loaders/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.QueryLoaderFactory = exports.
|
|
3
|
+
exports.QueryLoaderFactory = exports.AssocEdgeLoaderFactory = exports.AssocEdgeLoader = exports.AssocDirectEdgeLoader = exports.AssocEdgeCountLoaderFactory = exports.AssocEdgeCountLoader = exports.RawCountLoaderFactory = exports.RawCountLoader = exports.ObjectLoaderFactory = exports.ObjectLoader = void 0;
|
|
4
4
|
var object_loader_1 = require("./object_loader");
|
|
5
5
|
Object.defineProperty(exports, "ObjectLoader", { enumerable: true, get: function () { return object_loader_1.ObjectLoader; } });
|
|
6
6
|
Object.defineProperty(exports, "ObjectLoaderFactory", { enumerable: true, get: function () { return object_loader_1.ObjectLoaderFactory; } });
|
|
@@ -14,9 +14,5 @@ var assoc_edge_loader_1 = require("./assoc_edge_loader");
|
|
|
14
14
|
Object.defineProperty(exports, "AssocDirectEdgeLoader", { enumerable: true, get: function () { return assoc_edge_loader_1.AssocDirectEdgeLoader; } });
|
|
15
15
|
Object.defineProperty(exports, "AssocEdgeLoader", { enumerable: true, get: function () { return assoc_edge_loader_1.AssocEdgeLoader; } });
|
|
16
16
|
Object.defineProperty(exports, "AssocEdgeLoaderFactory", { enumerable: true, get: function () { return assoc_edge_loader_1.AssocEdgeLoaderFactory; } });
|
|
17
|
-
var index_loader_1 = require("./index_loader");
|
|
18
|
-
Object.defineProperty(exports, "IndexLoaderFactory", { enumerable: true, get: function () { return index_loader_1.IndexLoaderFactory; } });
|
|
19
17
|
var query_loader_1 = require("./query_loader");
|
|
20
|
-
Object.defineProperty(exports, "QueryLoader", { enumerable: true, get: function () { return query_loader_1.QueryLoader; } });
|
|
21
|
-
Object.defineProperty(exports, "QueryDirectLoader", { enumerable: true, get: function () { return query_loader_1.QueryDirectLoader; } });
|
|
22
18
|
Object.defineProperty(exports, "QueryLoaderFactory", { enumerable: true, get: function () { return query_loader_1.QueryLoaderFactory; } });
|
package/core/loaders/loader.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Loader, LoaderFactory, Context, DataOptions } from "../base";
|
|
2
|
-
export declare function getLoader<
|
|
3
|
-
export declare function getCustomLoader<
|
|
4
|
-
export declare class
|
|
2
|
+
export declare function getLoader<K, V>(factory: LoaderFactory<K, V>, create: () => Loader<K, V>, context?: Context): Loader<K, V>;
|
|
3
|
+
export declare function getCustomLoader<K, V>(key: string, create: () => Loader<K, V>, context?: Context): Loader<K, V>;
|
|
4
|
+
export declare class CacheMap {
|
|
5
5
|
private options;
|
|
6
6
|
private m;
|
|
7
7
|
constructor(options: DataOptions);
|
package/core/loaders/loader.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.CacheMap = exports.getCustomLoader = exports.getLoader = void 0;
|
|
4
4
|
const logger_1 = require("../logger");
|
|
5
5
|
// this is like factory factory FML
|
|
6
6
|
// helper function to handle context vs not
|
|
@@ -25,7 +25,7 @@ function getCustomLoader(key, create, context) {
|
|
|
25
25
|
return context.cache.getLoader(key, create);
|
|
26
26
|
}
|
|
27
27
|
exports.getCustomLoader = getCustomLoader;
|
|
28
|
-
class
|
|
28
|
+
class CacheMap {
|
|
29
29
|
constructor(options) {
|
|
30
30
|
this.options = options;
|
|
31
31
|
this.m = new Map();
|
|
@@ -37,38 +37,21 @@ class cacheMap {
|
|
|
37
37
|
// might be a lot?
|
|
38
38
|
// TODO this is not the best log format
|
|
39
39
|
// was designed for ObjectLoader time. Now we have different needs e.g. count, assoc etc
|
|
40
|
-
(0, logger_1.log)("
|
|
40
|
+
(0, logger_1.log)("cache", {
|
|
41
41
|
"dataloader-cache-hit": key,
|
|
42
42
|
"tableName": this.options.tableName,
|
|
43
43
|
});
|
|
44
|
-
// } else {
|
|
45
|
-
// log("query", {
|
|
46
|
-
// "dataloader-cache-miss": key,
|
|
47
|
-
// "tableName": options.tableName,
|
|
48
|
-
// });
|
|
49
44
|
}
|
|
50
45
|
return ret;
|
|
51
46
|
}
|
|
52
47
|
set(key, value) {
|
|
53
|
-
// log("query", {
|
|
54
|
-
// "dataloader-cache-set": key,
|
|
55
|
-
// "tableName": options.tableName,
|
|
56
|
-
// });
|
|
57
48
|
return this.m.set(key, value);
|
|
58
49
|
}
|
|
59
50
|
delete(key) {
|
|
60
|
-
// log("query", {
|
|
61
|
-
// "dataloader-cache-delete": key,
|
|
62
|
-
// "tableName": options.tableName,
|
|
63
|
-
// });
|
|
64
51
|
return this.m.delete(key);
|
|
65
52
|
}
|
|
66
53
|
clear() {
|
|
67
|
-
// log("query", {
|
|
68
|
-
// "dataloader-cache-clear": true,
|
|
69
|
-
// "tableName": options.tableName,
|
|
70
|
-
// });
|
|
71
54
|
return this.m.clear();
|
|
72
55
|
}
|
|
73
56
|
}
|
|
74
|
-
exports.
|
|
57
|
+
exports.CacheMap = CacheMap;
|
|
@@ -1,28 +1,49 @@
|
|
|
1
1
|
import { ID, Data, SelectDataOptions, Context, Loader, LoaderFactory } from "../base";
|
|
2
|
-
|
|
2
|
+
import * as clause from "../clause";
|
|
3
|
+
export declare class ObjectLoader<TQueryData extends Data = Data, TResultData extends Data = TQueryData, K = keyof TQueryData> implements Loader<ID, TResultData | null>, Loader<clause.Clause<TQueryData, K>, TResultData[] | null> {
|
|
3
4
|
private options;
|
|
4
5
|
context?: Context<import("../base").Viewer<import("../base").Ent<any> | null, ID | null>> | undefined;
|
|
5
6
|
private toPrime?;
|
|
6
|
-
private
|
|
7
|
+
private idLoader;
|
|
8
|
+
private clauseLoader;
|
|
7
9
|
private primedLoaders;
|
|
8
10
|
private memoizedInitPrime;
|
|
9
|
-
constructor(options: SelectDataOptions, context?: Context<import("../base").Viewer<import("../base").Ent<any> | null, ID | null>> | undefined, toPrime?: ObjectLoaderFactory<
|
|
11
|
+
constructor(options: SelectDataOptions, context?: Context<import("../base").Viewer<import("../base").Ent<any> | null, ID | null>> | undefined, toPrime?: ObjectLoaderFactory<TResultData>[] | undefined);
|
|
10
12
|
getOptions(): SelectDataOptions;
|
|
11
13
|
private initPrime;
|
|
12
|
-
load(key:
|
|
14
|
+
load(key: ID): Promise<TResultData | null>;
|
|
15
|
+
load(key: clause.Clause<TQueryData, K>): Promise<TResultData[] | null>;
|
|
16
|
+
private loadID;
|
|
17
|
+
private loadClause;
|
|
18
|
+
clearAll(): void;
|
|
19
|
+
loadMany(keys: ID[]): Promise<Array<TResultData | null>>;
|
|
20
|
+
loadMany(keys: clause.Clause<TQueryData, K>[]): Promise<Array<TResultData[] | null>>;
|
|
21
|
+
private loadIDMany;
|
|
22
|
+
private loadClauseMany;
|
|
23
|
+
prime(data: TResultData): void;
|
|
24
|
+
primeAll(data: TResultData): void;
|
|
25
|
+
}
|
|
26
|
+
export declare class ObjectCountLoader<V extends Data = Data, K = keyof V> implements Loader<clause.Clause<V, K>, number> {
|
|
27
|
+
private options;
|
|
28
|
+
context?: Context<import("../base").Viewer<import("../base").Ent<any> | null, ID | null>> | undefined;
|
|
29
|
+
private loader;
|
|
30
|
+
constructor(options: SelectDataOptions, context?: Context<import("../base").Viewer<import("../base").Ent<any> | null, ID | null>> | undefined);
|
|
31
|
+
getOptions(): SelectDataOptions;
|
|
32
|
+
load(key: clause.Clause<V, K>): Promise<number>;
|
|
13
33
|
clearAll(): void;
|
|
14
|
-
loadMany(keys:
|
|
15
|
-
prime(data: Data): void;
|
|
34
|
+
loadMany(keys: clause.Clause<V, K>[]): Promise<Array<number>>;
|
|
16
35
|
}
|
|
17
36
|
interface ObjectLoaderOptions extends SelectDataOptions {
|
|
18
37
|
instanceKey?: string;
|
|
19
38
|
}
|
|
20
|
-
export declare class ObjectLoaderFactory<
|
|
39
|
+
export declare class ObjectLoaderFactory<V extends Data = Data> implements LoaderFactory<ID, V | null>, LoaderFactory<clause.Clause<V>, V[] | null> {
|
|
21
40
|
options: ObjectLoaderOptions;
|
|
22
41
|
name: string;
|
|
23
42
|
private toPrime;
|
|
24
43
|
constructor(options: ObjectLoaderOptions);
|
|
25
|
-
createLoader(context?: Context): ObjectLoader<
|
|
26
|
-
|
|
44
|
+
createLoader(context?: Context): ObjectLoader<V>;
|
|
45
|
+
createTypedLoader<TQueryData extends Data = Data, TResultData extends Data = Data, K = keyof TQueryData>(context?: Context): ObjectLoader<TQueryData, TResultData, K>;
|
|
46
|
+
createCountLoader<K = keyof V>(context?: Context): ObjectCountLoader<V, K>;
|
|
47
|
+
addToPrime(factory: ObjectLoaderFactory<V>): this;
|
|
27
48
|
}
|
|
28
49
|
export {};
|