@snowtop/ent 0.1.0-alpha13 → 0.1.0-alpha16

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.
Files changed (39) hide show
  1. package/action/action.d.ts +19 -19
  2. package/action/executor.d.ts +3 -3
  3. package/action/executor.js +2 -2
  4. package/action/experimental_action.d.ts +21 -20
  5. package/action/experimental_action.js +10 -4
  6. package/action/orchestrator.d.ts +13 -13
  7. package/action/orchestrator.js +6 -4
  8. package/action/privacy.d.ts +2 -2
  9. package/core/base.d.ts +20 -20
  10. package/core/config.d.ts +5 -0
  11. package/core/context.d.ts +2 -2
  12. package/core/ent.d.ts +13 -13
  13. package/core/loaders/assoc_count_loader.d.ts +2 -2
  14. package/core/loaders/assoc_edge_loader.d.ts +2 -2
  15. package/core/loaders/object_loader.d.ts +3 -3
  16. package/core/loaders/query_loader.d.ts +2 -2
  17. package/core/loaders/raw_count_loader.d.ts +2 -2
  18. package/core/privacy.d.ts +24 -24
  19. package/core/query/assoc_query.d.ts +6 -6
  20. package/core/query/custom_query.d.ts +5 -5
  21. package/core/query/query.d.ts +1 -1
  22. package/core/viewer.d.ts +3 -3
  23. package/graphql/query/edge_connection.d.ts +9 -9
  24. package/graphql/query/page_info.d.ts +1 -1
  25. package/package.json +1 -1
  26. package/parse_schema/parse.d.ts +2 -0
  27. package/parse_schema/parse.js +4 -0
  28. package/schema/base_schema.js +3 -0
  29. package/schema/schema.d.ts +1 -0
  30. package/scripts/move_generated.js +2 -3
  31. package/scripts/transform_actions.d.ts +1 -0
  32. package/scripts/transform_actions.js +266 -0
  33. package/scripts/transform_code.js +1 -3
  34. package/testutils/builder.d.ts +10 -9
  35. package/testutils/builder.js +16 -3
  36. package/testutils/fake_data/user_query.d.ts +2 -2
  37. package/testutils/fake_log.d.ts +3 -3
  38. package/tsc/ast.d.ts +11 -0
  39. package/tsc/ast.js +46 -13
@@ -9,14 +9,14 @@ export declare enum WriteOperation {
9
9
  }
10
10
  declare type MaybeNull<T extends Ent> = T | null;
11
11
  declare type TMaybleNullableEnt<T extends Ent> = T | MaybeNull<T>;
12
- export interface Builder<T extends Ent, TExistingEnt extends TMaybleNullableEnt<T> = MaybeNull<T>> {
12
+ export interface Builder<TEnt extends Ent<TViewer>, TViewer extends Viewer = Viewer, TExistingEnt extends TMaybleNullableEnt<TEnt> = MaybeNull<TEnt>> {
13
13
  existingEnt: TExistingEnt;
14
- ent: EntConstructor<T>;
14
+ ent: EntConstructor<TEnt, TViewer>;
15
15
  placeholderID: ID;
16
- readonly viewer: Viewer;
17
- build(): Promise<Changeset<T>>;
16
+ readonly viewer: TViewer;
17
+ build(): Promise<Changeset>;
18
18
  operation: WriteOperation;
19
- editedEnt?(): Promise<T | null>;
19
+ editedEnt?(): Promise<TEnt | null>;
20
20
  nodeType: string;
21
21
  }
22
22
  export interface Executor extends Iterable<DataOperation>, Iterator<DataOperation> {
@@ -27,39 +27,39 @@ export interface Executor extends Iterable<DataOperation>, Iterator<DataOperatio
27
27
  postFetch?(queryer: Queryer, context?: Context): Promise<void>;
28
28
  executeObservers?(): Promise<void>;
29
29
  }
30
- export interface Changeset<T extends Ent> {
30
+ export interface Changeset {
31
31
  executor(): Executor;
32
32
  viewer: Viewer;
33
33
  placeholderID: ID;
34
- changesets?: Changeset<Ent>[];
34
+ changesets?: Changeset[];
35
35
  dependencies?: Map<ID, Builder<Ent>>;
36
36
  }
37
- export declare type TriggerReturn = void | Promise<Changeset<Ent> | void | (Changeset<Ent> | void)[]> | Promise<Changeset<Ent>>[];
38
- export interface Trigger<TEnt extends Ent, TBuilder extends Builder<TEnt, TExistingEnt>, TInput extends Data = Data, TExistingEnt extends TMaybleNullableEnt<TEnt> = MaybeNull<TEnt>> {
37
+ export declare type TriggerReturn = void | Promise<Changeset | void | (Changeset | void)[]> | Promise<Changeset>[];
38
+ 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>> {
39
39
  changeset(builder: TBuilder, input: TInput): TriggerReturn;
40
40
  }
41
- export interface Observer<TEnt extends Ent, TBuilder extends Builder<TEnt, TExistingEnt>, TInput extends Data = Data, TExistingEnt extends TMaybleNullableEnt<TEnt> = MaybeNull<TEnt>> {
41
+ 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>> {
42
42
  observe(builder: TBuilder, input: TInput): void | Promise<void>;
43
43
  }
44
- export interface Validator<TEnt extends Ent, TBuilder extends Builder<TEnt, TExistingEnt>, TInput extends Data, TExistingEnt extends TMaybleNullableEnt<TEnt> = MaybeNull<TEnt>> {
44
+ 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>> {
45
45
  validate(builder: TBuilder, input: TInput): Promise<void> | void;
46
46
  }
47
- export interface Action<TEnt extends Ent, TBuilder extends Builder<TEnt, TExistingEnt>, TInput extends Data, TExistingEnt extends TMaybleNullableEnt<TEnt> = MaybeNull<TEnt>> {
47
+ 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>> {
48
48
  readonly viewer: Viewer;
49
- changeset(): Promise<Changeset<TEnt>>;
49
+ changeset(): Promise<Changeset>;
50
50
  builder: TBuilder;
51
51
  getPrivacyPolicy(): PrivacyPolicy<TEnt>;
52
- triggers?: Trigger<TEnt, TBuilder, TInput, TExistingEnt>[];
53
- observers?: Observer<TEnt, TBuilder, TInput, TExistingEnt>[];
54
- validators?: Validator<TEnt, TBuilder, TInput, TExistingEnt>[];
52
+ getTriggers?(): Trigger<TEnt, TBuilder, TViewer, TInput, TExistingEnt>[];
53
+ getObservers?(): Observer<TEnt, TBuilder, TViewer, TInput, TExistingEnt>[];
54
+ getValidators?(): Validator<TEnt, TBuilder, TViewer, TInput, TExistingEnt>[];
55
55
  getInput(): TInput;
56
56
  transformWrite?: (stmt: UpdateOperation<TEnt>) => Promise<TransformedUpdateOperation<TEnt>> | TransformedUpdateOperation<TEnt> | null;
57
57
  valid(): Promise<boolean>;
58
58
  validX(): Promise<void>;
59
- viewerForEntLoad?(data: Data): Viewer | Promise<Viewer>;
59
+ viewerForEntLoad?(data: Data): TViewer | Promise<TViewer>;
60
60
  }
61
- export declare function saveBuilder<T extends Ent>(builder: Builder<T>): Promise<void>;
62
- export declare function saveBuilderX<T extends Ent>(builder: Builder<T>): Promise<void>;
61
+ export declare function saveBuilder<TEnt extends Ent<TViewer>, TViewer extends Viewer>(builder: Builder<TEnt, TViewer>): Promise<void>;
62
+ export declare function saveBuilderX<TEnt extends Ent<TViewer>, TViewer extends Viewer>(builder: Builder<TEnt, TViewer>): Promise<void>;
63
63
  interface Orchestrator {
64
64
  addOutboundEdge<T2 extends Ent>(id2: ID | Builder<T2>, edgeType: string, nodeType: string, options?: AssocEdgeInputOptions): void;
65
65
  removeOutboundEdge(id2: ID, edgeType: string): void;
@@ -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, T | null> | undefined);
13
+ constructor(viewer: Viewer, placeholderID: ID, operations: DataOperation<T>[], options?: OrchestratorOptions<T, Viewer<Ent<any> | null, ID | null>, Data, 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<T>[], options?: OrchestratorOptions<T, Data>);
32
+ constructor(viewer: Viewer, placeholderID: ID, operations: DataOperation[], dependencies: Map<ID, Builder<T>>, changesets: Changeset[], options?: OrchestratorOptions<T, Viewer, Data>);
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>>>[]>;
@@ -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.observers) {
50
+ if (!this.options || !action || !action.getObservers) {
51
51
  return;
52
52
  }
53
53
  const builder = this.options.builder;
54
- await Promise.all(action.observers.map(async (observer) => {
54
+ await Promise.all(action.getObservers().map(async (observer) => {
55
55
  await observer.observe(builder, action.getInput());
56
56
  }));
57
57
  }
@@ -5,36 +5,37 @@ export interface ActionOptions<T extends Ent, TData extends Data> {
5
5
  input?: TData;
6
6
  operation?: WriteOperation;
7
7
  }
8
- interface EntBuilder<T extends Ent> extends Builder<T> {
8
+ interface EntBuilder<TEnt extends Ent<TViewer>, TViewer extends Viewer, TInput extends Data> extends Builder<TEnt, TViewer> {
9
9
  valid(): Promise<boolean>;
10
10
  validX(): Promise<void>;
11
11
  save(): Promise<void>;
12
12
  saveX(): Promise<void>;
13
- editedEnt(): Promise<T | null>;
14
- editedEntX(): Promise<T>;
13
+ editedEnt(): Promise<TEnt | null>;
14
+ editedEntX(): Promise<TEnt>;
15
+ getInput(): TInput;
15
16
  }
16
- export declare class BaseAction<TEnt extends Ent, TData extends Data> implements Action<TEnt, EntBuilder<TEnt>, TData> {
17
- viewer: Viewer;
18
- builderCtr: BuilderConstructor<TEnt, TData>;
19
- builder: EntBuilder<TEnt>;
17
+ export declare class BaseAction<TEnt extends Ent<TViewer>, TViewer extends Viewer, TInput extends Data> implements Action<TEnt, EntBuilder<TEnt, TViewer, TInput>, TViewer, TInput> {
18
+ viewer: TViewer;
19
+ builderCtr: BuilderConstructor<TEnt, TViewer, TInput>;
20
+ builder: EntBuilder<TEnt, TViewer, TInput>;
20
21
  private input;
21
- triggers: Trigger<TEnt, EntBuilder<TEnt>, TData>[];
22
- observers: Observer<TEnt, EntBuilder<TEnt>, TData>[];
23
- validators: Validator<TEnt, EntBuilder<TEnt>, TData>[];
24
- getPrivacyPolicy(): import("../core/base").PrivacyPolicy<Ent>;
25
- constructor(viewer: Viewer, builderCtr: BuilderConstructor<TEnt, TData>, options?: ActionOptions<TEnt, TData> | null);
26
- static createBuilder<TEnt extends Ent, TData extends Data>(viewer: Viewer, builderCtr: BuilderConstructor<TEnt, TData>, options?: ActionOptions<TEnt, TData> | null): Builder<TEnt>;
27
- static bulkAction<TEnt extends Ent, TData extends Data>(ent: TEnt, builderCtr: BuilderConstructor<TEnt, TData>, ...actions: Action<Ent, Builder<Ent>, Data>[]): BaseAction<TEnt, TData>;
28
- changeset(): Promise<Changeset<TEnt>>;
22
+ getPrivacyPolicy(): import("../core/base").PrivacyPolicy<Ent<Viewer<Ent<any> | null, import("../core/base").ID | null>>, Viewer<Ent<any> | null, import("../core/base").ID | null>>;
23
+ getTriggers(): Trigger<TEnt, EntBuilder<TEnt, TViewer, TInput>, TViewer, TInput>[];
24
+ getObservers(): Observer<TEnt, EntBuilder<TEnt, TViewer, TInput>, TViewer, TInput>[];
25
+ getValidators(): Validator<TEnt, EntBuilder<TEnt, TViewer, TInput>, TViewer, TInput>[];
26
+ constructor(viewer: TViewer, builderCtr: BuilderConstructor<TEnt, TViewer, TInput>, options?: ActionOptions<TEnt, TInput> | null);
27
+ static createBuilder<TEnt extends Ent<TViewer>, TViewer extends Viewer, TInput extends Data>(viewer: Viewer, builderCtr: BuilderConstructor<TEnt, TViewer, TInput>, options?: ActionOptions<TEnt, TInput> | null): Builder<TEnt>;
28
+ static bulkAction<TEnt extends Ent<TViewer>, TViewer extends Viewer, TInput extends Data>(ent: TEnt, builderCtr: BuilderConstructor<TEnt, TViewer, TInput>, ...actions: Action<Ent, Builder<Ent, any>>[]): BaseAction<TEnt, TViewer, TInput>;
29
+ changeset(): Promise<Changeset>;
29
30
  valid(): Promise<boolean>;
30
31
  validX(): Promise<void>;
31
32
  save(): Promise<TEnt | null>;
32
33
  saveX(): Promise<TEnt>;
33
- getInput(): TData;
34
+ getInput(): TInput;
34
35
  }
35
- interface BuilderConstructor<TEnt extends Ent, TData extends Data> {
36
- new (viewer: Viewer, operation: WriteOperation, action: Action<TEnt, EntBuilder<TEnt>, TData>, existingEnt: TEnt | null): EntBuilder<TEnt>;
36
+ interface BuilderConstructor<TEnt extends Ent<TViewer>, TViewer extends Viewer, TInput extends Data> {
37
+ new (viewer: TViewer, operation: WriteOperation, action: Action<TEnt, EntBuilder<TEnt, TViewer, TInput>, TViewer, TInput>, existingEnt: TEnt | null): EntBuilder<TEnt, TViewer, TInput>;
37
38
  }
38
- export declare function updateRawObject<TEnt extends Ent, TInput extends Data>(viewer: Viewer, builderCtr: BuilderConstructor<TEnt, TInput>, existingEnt: TEnt, input: TInput): Promise<TEnt>;
39
- export declare function getSimpleEditAction<TEnt extends Ent, TInput extends Data>(viewer: Viewer, builderCtr: BuilderConstructor<TEnt, TInput>, existingEnt: TEnt, input: TInput): Action<TEnt, Builder<TEnt>, TInput>;
39
+ export declare function updateRawObject<TEnt extends Ent<TViewer>, TViewer extends Viewer, TInput extends Data>(viewer: Viewer, builderCtr: BuilderConstructor<TEnt, TViewer, TInput>, existingEnt: TEnt, input: TInput): Promise<TEnt>;
40
+ export declare function getSimpleEditAction<TEnt extends Ent<TViewer>, TViewer extends Viewer, TInput extends Data>(viewer: TViewer, builderCtr: BuilderConstructor<TEnt, TViewer, TInput>, existingEnt: TEnt, input: TInput): Action<TEnt, Builder<TEnt, TViewer>, TViewer, TInput>;
40
41
  export {};
@@ -7,9 +7,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) {
@@ -25,6 +22,15 @@ class BaseAction {
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.triggers = [
44
+ action.getTriggers = () => [
39
45
  {
40
46
  changeset: () => {
41
47
  return actions.map((action) => action.changeset());
@@ -5,17 +5,17 @@ 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
7
  declare type TMaybleNullableEnt<T extends Ent> = T | MaybeNull<T>;
8
- export interface OrchestratorOptions<TEnt extends Ent, TData extends Data, TExistingEnt extends TMaybleNullableEnt<TEnt> = MaybeNull<TEnt>> {
8
+ export interface OrchestratorOptions<TEnt extends Ent<TViewer>, TViewer extends Viewer, TInput extends Data, TExistingEnt extends TMaybleNullableEnt<TEnt> = MaybeNull<TEnt>> {
9
9
  viewer: Viewer;
10
10
  operation: WriteOperation;
11
11
  tableName: string;
12
- loaderOptions: LoadEntOptions<TEnt>;
12
+ loaderOptions: LoadEntOptions<TEnt, TViewer>;
13
13
  key: string;
14
- builder: Builder<TEnt, TExistingEnt>;
15
- action?: Action<TEnt, Builder<TEnt>, TData>;
14
+ builder: Builder<TEnt, TViewer, TExistingEnt>;
15
+ action?: Action<TEnt, Builder<TEnt, TViewer>, TViewer, TInput>;
16
16
  schema: SchemaInputType;
17
17
  editedFields(): Map<string, any> | Promise<Map<string, any>>;
18
- updateInput?: (data: TData) => void;
18
+ updateInput?: (data: TInput) => void;
19
19
  fieldInfo: FieldInfoMap;
20
20
  }
21
21
  interface edgeInputDataOpts {
@@ -31,7 +31,7 @@ export declare enum edgeDirection {
31
31
  inboundEdge = 0,
32
32
  outboundEdge = 1
33
33
  }
34
- export declare class Orchestrator<TEnt extends Ent, TData extends Data, TExistingEnt extends TMaybleNullableEnt<TEnt> = MaybeNull<TEnt>> {
34
+ export declare class Orchestrator<TEnt extends Ent<TViewer>, TInput extends Data, TViewer extends Viewer, TExistingEnt extends TMaybleNullableEnt<TEnt> = MaybeNull<TEnt>> {
35
35
  private options;
36
36
  private edgeSet;
37
37
  private edges;
@@ -48,11 +48,11 @@ export declare class Orchestrator<TEnt extends Ent, TData extends Data, TExistin
48
48
  private existingEnt;
49
49
  private disableTransformations;
50
50
  private memoizedGetFields;
51
- constructor(options: OrchestratorOptions<TEnt, TData, TExistingEnt>);
51
+ constructor(options: OrchestratorOptions<TEnt, TViewer, TInput, TExistingEnt>);
52
52
  private addEdge;
53
53
  setDisableTransformations(val: boolean): void;
54
- addInboundEdge<T2 extends Ent>(id1: ID | Builder<T2>, edgeType: string, nodeType: string, options?: AssocEdgeInputOptions): void;
55
- addOutboundEdge<T2 extends Ent>(id2: ID | Builder<T2>, edgeType: string, nodeType: string, options?: AssocEdgeInputOptions): void;
54
+ addInboundEdge<T2 extends Ent>(id1: ID | Builder<T2, any>, edgeType: string, nodeType: string, options?: AssocEdgeInputOptions): void;
55
+ addOutboundEdge<T2 extends Ent>(id2: ID | Builder<T2, any>, edgeType: string, nodeType: string, options?: AssocEdgeInputOptions): void;
56
56
  removeInboundEdge(id1: ID, edgeType: string): void;
57
57
  removeOutboundEdge(id2: ID, edgeType: string): void;
58
58
  getInputEdges(edgeType: string, op: WriteOperation): EdgeInputData[];
@@ -85,16 +85,16 @@ export declare class Orchestrator<TEnt extends Ent, TData extends Data, TExistin
85
85
  editedEnt(): Promise<TEnt | null>;
86
86
  editedEntX(): Promise<TEnt>;
87
87
  }
88
- export declare class EntChangeset<T extends Ent> implements Changeset<T> {
88
+ export declare class EntChangeset<T extends Ent> implements Changeset {
89
89
  viewer: Viewer;
90
90
  readonly placeholderID: ID;
91
91
  readonly ent: EntConstructor<T>;
92
92
  operations: DataOperation[];
93
- dependencies?: Map<ID, Builder<Ent, Ent | null>> | undefined;
94
- changesets?: Changeset<Ent>[] | undefined;
93
+ 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;
94
+ changesets?: Changeset[] | undefined;
95
95
  private options?;
96
96
  private _executor;
97
- constructor(viewer: Viewer, placeholderID: ID, ent: EntConstructor<T>, operations: DataOperation[], dependencies?: Map<ID, Builder<Ent, Ent | null>> | undefined, changesets?: Changeset<Ent>[] | undefined, options?: OrchestratorOptions<T, Data, MaybeNull<T>> | undefined);
97
+ 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, Viewer<Ent<any> | null, ID | null>, Data, MaybeNull<T>> | undefined);
98
98
  executor(): Executor;
99
99
  }
100
100
  export {};
@@ -317,11 +317,13 @@ class Orchestrator {
317
317
  }
318
318
  // have to run triggers which update fields first before field and other validators
319
319
  // so running this first to build things up
320
- let triggers = action?.triggers;
321
- if (triggers) {
322
- await this.triggers(action, builder, triggers);
320
+ if (action?.getTriggers) {
321
+ await this.triggers(action, builder, action.getTriggers());
322
+ }
323
+ let validators = [];
324
+ if (action?.getValidators) {
325
+ validators = action.getValidators();
323
326
  }
324
- let validators = action?.validators || [];
325
327
  // not ideal we're calling this twice. fix...
326
328
  // needed for now. may need to rewrite some of this?
327
329
  const editedFields2 = await this.options.editedFields();
@@ -2,11 +2,11 @@ import { Builder } from "./action";
2
2
  import { Viewer, ID, Ent, PrivacyResult, PrivacyPolicyRule } from "../core/base";
3
3
  export declare class DenyIfBuilder implements PrivacyPolicyRule {
4
4
  private id?;
5
- constructor(id?: ID | Builder<Ent, Ent | null> | undefined);
5
+ constructor(id?: ID | Builder<Ent<Viewer<Ent<any> | null, ID | null>>, any, Ent<Viewer<Ent<any> | null, ID | null>> | null> | undefined);
6
6
  apply(_v: Viewer, _ent: Ent): Promise<PrivacyResult>;
7
7
  }
8
8
  export declare class AllowIfBuilder implements PrivacyPolicyRule {
9
9
  private id?;
10
- constructor(id?: ID | Builder<Ent, Ent | null> | undefined);
10
+ constructor(id?: ID | Builder<Ent<Viewer<Ent<any> | null, ID | null>>, any, Ent<Viewer<Ent<any> | null, ID | null>> | null> | undefined);
11
11
  apply(_v: Viewer, _ent: Ent): Promise<PrivacyResult>;
12
12
  }
package/core/base.d.ts CHANGED
@@ -30,27 +30,27 @@ interface queryOptions {
30
30
  clause: clause.Clause;
31
31
  orderby?: string;
32
32
  }
33
- export interface Context {
34
- getViewer(): Viewer;
33
+ export interface Context<TViewer extends Viewer = Viewer> {
34
+ getViewer(): TViewer;
35
35
  cache?: cache;
36
36
  }
37
- export interface Viewer {
38
- viewerID: ID | null;
39
- viewer: () => Promise<Ent | null>;
37
+ export interface Viewer<TEnt extends any = Ent<any> | null, TID extends any = ID | null> {
38
+ viewerID: TID;
39
+ viewer: () => Promise<TEnt>;
40
40
  instanceKey: () => string;
41
- context?: Context;
41
+ context?: Context<any>;
42
42
  }
43
- export interface Ent {
43
+ export interface Ent<TViewer extends Viewer = Viewer> {
44
44
  id: ID;
45
- viewer: Viewer;
46
- getPrivacyPolicy(): PrivacyPolicy<this>;
45
+ viewer: TViewer;
46
+ getPrivacyPolicy(): PrivacyPolicy<this, TViewer>;
47
47
  nodeType: string;
48
48
  }
49
49
  export declare type Data = {
50
50
  [key: string]: any;
51
51
  };
52
- export interface EntConstructor<T extends Ent> {
53
- new (viewer: Viewer, data: Data): T;
52
+ export interface EntConstructor<TEnt extends Ent, TViewer extends Viewer = Viewer> {
53
+ new (viewer: TViewer, data: Data): TEnt;
54
54
  }
55
55
  export declare type ID = string | number;
56
56
  export interface DataOptions {
@@ -84,15 +84,15 @@ export interface CreateRowOptions extends DataOptions {
84
84
  export interface EditRowOptions extends CreateRowOptions {
85
85
  key: string;
86
86
  }
87
- interface LoadableEntOptions<T extends Ent> {
87
+ interface LoadableEntOptions<TEnt extends Ent, TViewer extends Viewer = Viewer> {
88
88
  loaderFactory: LoaderFactory<any, Data | null>;
89
- ent: EntConstructor<T>;
89
+ ent: EntConstructor<TEnt, TViewer>;
90
90
  }
91
- export interface LoadEntOptions<T extends Ent> extends LoadableEntOptions<T>, SelectBaseDataOptions {
91
+ export interface LoadEntOptions<TEnt extends Ent, TViewer extends Viewer = Viewer> extends LoadableEntOptions<TEnt, TViewer>, SelectBaseDataOptions {
92
92
  fieldPrivacy?: Map<string, PrivacyPolicy>;
93
93
  }
94
- export interface LoadCustomEntOptions<T extends Ent> extends SelectBaseDataOptions {
95
- ent: EntConstructor<T>;
94
+ export interface LoadCustomEntOptions<TEnt extends Ent, TViewer extends Viewer = Viewer> extends SelectBaseDataOptions {
95
+ ent: EntConstructor<TEnt, TViewer>;
96
96
  fieldPrivacy?: Map<string, PrivacyPolicy>;
97
97
  }
98
98
  export interface LoaderInfo {
@@ -121,10 +121,10 @@ export declare function Allow(): PrivacyResult;
121
121
  export declare function Skip(): PrivacyResult;
122
122
  export declare function Deny(): PrivacyResult;
123
123
  export declare function DenyWithReason(e: PrivacyError | string): PrivacyResult;
124
- export interface PrivacyPolicyRule<TEnt extends Ent = Ent> {
125
- apply(v: Viewer, ent?: TEnt): Promise<PrivacyResult>;
124
+ export interface PrivacyPolicyRule<TEnt extends Ent = Ent, TViewer = Viewer> {
125
+ apply(v: TViewer, ent?: TEnt): Promise<PrivacyResult>;
126
126
  }
127
- export interface PrivacyPolicy<TEnt extends Ent = Ent> {
128
- rules: PrivacyPolicyRule<TEnt>[];
127
+ export interface PrivacyPolicy<TEnt extends Ent = Ent, TViewer = Viewer> {
128
+ rules: PrivacyPolicyRule<TEnt, TViewer>[];
129
129
  }
130
130
  export {};
package/core/config.d.ts CHANGED
@@ -35,6 +35,7 @@ interface CodegenConfig {
35
35
  schemaSQLFilePath?: boolean;
36
36
  databaseToCompareTo?: string;
37
37
  fieldPrivacyEvaluated?: fieldPrivacyEvaluated;
38
+ templatizedViewer?: templatizedViewer;
38
39
  }
39
40
  interface PrettierConfig {
40
41
  custom?: boolean;
@@ -45,5 +46,9 @@ interface PrivacyConfig {
45
46
  policyName: string;
46
47
  class?: boolean;
47
48
  }
49
+ interface templatizedViewer {
50
+ path: string;
51
+ name: string;
52
+ }
48
53
  export declare function loadConfig(file?: string | Buffer | Config): void;
49
54
  export {};
package/core/context.d.ts CHANGED
@@ -3,8 +3,8 @@ import { Viewer, Data, Loader } from "./base";
3
3
  import { IncomingMessage, ServerResponse } from "http";
4
4
  import * as clause from "./clause";
5
5
  import { Context } from "./base";
6
- export interface RequestContext extends Context {
7
- authViewer(viewer: Viewer): Promise<void>;
6
+ export interface RequestContext<TViewer extends Viewer = Viewer> extends Context<TViewer> {
7
+ authViewer(viewer: TViewer): Promise<void>;
8
8
  logout(): Promise<void>;
9
9
  request: IncomingMessage;
10
10
  response: ServerResponse;
package/core/ent.d.ts CHANGED
@@ -4,16 +4,16 @@ import { Executor } from "../action/action";
4
4
  import * as clause from "./clause";
5
5
  import { Builder } from "../action";
6
6
  import DataLoader from "dataloader";
7
- export declare function loadEnt<T extends Ent>(viewer: Viewer, id: ID, options: LoadEntOptions<T>): Promise<T | null>;
8
- export declare function loadEntViaKey<T extends Ent>(viewer: Viewer, key: any, options: LoadEntOptions<T>): Promise<T | null>;
9
- export declare function loadEntX<T extends Ent>(viewer: Viewer, id: ID, options: LoadEntOptions<T>): Promise<T>;
10
- export declare function loadEntXViaKey<T extends Ent>(viewer: Viewer, key: any, options: LoadEntOptions<T>): Promise<T>;
11
- export declare function loadEntFromClause<T extends Ent>(viewer: Viewer, options: LoadEntOptions<T>, clause: clause.Clause): Promise<T | null>;
12
- export declare function loadEntXFromClause<T extends Ent>(viewer: Viewer, options: LoadEntOptions<T>, clause: clause.Clause): Promise<T>;
13
- export declare function loadEnts<T extends Ent>(viewer: Viewer, options: LoadEntOptions<T>, ...ids: ID[]): Promise<Map<ID, T>>;
14
- export declare function loadEntsList<T extends Ent>(viewer: Viewer, options: LoadEntOptions<T>, ...ids: ID[]): Promise<T[]>;
15
- export declare function loadEntsFromClause<T extends Ent>(viewer: Viewer, clause: clause.Clause, options: LoadEntOptions<T>): Promise<Map<ID, T>>;
16
- export declare function loadCustomEnts<T extends Ent>(viewer: Viewer, options: LoadCustomEntOptions<T>, query: CustomQuery): Promise<T[]>;
7
+ export declare function loadEnt<TEnt extends Ent<TViewer>, TViewer extends Viewer>(viewer: TViewer, id: ID, options: LoadEntOptions<TEnt, TViewer>): Promise<TEnt | null>;
8
+ export declare function loadEntViaKey<TEnt extends Ent<TViewer>, TViewer extends Viewer>(viewer: TViewer, key: any, options: LoadEntOptions<TEnt, TViewer>): Promise<TEnt | null>;
9
+ export declare function loadEntX<TEnt extends Ent<TViewer>, TViewer extends Viewer>(viewer: TViewer, id: ID, options: LoadEntOptions<TEnt, TViewer>): Promise<TEnt>;
10
+ export declare function loadEntXViaKey<TEnt extends Ent<TViewer>, TViewer extends Viewer>(viewer: TViewer, key: any, options: LoadEntOptions<TEnt, TViewer>): Promise<TEnt>;
11
+ export declare function loadEntFromClause<TEnt extends Ent<TViewer>, TViewer extends Viewer>(viewer: TViewer, options: LoadEntOptions<TEnt, TViewer>, clause: clause.Clause): Promise<TEnt | null>;
12
+ export declare function loadEntXFromClause<TEnt extends Ent<TViewer>, TViewer extends Viewer>(viewer: TViewer, options: LoadEntOptions<TEnt, TViewer>, clause: clause.Clause): Promise<TEnt>;
13
+ export declare function loadEnts<TEnt extends Ent<TViewer>, TViewer extends Viewer>(viewer: TViewer, options: LoadEntOptions<TEnt, TViewer>, ...ids: ID[]): Promise<Map<ID, TEnt>>;
14
+ export declare function loadEntsList<TEnt extends Ent<TViewer>, TViewer extends Viewer>(viewer: TViewer, options: LoadEntOptions<TEnt, TViewer>, ...ids: ID[]): Promise<TEnt[]>;
15
+ export declare function loadEntsFromClause<TEnt extends Ent<TViewer>, TViewer extends Viewer>(viewer: TViewer, clause: clause.Clause, options: LoadEntOptions<TEnt, TViewer>): Promise<Map<ID, TEnt>>;
16
+ export declare function loadCustomEnts<TEnt extends Ent<TViewer>, TViewer extends Viewer>(viewer: TViewer, options: LoadCustomEntOptions<TEnt, TViewer>, query: CustomQuery): Promise<TEnt[]>;
17
17
  interface rawQueryOptions {
18
18
  query: string;
19
19
  values?: any[];
@@ -21,8 +21,8 @@ interface rawQueryOptions {
21
21
  }
22
22
  export declare type CustomQuery = string | rawQueryOptions | clause.Clause | QueryDataOptions;
23
23
  export declare function loadCustomData(options: SelectBaseDataOptions, query: CustomQuery, context: Context | undefined): Promise<Data[]>;
24
- export declare function loadDerivedEnt<T extends Ent>(viewer: Viewer, data: Data, loader: new (viewer: Viewer, data: Data) => T): Promise<T | null>;
25
- export declare function loadDerivedEntX<T extends Ent>(viewer: Viewer, data: Data, loader: new (viewer: Viewer, data: Data) => T): Promise<T>;
24
+ export declare function loadDerivedEnt<TEnt extends Ent<TViewer>, TViewer extends Viewer>(viewer: TViewer, data: Data, loader: new (viewer: TViewer, data: Data) => TEnt): Promise<TEnt | null>;
25
+ export declare function loadDerivedEntX<TEnt extends Ent<TViewer>, TViewer extends Viewer>(viewer: TViewer, data: Data, loader: new (viewer: TViewer, data: Data) => TEnt): Promise<TEnt>;
26
26
  export declare function loadRowX(options: LoadRowOptions): Promise<Data>;
27
27
  export declare function loadRow(options: LoadRowOptions): Promise<Data | null>;
28
28
  export declare function performRawQuery(query: string, values: any[], logValues?: any[]): Promise<Data[]>;
@@ -165,7 +165,7 @@ export declare function defaultEdgeQueryOptions(id1: ID, edgeType: string): Edge
165
165
  export declare function loadEdges(options: loadEdgesOptions): Promise<AssocEdge[]>;
166
166
  export declare function loadCustomEdges<T extends AssocEdge>(options: loadCustomEdgesOptions<T>): Promise<T[]>;
167
167
  export declare function loadUniqueEdge(options: loadEdgesOptions): Promise<AssocEdge | null>;
168
- export declare function loadUniqueNode<T extends Ent>(viewer: Viewer, id1: ID, edgeType: string, options: LoadEntOptions<T>): Promise<T | null>;
168
+ export declare function loadUniqueNode<TEnt extends Ent<TViewer>, TViewer extends Viewer>(viewer: TViewer, id1: ID, edgeType: string, options: LoadEntOptions<TEnt, TViewer>): Promise<TEnt | null>;
169
169
  export declare function loadRawEdgeCountX(options: loadEdgesOptions): Promise<number>;
170
170
  interface loadEdgeForIDOptions<T extends AssocEdge> extends loadCustomEdgesOptions<T> {
171
171
  id2: ID;
@@ -1,10 +1,10 @@
1
1
  import { ID, Context, Loader, LoaderFactory } from "../base";
2
2
  export declare class AssocEdgeCountLoader implements Loader<ID, number> {
3
3
  private edgeType;
4
- context?: Context | undefined;
4
+ context?: Context<import("../base").Viewer<import("../base").Ent<any> | null, ID | null>> | undefined;
5
5
  private loaderFn;
6
6
  private loader;
7
- constructor(edgeType: string, context?: Context | undefined);
7
+ constructor(edgeType: string, context?: Context<import("../base").Viewer<import("../base").Ent<any> | null, ID | null>> | undefined);
8
8
  private getLoader;
9
9
  load(id: ID): Promise<number>;
10
10
  clearAll(): void;
@@ -20,8 +20,8 @@ export declare class AssocDirectEdgeLoader<T extends AssocEdge> implements Loade
20
20
  private edgeType;
21
21
  private edgeCtr;
22
22
  private options?;
23
- context?: Context | undefined;
24
- constructor(edgeType: string, edgeCtr: AssocEdgeConstructor<T>, options?: Partial<Pick<import("../base").QueryableDataOptions, "limit" | "orderby" | "clause">> | undefined, context?: Context | undefined);
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" | "clause">> | 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;
@@ -1,12 +1,12 @@
1
- import { Data, SelectDataOptions, Context, Loader, LoaderFactory } from "../base";
1
+ import { ID, Data, SelectDataOptions, Context, Loader, LoaderFactory } from "../base";
2
2
  export declare class ObjectLoader<T> implements Loader<T, Data | null> {
3
3
  private options;
4
- context?: Context | undefined;
4
+ context?: Context<import("../base").Viewer<import("../base").Ent<any> | null, ID | null>> | undefined;
5
5
  private toPrime?;
6
6
  private loader;
7
7
  private primedLoaders;
8
8
  private memoizedInitPrime;
9
- constructor(options: SelectDataOptions, context?: Context | undefined, toPrime?: ObjectLoaderFactory<T>[] | undefined);
9
+ constructor(options: SelectDataOptions, context?: Context<import("../base").Viewer<import("../base").Ent<any> | null, ID | null>> | undefined, toPrime?: ObjectLoaderFactory<T>[] | undefined);
10
10
  getOptions(): SelectDataOptions;
11
11
  private initPrime;
12
12
  load(key: T): Promise<Data | null>;
@@ -10,12 +10,12 @@ export declare class QueryDirectLoader<K extends any> implements Loader<K, Data[
10
10
  }
11
11
  export declare class QueryLoader<K extends any> implements Loader<K, Data[]> {
12
12
  private options;
13
- context?: Context | undefined;
13
+ context?: Context<import("../base").Viewer<import("../base").Ent<any> | null, ID | null>> | undefined;
14
14
  private queryOptions?;
15
15
  private loader;
16
16
  private primedLoaders;
17
17
  private memoizedInitPrime;
18
- constructor(options: QueryOptions, context?: Context | undefined, queryOptions?: Partial<Pick<import("../base").QueryableDataOptions, "limit" | "orderby" | "clause">> | undefined);
18
+ constructor(options: QueryOptions, context?: Context<import("../base").Viewer<import("../base").Ent<any> | null, ID | null>> | undefined, queryOptions?: Partial<Pick<import("../base").QueryableDataOptions, "limit" | "orderby" | "clause">> | undefined);
19
19
  private initPrime;
20
20
  load(id: K): Promise<Data[]>;
21
21
  clearAll(): void;
@@ -9,9 +9,9 @@ interface QueryCountOptions {
9
9
  export declare function createCountDataLoader<K extends any>(options: QueryCountOptions): DataLoader<K, number, K>;
10
10
  export declare class RawCountLoader<K extends any> implements Loader<K, number> {
11
11
  private options;
12
- context?: Context | undefined;
12
+ context?: Context<import("../base").Viewer<import("../base").Ent<any> | null, ID | null>> | undefined;
13
13
  private loader;
14
- constructor(options: QueryCountOptions, context?: Context | undefined);
14
+ constructor(options: QueryCountOptions, context?: Context<import("../base").Viewer<import("../base").Ent<any> | null, ID | null>> | undefined);
15
15
  load(id: K): Promise<number>;
16
16
  clearAll(): void;
17
17
  }