@snowtop/ent 0.1.0-alpha9 → 0.1.0-alpha90
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 +36 -31
- package/action/action.js +2 -6
- package/action/executor.d.ts +3 -3
- package/action/executor.js +2 -2
- package/action/experimental_action.d.ts +29 -22
- package/action/experimental_action.js +29 -6
- package/action/orchestrator.d.ts +38 -16
- package/action/orchestrator.js +219 -61
- package/action/privacy.d.ts +2 -2
- package/core/base.d.ts +45 -24
- package/core/base.js +7 -1
- package/core/clause.d.ts +68 -7
- package/core/clause.js +291 -62
- package/core/config.d.ts +8 -0
- package/core/context.d.ts +5 -3
- package/core/context.js +20 -2
- package/core/convert.d.ts +1 -1
- package/core/db.d.ts +2 -2
- package/core/db.js +1 -1
- package/core/ent.d.ts +79 -24
- package/core/ent.js +520 -168
- package/core/loaders/assoc_count_loader.d.ts +2 -2
- package/core/loaders/assoc_count_loader.js +6 -1
- package/core/loaders/assoc_edge_loader.d.ts +2 -2
- package/core/loaders/index.d.ts +1 -1
- package/core/loaders/index.js +1 -3
- package/core/loaders/index_loader.d.ts +2 -2
- package/core/loaders/loader.js +5 -5
- package/core/loaders/object_loader.d.ts +6 -5
- package/core/loaders/object_loader.js +62 -58
- package/core/loaders/query_loader.d.ts +6 -12
- package/core/loaders/query_loader.js +47 -10
- package/core/loaders/raw_count_loader.d.ts +2 -2
- package/core/logger.d.ts +1 -1
- package/core/logger.js +1 -0
- package/core/privacy.d.ts +26 -25
- package/core/privacy.js +21 -25
- package/core/query/assoc_query.d.ts +6 -6
- package/core/query/custom_clause_query.d.ts +24 -0
- package/core/query/custom_clause_query.js +72 -0
- package/core/query/custom_query.d.ts +20 -5
- package/core/query/custom_query.js +77 -10
- package/core/query/index.d.ts +1 -0
- package/core/query/index.js +3 -1
- package/core/query/query.d.ts +1 -1
- package/core/query/query.js +8 -1
- package/core/query/shared_assoc_test.d.ts +1 -1
- package/core/query/shared_assoc_test.js +17 -5
- package/core/query/shared_test.d.ts +3 -0
- package/core/query/shared_test.js +211 -30
- package/core/viewer.d.ts +3 -3
- package/core/viewer.js +1 -1
- package/graphql/graphql.js +6 -0
- package/graphql/query/edge_connection.d.ts +9 -9
- package/graphql/query/page_info.d.ts +1 -1
- package/index.d.ts +11 -5
- package/index.js +15 -6
- package/package.json +1 -1
- package/parse_schema/parse.d.ts +12 -3
- package/parse_schema/parse.js +70 -11
- package/schema/base_schema.js +3 -0
- package/schema/field.d.ts +44 -8
- package/schema/field.js +125 -9
- package/schema/index.d.ts +2 -2
- package/schema/json_field.d.ts +13 -1
- package/schema/json_field.js +28 -1
- package/schema/schema.d.ts +65 -11
- package/schema/schema.js +18 -4
- package/schema/struct_field.d.ts +11 -1
- package/schema/struct_field.js +44 -5
- package/scripts/custom_graphql.js +8 -3
- package/scripts/{transform_schema.d.ts → migrate_v0.1.d.ts} +0 -0
- package/scripts/migrate_v0.1.js +36 -0
- package/scripts/read_schema.js +15 -4
- package/testutils/builder.d.ts +31 -21
- package/testutils/builder.js +83 -29
- 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} +15 -3
- package/testutils/db/{test_db.js → temp_db.js} +70 -16
- package/testutils/db/value.d.ts +6 -0
- package/testutils/db/value.js +251 -0
- package/testutils/db_time_zone.d.ts +4 -0
- package/testutils/db_time_zone.js +41 -0
- package/testutils/fake_data/fake_contact.d.ts +5 -4
- package/testutils/fake_data/fake_contact.js +14 -6
- package/testutils/fake_data/fake_event.d.ts +5 -3
- package/testutils/fake_data/fake_event.js +8 -5
- package/testutils/fake_data/fake_user.d.ts +4 -4
- package/testutils/fake_data/fake_user.js +16 -13
- package/testutils/fake_data/test_helpers.d.ts +3 -2
- package/testutils/fake_data/test_helpers.js +8 -6
- package/testutils/fake_data/user_query.d.ts +8 -6
- package/testutils/fake_data/user_query.js +28 -21
- package/testutils/fake_log.d.ts +3 -3
- 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 +58 -0
- package/testutils/write.d.ts +2 -2
- package/testutils/write.js +29 -7
- package/tsc/ast.d.ts +44 -0
- package/tsc/ast.js +267 -0
- package/tsc/compilerOptions.d.ts +6 -0
- package/tsc/compilerOptions.js +40 -1
- package/tsc/move_generated.d.ts +1 -0
- package/tsc/move_generated.js +160 -0
- package/tsc/transform.d.ts +21 -0
- package/tsc/transform.js +167 -0
- package/tsc/transform_action.d.ts +22 -0
- package/tsc/transform_action.js +179 -0
- package/tsc/transform_ent.d.ts +17 -0
- package/tsc/transform_ent.js +59 -0
- package/tsc/transform_schema.d.ts +27 -0
- package/tsc/transform_schema.js +379 -0
- package/scripts/transform_schema.js +0 -445
package/action/action.d.ts
CHANGED
|
@@ -1,21 +1,27 @@
|
|
|
1
|
-
import { Ent, EntConstructor, Viewer, ID, Data, PrivacyPolicy, Context } from "../core/base";
|
|
1
|
+
import { Ent, EntConstructor, Viewer, ID, Data, PrivacyPolicy, Context, WriteOperation } from "../core/base";
|
|
2
2
|
import { DataOperation, AssocEdgeInputOptions } from "../core/ent";
|
|
3
3
|
import { Queryer } from "../core/db";
|
|
4
4
|
import { TransformedUpdateOperation, UpdateOperation } from "../schema";
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
5
|
+
import { FieldInfoMap } from "../schema/schema";
|
|
6
|
+
export { WriteOperation };
|
|
7
|
+
declare type MaybeNull<T extends Ent> = T | null;
|
|
8
|
+
declare type TMaybleNullableEnt<T extends Ent> = T | MaybeNull<T>;
|
|
9
|
+
interface BuilderOrchestrator {
|
|
10
|
+
__getOptions(): {
|
|
11
|
+
fieldInfo: FieldInfoMap;
|
|
12
|
+
};
|
|
9
13
|
}
|
|
10
|
-
export interface Builder<
|
|
11
|
-
existingEnt
|
|
12
|
-
ent: EntConstructor<
|
|
14
|
+
export interface Builder<TEnt extends Ent<TViewer>, TViewer extends Viewer = Viewer, TExistingEnt extends TMaybleNullableEnt<TEnt> = MaybeNull<TEnt>> {
|
|
15
|
+
existingEnt: TExistingEnt;
|
|
16
|
+
ent: EntConstructor<TEnt, TViewer>;
|
|
13
17
|
placeholderID: ID;
|
|
14
|
-
readonly viewer:
|
|
15
|
-
build(): Promise<Changeset
|
|
18
|
+
readonly viewer: TViewer;
|
|
19
|
+
build(): Promise<Changeset>;
|
|
16
20
|
operation: WriteOperation;
|
|
17
|
-
editedEnt?(): Promise<
|
|
21
|
+
editedEnt?(): Promise<TEnt | null>;
|
|
18
22
|
nodeType: string;
|
|
23
|
+
getInput(): Data;
|
|
24
|
+
orchestrator: BuilderOrchestrator;
|
|
19
25
|
}
|
|
20
26
|
export interface Executor extends Iterable<DataOperation>, Iterator<DataOperation> {
|
|
21
27
|
placeholderID: ID;
|
|
@@ -25,43 +31,42 @@ export interface Executor extends Iterable<DataOperation>, Iterator<DataOperatio
|
|
|
25
31
|
postFetch?(queryer: Queryer, context?: Context): Promise<void>;
|
|
26
32
|
executeObservers?(): Promise<void>;
|
|
27
33
|
}
|
|
28
|
-
export interface Changeset
|
|
34
|
+
export interface Changeset {
|
|
29
35
|
executor(): Executor;
|
|
30
36
|
viewer: Viewer;
|
|
31
37
|
placeholderID: ID;
|
|
32
|
-
changesets?: Changeset
|
|
38
|
+
changesets?: Changeset[];
|
|
33
39
|
dependencies?: Map<ID, Builder<Ent>>;
|
|
34
40
|
}
|
|
35
|
-
export declare type TriggerReturn = void | Promise<Changeset
|
|
36
|
-
export interface Trigger<TBuilder extends Builder<
|
|
37
|
-
changeset(builder: TBuilder, input:
|
|
41
|
+
export declare type TriggerReturn = void | Promise<Changeset | void | (Changeset | void)[]> | Promise<Changeset>[];
|
|
42
|
+
export interface Trigger<TEnt extends Ent<TViewer>, TBuilder extends Builder<TEnt, TViewer, TExistingEnt>, TViewer extends Viewer = Viewer, TInput extends Data = Data, TExistingEnt extends TMaybleNullableEnt<TEnt> = MaybeNull<TEnt>> {
|
|
43
|
+
changeset(builder: TBuilder, input: TInput): TriggerReturn;
|
|
38
44
|
}
|
|
39
|
-
export interface Observer<TBuilder extends Builder<
|
|
40
|
-
observe(builder: TBuilder, input:
|
|
45
|
+
export interface Observer<TEnt extends Ent<TViewer>, TBuilder extends Builder<TEnt, TViewer, TExistingEnt>, TViewer extends Viewer = Viewer, TInput extends Data = Data, TExistingEnt extends TMaybleNullableEnt<TEnt> = MaybeNull<TEnt>> {
|
|
46
|
+
observe(builder: TBuilder, input: TInput): void | Promise<void>;
|
|
41
47
|
}
|
|
42
|
-
export interface Validator<TBuilder extends Builder<
|
|
43
|
-
validate(builder: TBuilder, input:
|
|
48
|
+
export interface Validator<TEnt extends Ent<TViewer>, TBuilder extends Builder<TEnt, TViewer, TExistingEnt>, TViewer extends Viewer = Viewer, TInput extends Data = Data, TExistingEnt extends TMaybleNullableEnt<TEnt> = MaybeNull<TEnt>> {
|
|
49
|
+
validate(builder: TBuilder, input: TInput): Promise<void | undefined | Error> | void | Error | undefined;
|
|
44
50
|
}
|
|
45
|
-
export interface Action<TEnt extends Ent
|
|
51
|
+
export interface Action<TEnt extends Ent<TViewer>, TBuilder extends Builder<TEnt, TViewer, TExistingEnt>, TViewer extends Viewer = Viewer, TInput extends Data = Data, TExistingEnt extends TMaybleNullableEnt<TEnt> = MaybeNull<TEnt>> {
|
|
46
52
|
readonly viewer: Viewer;
|
|
47
|
-
changeset(): Promise<Changeset
|
|
53
|
+
changeset(): Promise<Changeset>;
|
|
48
54
|
builder: TBuilder;
|
|
49
55
|
getPrivacyPolicy(): PrivacyPolicy<TEnt>;
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
getInput():
|
|
54
|
-
transformWrite?:
|
|
56
|
+
getTriggers?(): (Trigger<TEnt, TBuilder, TViewer, TInput, TExistingEnt> | Trigger<TEnt, TBuilder, TViewer, TInput, TExistingEnt>[])[];
|
|
57
|
+
getObservers?(): Observer<TEnt, TBuilder, TViewer, TInput, TExistingEnt>[];
|
|
58
|
+
getValidators?(): Validator<TEnt, TBuilder, TViewer, TInput, TExistingEnt>[];
|
|
59
|
+
getInput(): TInput;
|
|
60
|
+
transformWrite?: (stmt: UpdateOperation<TEnt, TViewer>) => Promise<TransformedUpdateOperation<TEnt, TViewer>> | TransformedUpdateOperation<TEnt, TViewer> | null;
|
|
55
61
|
valid(): Promise<boolean>;
|
|
56
62
|
validX(): Promise<void>;
|
|
57
|
-
viewerForEntLoad?(data: Data):
|
|
63
|
+
viewerForEntLoad?(data: Data, context?: Context<TViewer>): TViewer | Promise<TViewer>;
|
|
58
64
|
}
|
|
59
|
-
export declare function saveBuilder<
|
|
60
|
-
export declare function saveBuilderX<
|
|
65
|
+
export declare function saveBuilder<TEnt extends Ent<TViewer>, TViewer extends Viewer>(builder: Builder<TEnt, TViewer>): Promise<void>;
|
|
66
|
+
export declare function saveBuilderX<TEnt extends Ent<TViewer>, TViewer extends Viewer>(builder: Builder<TEnt, TViewer>): Promise<void>;
|
|
61
67
|
interface Orchestrator {
|
|
62
68
|
addOutboundEdge<T2 extends Ent>(id2: ID | Builder<T2>, edgeType: string, nodeType: string, options?: AssocEdgeInputOptions): void;
|
|
63
69
|
removeOutboundEdge(id2: ID, edgeType: string): void;
|
|
64
70
|
viewer: Viewer;
|
|
65
71
|
}
|
|
66
72
|
export declare function setEdgeTypeInGroup<T extends string>(orchestrator: Orchestrator, inputEnumValue: string, id1: ID, id2: ID, nodeType: string, m: Map<T, string>): Promise<void>;
|
|
67
|
-
export {};
|
package/action/action.js
CHANGED
|
@@ -1,14 +1,10 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.setEdgeTypeInGroup = exports.saveBuilderX = exports.saveBuilder = exports.WriteOperation = void 0;
|
|
4
|
+
const base_1 = require("../core/base");
|
|
5
|
+
Object.defineProperty(exports, "WriteOperation", { enumerable: true, get: function () { return base_1.WriteOperation; } });
|
|
4
6
|
const ent_1 = require("../core/ent");
|
|
5
7
|
const logger_1 = require("../core/logger");
|
|
6
|
-
var WriteOperation;
|
|
7
|
-
(function (WriteOperation) {
|
|
8
|
-
WriteOperation["Insert"] = "insert";
|
|
9
|
-
WriteOperation["Edit"] = "edit";
|
|
10
|
-
WriteOperation["Delete"] = "delete";
|
|
11
|
-
})(WriteOperation = exports.WriteOperation || (exports.WriteOperation = {}));
|
|
12
8
|
async function saveBuilder(builder) {
|
|
13
9
|
await saveBuilderImpl(builder, false);
|
|
14
10
|
}
|
package/action/executor.d.ts
CHANGED
|
@@ -10,7 +10,7 @@ export declare class ListBasedExecutor<T extends Ent> implements Executor {
|
|
|
10
10
|
private operations;
|
|
11
11
|
private options?;
|
|
12
12
|
private idx;
|
|
13
|
-
constructor(viewer: Viewer, placeholderID: ID, operations: DataOperation<T>[], options?: OrchestratorOptions<T, Data> | undefined);
|
|
13
|
+
constructor(viewer: Viewer, placeholderID: ID, operations: DataOperation<T>[], options?: OrchestratorOptions<T, Data, Viewer<Ent<any> | null, ID | null>, T | null> | undefined);
|
|
14
14
|
private lastOp;
|
|
15
15
|
private createdEnt;
|
|
16
16
|
resolveValue(val: ID): Ent | null;
|
|
@@ -29,7 +29,7 @@ export declare class ComplexExecutor<T extends Ent> implements Executor {
|
|
|
29
29
|
private lastOp;
|
|
30
30
|
private allOperations;
|
|
31
31
|
private executors;
|
|
32
|
-
constructor(viewer: Viewer, placeholderID: ID, operations: DataOperation[], dependencies: Map<ID, Builder<T>>, changesets: Changeset
|
|
32
|
+
constructor(viewer: Viewer, placeholderID: ID, operations: DataOperation[], dependencies: Map<ID, Builder<T>>, changesets: Changeset[], options?: OrchestratorOptions<T, Data, Viewer>);
|
|
33
33
|
[Symbol.iterator](): this;
|
|
34
34
|
private handleCreatedEnt;
|
|
35
35
|
next(): IteratorResult<DataOperation<Ent>>;
|
|
@@ -39,4 +39,4 @@ export declare class ComplexExecutor<T extends Ent> implements Executor {
|
|
|
39
39
|
preFetch?(queryer: Queryer, context: Context): Promise<void>;
|
|
40
40
|
postFetch?(queryer: Queryer, context: Context): Promise<void>;
|
|
41
41
|
}
|
|
42
|
-
export declare function executeOperations(executor: Executor, context?: Context, trackOps?: true): Promise<DataOperation<Ent>[]>;
|
|
42
|
+
export declare function executeOperations(executor: Executor, context?: Context, trackOps?: true): Promise<DataOperation<Ent<Viewer<Ent<any> | null, ID | null>>>[]>;
|
package/action/executor.js
CHANGED
|
@@ -47,11 +47,11 @@ class ListBasedExecutor {
|
|
|
47
47
|
}
|
|
48
48
|
async executeObservers() {
|
|
49
49
|
const action = this.options?.action;
|
|
50
|
-
if (!this.options || !action || !action.
|
|
50
|
+
if (!this.options || !action || !action.getObservers) {
|
|
51
51
|
return;
|
|
52
52
|
}
|
|
53
53
|
const builder = this.options.builder;
|
|
54
|
-
await Promise.all(action.
|
|
54
|
+
await Promise.all(action.getObservers().map(async (observer) => {
|
|
55
55
|
await observer.observe(builder, action.getInput());
|
|
56
56
|
}));
|
|
57
57
|
}
|
|
@@ -1,40 +1,47 @@
|
|
|
1
|
+
import { Orchestrator } from "./orchestrator";
|
|
1
2
|
import { Viewer, Ent, Data } from "../core/base";
|
|
2
3
|
import { Action, WriteOperation, Builder, Trigger, Observer, Changeset, Validator } from "./action";
|
|
3
|
-
export interface ActionOptions<
|
|
4
|
-
existingEnt
|
|
4
|
+
export interface ActionOptions<TEnt extends Ent<TViewer>, TViewer extends Viewer, TData extends Data, TExistingEnt extends TMaybleNullableEnt<TEnt> = MaybeNull<TEnt>> {
|
|
5
|
+
existingEnt: TExistingEnt;
|
|
5
6
|
input?: TData;
|
|
6
7
|
operation?: WriteOperation;
|
|
7
8
|
}
|
|
8
|
-
|
|
9
|
+
declare type MaybeNull<T extends Ent> = T | null;
|
|
10
|
+
declare type TMaybleNullableEnt<T extends Ent> = T | MaybeNull<T>;
|
|
11
|
+
export interface EntBuilder<TEnt extends Ent<TViewer>, TViewer extends Viewer, TInput extends Data, TExistingEnt extends TMaybleNullableEnt<TEnt> = MaybeNull<TEnt>> extends Builder<TEnt, TViewer, TExistingEnt> {
|
|
9
12
|
valid(): Promise<boolean>;
|
|
10
13
|
validX(): Promise<void>;
|
|
11
14
|
save(): Promise<void>;
|
|
12
15
|
saveX(): Promise<void>;
|
|
13
|
-
editedEnt(): Promise<
|
|
14
|
-
editedEntX(): Promise<
|
|
16
|
+
editedEnt(): Promise<TEnt | null>;
|
|
17
|
+
editedEntX(): Promise<TEnt>;
|
|
18
|
+
getInput(): TInput;
|
|
19
|
+
orchestrator: Orchestrator<TEnt, TInput, TViewer, TExistingEnt>;
|
|
15
20
|
}
|
|
16
|
-
export declare class BaseAction<TEnt extends Ent,
|
|
17
|
-
viewer:
|
|
18
|
-
builderCtr: BuilderConstructor<TEnt,
|
|
19
|
-
builder: EntBuilder<TEnt>;
|
|
21
|
+
export declare class BaseAction<TEnt extends Ent<TViewer>, TViewer extends Viewer, TInput extends Data, TExistingEnt extends TMaybleNullableEnt<TEnt> = MaybeNull<TEnt>> implements Action<TEnt, EntBuilder<TEnt, TViewer, TInput, TExistingEnt>, TViewer, TInput, TExistingEnt> {
|
|
22
|
+
viewer: TViewer;
|
|
23
|
+
builderCtr: BuilderConstructor<TEnt, TViewer, TInput, TExistingEnt>;
|
|
24
|
+
builder: EntBuilder<TEnt, TViewer, TInput, TExistingEnt>;
|
|
20
25
|
private input;
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
constructor(viewer:
|
|
26
|
-
static createBuilder<TEnt extends Ent,
|
|
27
|
-
static bulkAction<TEnt extends Ent,
|
|
28
|
-
changeset(): Promise<Changeset
|
|
26
|
+
getPrivacyPolicy(): import("../core/base").PrivacyPolicy<Ent<Viewer<Ent<any> | null, import("../core/base").ID | null>>, Viewer<Ent<any> | null, import("../core/base").ID | null>>;
|
|
27
|
+
getTriggers(): Trigger<TEnt, EntBuilder<TEnt, TViewer, TInput, TExistingEnt>, TViewer, TInput, TExistingEnt>[];
|
|
28
|
+
getObservers(): Observer<TEnt, EntBuilder<TEnt, TViewer, TInput, TExistingEnt>, TViewer, TInput, TExistingEnt>[];
|
|
29
|
+
getValidators(): Validator<TEnt, EntBuilder<TEnt, TViewer, TInput, TExistingEnt>, TViewer, TInput, TExistingEnt>[];
|
|
30
|
+
constructor(viewer: TViewer, builderCtr: BuilderConstructor<TEnt, TViewer, TInput, TExistingEnt>, options: ActionOptions<TEnt, TViewer, TInput, TExistingEnt>);
|
|
31
|
+
static createBuilder<TEnt extends Ent<TViewer>, TViewer extends Viewer, TInput extends Data, TExistingEnt extends TMaybleNullableEnt<TEnt> = MaybeNull<TEnt>>(viewer: Viewer, builderCtr: BuilderConstructor<TEnt, TViewer, TInput, TExistingEnt>, options: ActionOptions<TEnt, TViewer, TInput, TExistingEnt>): Builder<TEnt>;
|
|
32
|
+
static bulkAction<TEnt extends Ent<TViewer>, TViewer extends Viewer, TInput extends Data>(ent: TEnt, builderCtr: BuilderConstructor<TEnt, TViewer, TInput, TEnt>, ...actions: Action<Ent, Builder<Ent, any>>[]): BaseAction<TEnt, TViewer, TInput, TEnt>;
|
|
33
|
+
changeset(): Promise<Changeset>;
|
|
29
34
|
valid(): Promise<boolean>;
|
|
30
35
|
validX(): Promise<void>;
|
|
31
36
|
save(): Promise<TEnt | null>;
|
|
32
37
|
saveX(): Promise<TEnt>;
|
|
33
|
-
getInput():
|
|
38
|
+
getInput(): TInput;
|
|
34
39
|
}
|
|
35
|
-
interface BuilderConstructor<TEnt extends Ent,
|
|
36
|
-
new (viewer:
|
|
40
|
+
export interface BuilderConstructor<TEnt extends Ent<TViewer>, TViewer extends Viewer, TInput extends Data, TExistingEnt extends TMaybleNullableEnt<TEnt> = MaybeNull<TEnt>> {
|
|
41
|
+
new (viewer: TViewer, operation: WriteOperation, action: Action<TEnt, any, TViewer, TInput, TExistingEnt>, existingEnt: TExistingEnt): EntBuilder<TEnt, TViewer, TInput, TExistingEnt>;
|
|
37
42
|
}
|
|
38
|
-
export declare function updateRawObject<TEnt extends Ent, TInput extends Data>(viewer:
|
|
39
|
-
export declare function getSimpleEditAction<TEnt extends Ent, TInput extends Data>(viewer:
|
|
43
|
+
export declare function updateRawObject<TEnt extends Ent<TViewer>, TViewer extends Viewer, TInput extends Data>(viewer: TViewer, builderCtr: BuilderConstructor<TEnt, TViewer, TInput, TEnt>, existingEnt: TEnt, input: TInput): Promise<TEnt>;
|
|
44
|
+
export declare function getSimpleEditAction<TEnt extends Ent<TViewer>, TViewer extends Viewer, TInput extends Data>(viewer: TViewer, builderCtr: BuilderConstructor<TEnt, TViewer, TInput, TEnt>, existingEnt: TEnt, input: TInput): BaseAction<TEnt, TViewer, TInput, TEnt>;
|
|
45
|
+
export declare function getSimpleDeleteAction<TEnt extends Ent<TViewer>, TViewer extends Viewer, TInput extends Data>(viewer: TViewer, builderCtr: BuilderConstructor<TEnt, TViewer, TInput, TEnt>, existingEnt: TEnt, input: TInput): BaseAction<TEnt, TViewer, TInput, TEnt>;
|
|
46
|
+
export declare function getSimpleInsertAction<TEnt extends Ent<TViewer>, TViewer extends Viewer, TInput extends Data>(viewer: TViewer, builderCtr: BuilderConstructor<TEnt, TViewer, TInput, null>, input: TInput): BaseAction<TEnt, TViewer, TInput, null>;
|
|
40
47
|
export {};
|
|
@@ -1,15 +1,12 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getSimpleEditAction = exports.updateRawObject = exports.BaseAction = void 0;
|
|
3
|
+
exports.getSimpleInsertAction = exports.getSimpleDeleteAction = exports.getSimpleEditAction = exports.updateRawObject = exports.BaseAction = void 0;
|
|
4
4
|
const privacy_1 = require("../core/privacy");
|
|
5
5
|
const action_1 = require("./action");
|
|
6
6
|
class BaseAction {
|
|
7
7
|
constructor(viewer, builderCtr, options) {
|
|
8
8
|
this.viewer = viewer;
|
|
9
9
|
this.builderCtr = builderCtr;
|
|
10
|
-
this.triggers = [];
|
|
11
|
-
this.observers = [];
|
|
12
|
-
this.validators = [];
|
|
13
10
|
let operation = options?.operation;
|
|
14
11
|
if (!operation) {
|
|
15
12
|
if (options?.existingEnt) {
|
|
@@ -20,11 +17,20 @@ class BaseAction {
|
|
|
20
17
|
}
|
|
21
18
|
}
|
|
22
19
|
this.input = options?.input || {};
|
|
23
|
-
this.builder = new builderCtr(viewer, operation, this, options
|
|
20
|
+
this.builder = new builderCtr(viewer, operation, this, options.existingEnt);
|
|
24
21
|
}
|
|
25
22
|
getPrivacyPolicy() {
|
|
26
23
|
return privacy_1.AlwaysAllowPrivacyPolicy;
|
|
27
24
|
}
|
|
25
|
+
getTriggers() {
|
|
26
|
+
return [];
|
|
27
|
+
}
|
|
28
|
+
getObservers() {
|
|
29
|
+
return [];
|
|
30
|
+
}
|
|
31
|
+
getValidators() {
|
|
32
|
+
return [];
|
|
33
|
+
}
|
|
28
34
|
static createBuilder(viewer, builderCtr, options) {
|
|
29
35
|
let action = new BaseAction(viewer, builderCtr, options);
|
|
30
36
|
return action.builder;
|
|
@@ -35,7 +41,7 @@ class BaseAction {
|
|
|
35
41
|
let action = new BaseAction(ent.viewer, builderCtr, {
|
|
36
42
|
existingEnt: ent,
|
|
37
43
|
});
|
|
38
|
-
action.
|
|
44
|
+
action.getTriggers = () => [
|
|
39
45
|
{
|
|
40
46
|
changeset: () => {
|
|
41
47
|
return actions.map((action) => action.changeset());
|
|
@@ -79,6 +85,7 @@ async function updateRawObject(viewer, builderCtr, existingEnt, input) {
|
|
|
79
85
|
return action.saveX();
|
|
80
86
|
}
|
|
81
87
|
exports.updateRawObject = updateRawObject;
|
|
88
|
+
// TODO need to fix types for all these
|
|
82
89
|
// creates an action which has no privacy, triggers, observers etc
|
|
83
90
|
// does do field validation
|
|
84
91
|
// useful to batch a bunch of writes together with BaseAction.bulkAction
|
|
@@ -91,3 +98,19 @@ function getSimpleEditAction(viewer, builderCtr, existingEnt, input) {
|
|
|
91
98
|
});
|
|
92
99
|
}
|
|
93
100
|
exports.getSimpleEditAction = getSimpleEditAction;
|
|
101
|
+
function getSimpleDeleteAction(viewer, builderCtr, existingEnt, input) {
|
|
102
|
+
return new BaseAction(viewer, builderCtr, {
|
|
103
|
+
existingEnt: existingEnt,
|
|
104
|
+
operation: action_1.WriteOperation.Delete,
|
|
105
|
+
input,
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
exports.getSimpleDeleteAction = getSimpleDeleteAction;
|
|
109
|
+
function getSimpleInsertAction(viewer, builderCtr, input) {
|
|
110
|
+
return new BaseAction(viewer, builderCtr, {
|
|
111
|
+
operation: action_1.WriteOperation.Insert,
|
|
112
|
+
input,
|
|
113
|
+
existingEnt: null,
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
exports.getSimpleInsertAction = getSimpleInsertAction;
|
package/action/orchestrator.d.ts
CHANGED
|
@@ -1,19 +1,22 @@
|
|
|
1
1
|
import { ID, Data, Ent, Viewer, EntConstructor, LoadEntOptions } from "../core/base";
|
|
2
2
|
import { AssocEdgeInputOptions, DataOperation } from "../core/ent";
|
|
3
|
-
import { SchemaInputType } from "../schema/schema";
|
|
3
|
+
import { SchemaInputType, FieldInfoMap } from "../schema/schema";
|
|
4
4
|
import { Changeset, Executor } from "../action/action";
|
|
5
5
|
import { WriteOperation, Builder, Action } from "../action";
|
|
6
|
-
|
|
6
|
+
declare type MaybeNull<T extends Ent> = T | null;
|
|
7
|
+
declare type TMaybleNullableEnt<T extends Ent> = T | MaybeNull<T>;
|
|
8
|
+
export interface OrchestratorOptions<TEnt extends Ent<TViewer>, TInput extends Data, TViewer extends Viewer, TExistingEnt extends TMaybleNullableEnt<TEnt> = MaybeNull<TEnt>> {
|
|
7
9
|
viewer: Viewer;
|
|
8
10
|
operation: WriteOperation;
|
|
9
11
|
tableName: string;
|
|
10
|
-
loaderOptions: LoadEntOptions<TEnt>;
|
|
12
|
+
loaderOptions: LoadEntOptions<TEnt, TViewer>;
|
|
11
13
|
key: string;
|
|
12
|
-
builder: Builder<TEnt>;
|
|
13
|
-
action?: Action<TEnt, Builder<TEnt>,
|
|
14
|
+
builder: Builder<TEnt, TViewer, TExistingEnt>;
|
|
15
|
+
action?: Action<TEnt, Builder<TEnt, TViewer>, TViewer, TInput>;
|
|
14
16
|
schema: SchemaInputType;
|
|
15
17
|
editedFields(): Map<string, any> | Promise<Map<string, any>>;
|
|
16
|
-
updateInput?: (data:
|
|
18
|
+
updateInput?: (data: TInput) => void;
|
|
19
|
+
fieldInfo: FieldInfoMap;
|
|
17
20
|
}
|
|
18
21
|
interface edgeInputDataOpts {
|
|
19
22
|
edgeType: string;
|
|
@@ -28,7 +31,7 @@ export declare enum edgeDirection {
|
|
|
28
31
|
inboundEdge = 0,
|
|
29
32
|
outboundEdge = 1
|
|
30
33
|
}
|
|
31
|
-
export declare class Orchestrator<TEnt extends Ent,
|
|
34
|
+
export declare class Orchestrator<TEnt extends Ent<TViewer>, TInput extends Data, TViewer extends Viewer, TExistingEnt extends TMaybleNullableEnt<TEnt> = MaybeNull<TEnt>> {
|
|
32
35
|
private options;
|
|
33
36
|
private edgeSet;
|
|
34
37
|
private edges;
|
|
@@ -42,13 +45,15 @@ export declare class Orchestrator<TEnt extends Ent, TData extends Data> {
|
|
|
42
45
|
private defaultFieldsByFieldName;
|
|
43
46
|
private defaultFieldsByTSName;
|
|
44
47
|
private actualOperation;
|
|
45
|
-
private existingEnt
|
|
48
|
+
private existingEnt;
|
|
46
49
|
private disableTransformations;
|
|
47
|
-
|
|
50
|
+
private memoizedGetFields;
|
|
51
|
+
constructor(options: OrchestratorOptions<TEnt, TInput, TViewer, TExistingEnt>);
|
|
52
|
+
__getOptions(): OrchestratorOptions<any, any, any, any>;
|
|
48
53
|
private addEdge;
|
|
49
54
|
setDisableTransformations(val: boolean): void;
|
|
50
|
-
addInboundEdge<T2 extends Ent>(id1: ID | Builder<T2>, edgeType: string, nodeType: string, options?: AssocEdgeInputOptions): void;
|
|
51
|
-
addOutboundEdge<T2 extends Ent>(id2: ID | Builder<T2>, edgeType: string, nodeType: string, options?: AssocEdgeInputOptions): void;
|
|
55
|
+
addInboundEdge<T2 extends Ent>(id1: ID | Builder<T2, any>, edgeType: string, nodeType: string, options?: AssocEdgeInputOptions): void;
|
|
56
|
+
addOutboundEdge<T2 extends Ent>(id2: ID | Builder<T2, any>, edgeType: string, nodeType: string, options?: AssocEdgeInputOptions): void;
|
|
52
57
|
removeInboundEdge(id1: ID, edgeType: string): void;
|
|
53
58
|
removeOutboundEdge(id2: ID, edgeType: string): void;
|
|
54
59
|
getInputEdges(edgeType: string, op: WriteOperation): EdgeInputData[];
|
|
@@ -60,34 +65,51 @@ export declare class Orchestrator<TEnt extends Ent, TData extends Data> {
|
|
|
60
65
|
private getEntForPrivacyPolicyImpl;
|
|
61
66
|
private getSQLStatementOperation;
|
|
62
67
|
private getWriteOpForSQLStamentOp;
|
|
63
|
-
getPossibleUnsafeEntForPrivacy(): Promise<TEnt
|
|
68
|
+
getPossibleUnsafeEntForPrivacy(): Promise<TEnt>;
|
|
69
|
+
getEditedData(): Promise<Data>;
|
|
70
|
+
/**
|
|
71
|
+
* @returns validated and formatted fields that would be written to the db
|
|
72
|
+
* throws an error if called before valid() or validX() has been called
|
|
73
|
+
*/
|
|
74
|
+
getValidatedFields(): Data;
|
|
64
75
|
private getFieldsInfo;
|
|
65
76
|
private validate;
|
|
66
77
|
private triggers;
|
|
67
78
|
private validators;
|
|
68
79
|
private isBuilder;
|
|
80
|
+
private getInputKey;
|
|
81
|
+
private getStorageKey;
|
|
69
82
|
private getFieldsWithDefaultValues;
|
|
70
83
|
private hasData;
|
|
71
84
|
private transformFieldValue;
|
|
72
85
|
private formatAndValidateFields;
|
|
73
86
|
valid(): Promise<boolean>;
|
|
74
87
|
validX(): Promise<void>;
|
|
88
|
+
/**
|
|
89
|
+
* @experimental API that's not guaranteed to remain in the future which returns
|
|
90
|
+
* a list of errors encountered
|
|
91
|
+
* 0 errors indicates valid
|
|
92
|
+
* NOTE that this currently doesn't catch errors returned by validators().
|
|
93
|
+
* If those throws, this still throws and doesn't return them
|
|
94
|
+
*/
|
|
95
|
+
validWithErrors(): Promise<Error[]>;
|
|
75
96
|
build(): Promise<EntChangeset<TEnt>>;
|
|
76
97
|
private viewerForEntLoad;
|
|
77
98
|
returnedRow(): Promise<Data | null>;
|
|
78
99
|
editedEnt(): Promise<TEnt | null>;
|
|
79
100
|
editedEntX(): Promise<TEnt>;
|
|
80
101
|
}
|
|
81
|
-
export declare class EntChangeset<T extends Ent> implements Changeset
|
|
102
|
+
export declare class EntChangeset<T extends Ent> implements Changeset {
|
|
82
103
|
viewer: Viewer;
|
|
83
104
|
readonly placeholderID: ID;
|
|
84
105
|
readonly ent: EntConstructor<T>;
|
|
85
106
|
operations: DataOperation[];
|
|
86
|
-
dependencies?: Map<ID, Builder<Ent>> | undefined;
|
|
87
|
-
changesets?: Changeset
|
|
107
|
+
dependencies?: Map<ID, Builder<Ent<Viewer<Ent<any> | null, ID | null>>, Viewer<Ent<any> | null, ID | null>, Ent<Viewer<Ent<any> | null, ID | null>> | null>> | undefined;
|
|
108
|
+
changesets?: Changeset[] | undefined;
|
|
88
109
|
private options?;
|
|
89
110
|
private _executor;
|
|
90
|
-
constructor(viewer: Viewer, placeholderID: ID, ent: EntConstructor<T>, operations: DataOperation[], dependencies?: Map<ID, Builder<Ent>> | undefined, changesets?: Changeset
|
|
111
|
+
constructor(viewer: Viewer, placeholderID: ID, ent: EntConstructor<T>, operations: DataOperation[], dependencies?: Map<ID, Builder<Ent<Viewer<Ent<any> | null, ID | null>>, Viewer<Ent<any> | null, ID | null>, Ent<Viewer<Ent<any> | null, ID | null>> | null>> | undefined, changesets?: Changeset[] | undefined, options?: OrchestratorOptions<T, Data, Viewer<Ent<any> | null, ID | null>, MaybeNull<T>> | undefined);
|
|
112
|
+
static changesetFrom(builder: Builder<any, any, any>, ops: DataOperation[]): EntChangeset<any>;
|
|
91
113
|
executor(): Executor;
|
|
92
114
|
}
|
|
93
115
|
export {};
|