@snowtop/ent 0.1.13 → 0.1.14-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.
@@ -24,7 +24,7 @@ export interface Builder<TEnt extends Ent<TViewer>, TViewer extends Viewer = Vie
24
24
  getInput(): Data;
25
25
  orchestrator: BuilderOrchestrator;
26
26
  }
27
- export interface Executor extends Iterable<DataOperation>, Iterator<DataOperation> {
27
+ export interface Executor extends Iterable<DataOperation<Ent>>, Iterator<DataOperation<Ent>> {
28
28
  placeholderID: ID;
29
29
  resolveValue(val: any): Ent | null;
30
30
  builderOpChanged(builder: Builder<any>): boolean;
@@ -40,7 +40,7 @@ export declare class ComplexExecutor<T extends Ent> implements Executor {
40
40
  private executors;
41
41
  private changedOps;
42
42
  builder?: Builder<Ent> | undefined;
43
- constructor(viewer: Viewer, placeholderID: ID, operations: DataOperation[], dependencies: Map<ID, Builder<T>>, changesets: Changeset[], options?: OrchestratorOptions<T, Data, Viewer>, complexOptions?: ComplexExecutorOptions | undefined);
43
+ constructor(viewer: Viewer, placeholderID: ID, operations: DataOperation<T>[], dependencies: Map<ID, Builder<T>>, changesets: Changeset[], options?: OrchestratorOptions<T, Data, Viewer>, complexOptions?: ComplexExecutorOptions | undefined);
44
44
  [Symbol.iterator](): this;
45
45
  private handleCreatedEnt;
46
46
  next(): IteratorResult<DataOperation<Ent>>;
@@ -51,5 +51,5 @@ export declare class ComplexExecutor<T extends Ent> implements Executor {
51
51
  preFetch?(queryer: Queryer, context: Context): Promise<void>;
52
52
  postFetch?(queryer: Queryer, context: Context): Promise<void>;
53
53
  }
54
- export declare function executeOperations(executor: Executor, context?: Context, trackOps?: true): Promise<DataOperation<Ent<Viewer<Ent<any> | null, ID | null>>>[]>;
54
+ export declare function executeOperations(executor: Executor, context?: Context, trackOps?: true): Promise<DataOperation<Ent<Viewer<Ent<any> | null, ID | null>>, Viewer<Ent<any> | null, ID | null>>[]>;
55
55
  export {};
@@ -3,62 +3,62 @@ import { Viewer, Ent, ID, Data, DataOptions, EditRowOptions, LoadEntOptions, Con
3
3
  import { Executor } from "../action/action";
4
4
  import { WriteOperation, Builder } from "../action";
5
5
  import { AssocEdgeData, parameterizedQueryOptions } from "../core/ent";
6
- export interface UpdatedOperation {
6
+ export interface UpdatedOperation<TEnt extends Ent<TViewer>, TViewer extends Viewer = Viewer> {
7
7
  operation: WriteOperation;
8
- builder: Builder<any>;
8
+ builder: Builder<TEnt, TViewer>;
9
9
  }
10
- export interface DataOperation<T extends Ent = Ent> {
11
- builder: Builder<T>;
10
+ export interface DataOperation<TEnt extends Ent<TViewer>, TViewer extends Viewer = Viewer> {
11
+ builder: Builder<TEnt, TViewer>;
12
12
  preFetch?(queryer: Queryer, context?: Context): Promise<void>;
13
13
  performWriteSync(queryer: SyncQueryer, context?: Context): void;
14
14
  performWrite(queryer: Queryer, context?: Context): Promise<void>;
15
15
  placeholderID?: ID;
16
16
  returnedRow?(): Data | null;
17
- createdEnt?(viewer: Viewer): T | null;
17
+ createdEnt?(viewer: Viewer): TEnt | null;
18
18
  shortCircuit?(executor: Executor): boolean;
19
- updatedOperation?(): UpdatedOperation | null;
19
+ updatedOperation?(): UpdatedOperation<TEnt, TViewer> | null;
20
20
  resolve?(executor: Executor): void;
21
21
  postFetch?(queryer: Queryer, context?: Context): Promise<void>;
22
22
  }
23
- export declare class DeleteNodeOperation implements DataOperation {
23
+ export declare class DeleteNodeOperation<TEnt extends Ent<TViewer>, TViewer extends Viewer = Viewer> implements DataOperation<TEnt, TViewer> {
24
24
  private id;
25
- readonly builder: Builder<Ent>;
25
+ readonly builder: Builder<TEnt, TViewer>;
26
26
  private options;
27
- constructor(id: ID, builder: Builder<Ent>, options: DataOptions);
27
+ constructor(id: ID, builder: Builder<TEnt, TViewer>, options: DataOptions);
28
28
  performWrite(queryer: Queryer, context?: Context): Promise<void>;
29
29
  performWriteSync(queryer: SyncQueryer, context?: Context): void;
30
30
  }
31
- export declare class RawQueryOperation<TEnt extends Ent<TViewer>, TViewer extends Viewer = Viewer> implements DataOperation<TEnt> {
31
+ export declare class RawQueryOperation<TEnt extends Ent<TViewer>, TViewer extends Viewer = Viewer> implements DataOperation<TEnt, TViewer> {
32
32
  builder: Builder<TEnt, TViewer>;
33
33
  private queries;
34
34
  constructor(builder: Builder<TEnt, TViewer>, queries: (string | parameterizedQueryOptions)[]);
35
35
  performWrite(queryer: Queryer, context?: Context): Promise<void>;
36
36
  performWriteSync(queryer: SyncQueryer, context?: Context): void;
37
37
  }
38
- export interface EditNodeOptions<T extends Ent> extends EditRowOptions {
38
+ export interface EditNodeOptions<TEnt extends Ent<TViewer>, TViewer extends Viewer = Viewer> extends EditRowOptions {
39
39
  fieldsToResolve: string[];
40
- loadEntOptions: LoadEntOptions<T>;
40
+ loadEntOptions: LoadEntOptions<TEnt>;
41
41
  key: string;
42
42
  onConflict?: CreateRowOptions["onConflict"];
43
- builder: Builder<T>;
43
+ builder: Builder<TEnt, TViewer>;
44
44
  }
45
- export declare class NoOperation<T extends Ent> implements DataOperation<T> {
46
- builder: Builder<any>;
45
+ export declare class NoOperation<TEnt extends Ent<TViewer>, TViewer extends Viewer = Viewer> implements DataOperation<TEnt, TViewer> {
46
+ builder: Builder<TEnt, TViewer>;
47
47
  private row;
48
- constructor(builder: Builder<any>, existingEnt?: Ent | null);
48
+ constructor(builder: Builder<TEnt, TViewer>, existingEnt?: Ent | null);
49
49
  performWrite(queryer: Queryer, context?: Context): Promise<void>;
50
50
  performWriteSync(queryer: SyncQueryer, context?: Context): void;
51
51
  returnedRow(): Data | null;
52
52
  }
53
- export declare class EditNodeOperation<T extends Ent> implements DataOperation {
54
- options: EditNodeOptions<T>;
53
+ export declare class EditNodeOperation<TEnt extends Ent<TViewer>, TViewer extends Viewer = Viewer> implements DataOperation<TEnt, TViewer> {
54
+ options: EditNodeOptions<TEnt, TViewer>;
55
55
  private existingEnt;
56
56
  private row;
57
57
  placeholderID?: ID | undefined;
58
58
  private updatedOp;
59
- builder: Builder<T>;
59
+ builder: Builder<TEnt, TViewer>;
60
60
  private resolved;
61
- constructor(options: EditNodeOptions<T>, existingEnt?: Ent | null);
61
+ constructor(options: EditNodeOptions<TEnt, TViewer>, existingEnt?: Ent | null);
62
62
  resolve<T extends Ent>(executor: Executor): void;
63
63
  private hasData;
64
64
  private buildOnConflictQuery;
@@ -67,8 +67,8 @@ export declare class EditNodeOperation<T extends Ent> implements DataOperation {
67
67
  private reloadRow;
68
68
  performWriteSync(queryer: SyncQueryer, context?: Context): void;
69
69
  returnedRow(): Data | null;
70
- createdEnt(viewer: Viewer): T | null;
71
- updatedOperation(): UpdatedOperation | null;
70
+ createdEnt(viewer: Viewer): TEnt | null;
71
+ updatedOperation(): UpdatedOperation<TEnt, TViewer> | null;
72
72
  }
73
73
  export interface AssocEdgeInputOptions extends AssocEdgeOptions {
74
74
  time?: Date;
@@ -85,8 +85,8 @@ export interface AssocEdgeInput extends AssocEdgeInputOptions {
85
85
  id2: ID;
86
86
  id2Type: string;
87
87
  }
88
- export declare class EdgeOperation implements DataOperation {
89
- builder: Builder<any>;
88
+ export declare class EdgeOperation<TViewer extends Viewer = Viewer> implements DataOperation<any, TViewer> {
89
+ builder: Builder<any, TViewer>;
90
90
  edgeInput: AssocEdgeInput;
91
91
  private options;
92
92
  private edgeData;
@@ -102,33 +102,33 @@ export declare class EdgeOperation implements DataOperation {
102
102
  private performInsertWriteSync;
103
103
  private resolveImpl;
104
104
  resolve(executor: Executor): void;
105
- symmetricEdge(): EdgeOperation;
106
- inverseEdge(edgeData: AssocEdgeData): EdgeOperation;
105
+ symmetricEdge(): EdgeOperation<TViewer>;
106
+ inverseEdge(edgeData: AssocEdgeData): EdgeOperation<TViewer>;
107
107
  private static resolveIDs;
108
108
  private static isBuilder;
109
109
  private static resolveData;
110
- static inboundEdge<T extends Ent, T2 extends Ent>(builder: Builder<T>, edgeType: string, id1: Builder<T2> | ID, nodeType: string, options?: AssocEdgeInputOptions): EdgeOperation;
111
- static outboundEdge<T extends Ent, T2 extends Ent>(builder: Builder<T>, edgeType: string, id2: Builder<T2> | ID, nodeType: string, options?: AssocEdgeInputOptions): EdgeOperation;
112
- static removeInboundEdge<T extends Ent>(builder: Builder<T>, edgeType: string, id1: ID, options?: AssocEdgeInputOptions): EdgeOperation;
113
- static removeOutboundEdge<T extends Ent>(builder: Builder<T>, edgeType: string, id2: ID, options?: AssocEdgeInputOptions): EdgeOperation;
110
+ static inboundEdge<T extends Ent<TViewer>, T2 extends Ent<TViewer>, TViewer extends Viewer = Viewer>(builder: Builder<T, TViewer>, edgeType: string, id1: Builder<T2, TViewer> | ID, nodeType: string, options?: AssocEdgeInputOptions): EdgeOperation<TViewer>;
111
+ static outboundEdge<T extends Ent<TViewer>, T2 extends Ent<TViewer>, TViewer extends Viewer = Viewer>(builder: Builder<T, TViewer>, edgeType: string, id2: Builder<T2, TViewer> | ID, nodeType: string, options?: AssocEdgeInputOptions): EdgeOperation<TViewer>;
112
+ static removeInboundEdge<T extends Ent<TViewer>, TViewer extends Viewer = Viewer>(builder: Builder<T, TViewer>, edgeType: string, id1: ID, options?: AssocEdgeInputOptions): EdgeOperation<TViewer>;
113
+ static removeOutboundEdge<T extends Ent<TViewer>, TViewer extends Viewer = Viewer>(builder: Builder<T, TViewer>, edgeType: string, id2: ID, options?: AssocEdgeInputOptions): EdgeOperation<TViewer>;
114
114
  }
115
- export declare class ConditionalOperation<T extends Ent = Ent> implements DataOperation<T> {
116
- protected op: DataOperation<T>;
115
+ export declare class ConditionalOperation<TEnt extends Ent<TViewer>, TViewer extends Viewer = Viewer> implements DataOperation<TEnt, TViewer> {
116
+ protected op: DataOperation<TEnt, TViewer>;
117
117
  private conditionalBuilder;
118
118
  placeholderID?: ID | undefined;
119
119
  protected shortCircuited: boolean;
120
- readonly builder: Builder<T>;
121
- constructor(op: DataOperation<T>, conditionalBuilder: Builder<any>);
120
+ readonly builder: Builder<TEnt, TViewer>;
121
+ constructor(op: DataOperation<TEnt, TViewer>, conditionalBuilder: Builder<TEnt, TViewer>);
122
122
  shortCircuit(executor: Executor): boolean;
123
123
  preFetch(queryer: Queryer, context?: Context<Viewer<Ent<any> | null, ID | null>> | undefined): Promise<void>;
124
124
  performWriteSync(queryer: SyncQueryer, context?: Context<Viewer<Ent<any> | null, ID | null>> | undefined): void;
125
125
  performWrite(queryer: Queryer, context?: Context<Viewer<Ent<any> | null, ID | null>> | undefined): Promise<void>;
126
126
  returnedRow(): Data | null;
127
- updatedOperation(): UpdatedOperation | null;
127
+ updatedOperation(): UpdatedOperation<TEnt, TViewer> | null;
128
128
  resolve(executor: Executor): void;
129
129
  postFetch(queryer: Queryer, context?: Context<Viewer<Ent<any> | null, ID | null>> | undefined): Promise<void>;
130
130
  }
131
- export declare class ConditionalNodeOperation<T extends Ent> extends ConditionalOperation<T> {
132
- createdEnt(viewer: Viewer): T | null;
133
- updatedOperation(): UpdatedOperation | null;
131
+ export declare class ConditionalNodeOperation<TEnt extends Ent<TViewer>, TViewer extends Viewer = Viewer> extends ConditionalOperation<TEnt, TViewer> {
132
+ createdEnt(viewer: Viewer): TEnt | null;
133
+ updatedOperation(): UpdatedOperation<TEnt, TViewer> | null;
134
134
  }
@@ -21,14 +21,14 @@ export interface OrchestratorOptions<TEnt extends Ent<TViewer>, TInput extends D
21
21
  expressions?: Map<string, clause.Clause>;
22
22
  fieldInfo: FieldInfoMap;
23
23
  }
24
- interface edgeInputDataOpts {
24
+ interface edgeInputDataOpts<TEnt extends Ent<TViewer>, TViewer extends Viewer = Viewer> {
25
25
  edgeType: string;
26
- id: Builder<Ent> | ID;
26
+ id: Builder<TEnt, TViewer> | ID;
27
27
  nodeType?: string;
28
28
  options?: AssocEdgeInputOptions;
29
29
  }
30
- export interface EdgeInputData extends edgeInputDataOpts {
31
- isBuilder(id: Builder<Ent> | ID): id is Builder<Ent>;
30
+ export interface EdgeInputData<TEnt extends Ent<TViewer>, TViewer extends Viewer = Viewer> extends edgeInputDataOpts<TEnt, TViewer> {
31
+ isBuilder(id: Builder<TEnt, TViewer> | ID): id is Builder<TEnt, TViewer>;
32
32
  }
33
33
  export declare enum edgeDirection {
34
34
  inboundEdge = 0,
@@ -62,7 +62,7 @@ export declare class Orchestrator<TEnt extends Ent<TViewer>, TInput extends Data
62
62
  addOutboundEdge<T2 extends Ent>(id2: ID | Builder<T2, any>, edgeType: string, nodeType: string, options?: AssocEdgeInputOptions): void;
63
63
  removeInboundEdge(id1: ID, edgeType: string, options?: AssocEdgeOptions): void;
64
64
  removeOutboundEdge(id2: ID, edgeType: string, options?: AssocEdgeOptions): void;
65
- getInputEdges(edgeType: string, op: WriteOperation): EdgeInputData[];
65
+ getInputEdges(edgeType: string, op: WriteOperation): EdgeInputData<any, TViewer>[];
66
66
  clearInputEdges(edgeType: string, op: WriteOperation, id?: ID): void;
67
67
  private buildMainOp;
68
68
  private getEdgeOperation;
@@ -108,24 +108,24 @@ export declare class Orchestrator<TEnt extends Ent<TViewer>, TInput extends Data
108
108
  editedEnt(): Promise<TEnt | null>;
109
109
  editedEntX(): Promise<TEnt>;
110
110
  }
111
- export declare class EntChangeset<T extends Ent> implements Changeset {
111
+ export declare class EntChangeset<TEnt extends Ent<TViewer>, TViewer extends Viewer = Viewer> implements Changeset {
112
112
  viewer: Viewer;
113
113
  private builder;
114
114
  readonly placeholderID: ID;
115
115
  private conditionalOverride;
116
- operations: DataOperation[];
116
+ operations: DataOperation<any, TViewer>[];
117
117
  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;
118
118
  changesets?: Changeset[] | undefined;
119
119
  private options?;
120
120
  private _executor;
121
- constructor(viewer: Viewer, builder: Builder<T>, placeholderID: ID, conditionalOverride: boolean, 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);
122
- static changesetFrom(builder: Builder<any, any, any>, ops: DataOperation[]): EntChangeset<any>;
123
- static changesetFromQueries(builder: Builder<any, any, any>, queries: Array<string | parameterizedQueryOptions>): EntChangeset<any>;
121
+ constructor(viewer: Viewer, builder: Builder<TEnt, TViewer>, placeholderID: ID, conditionalOverride: boolean, operations: DataOperation<any, TViewer>[], 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<TEnt, Data, TViewer, MaybeNull<TEnt>> | undefined);
122
+ static changesetFrom<TEnt extends Ent<TViewer>, TViewer extends Viewer = Viewer>(builder: Builder<TEnt, TViewer, any>, ops: DataOperation<any, TViewer>[]): EntChangeset<any, TViewer>;
123
+ static changesetFromQueries<TEnt extends Ent<TViewer>, TViewer extends Viewer = Viewer>(builder: Builder<TEnt, TViewer, any>, queries: Array<string | parameterizedQueryOptions>): EntChangeset<any, TViewer>;
124
124
  private static changesetFromEdgeOp;
125
- static changesetFromOutboundEdge(builder: Builder<any, any, any>, edgeType: string, id2: Builder<any> | ID, nodeType: string, options?: AssocEdgeInputOptions): Promise<EntChangeset<any>>;
126
- static changesetFromInboundEdge(builder: Builder<any, any, any>, edgeType: string, id1: Builder<any> | ID, nodeType: string, options?: AssocEdgeInputOptions): Promise<EntChangeset<any>>;
127
- static changesetRemoveFromOutboundEdge(builder: Builder<any, any, any>, edgeType: string, id2: ID, options?: AssocEdgeInputOptions): Promise<EntChangeset<any>>;
128
- static changesetRemoveFromInboundEdge(builder: Builder<any, any, any>, edgeType: string, id1: ID, options?: AssocEdgeInputOptions): Promise<EntChangeset<any>>;
125
+ static changesetFromOutboundEdge<TEnt extends Ent<TViewer>, TViewer extends Viewer = Viewer>(builder: Builder<TEnt, TViewer, any>, edgeType: string, id2: Builder<any, TViewer> | ID, nodeType: string, options?: AssocEdgeInputOptions): Promise<EntChangeset<any, TViewer>>;
126
+ static changesetFromInboundEdge<TEnt extends Ent<TViewer>, TViewer extends Viewer = Viewer>(builder: Builder<TEnt, TViewer, any>, edgeType: string, id1: Builder<any, TViewer> | ID, nodeType: string, options?: AssocEdgeInputOptions): Promise<EntChangeset<any, TViewer>>;
127
+ static changesetRemoveFromOutboundEdge<TEnt extends Ent<TViewer>, TViewer extends Viewer = Viewer>(builder: Builder<TEnt, TViewer, any>, edgeType: string, id2: ID, options?: AssocEdgeInputOptions): Promise<EntChangeset<any, TViewer>>;
128
+ static changesetRemoveFromInboundEdge<TEnt extends Ent<TViewer>, TViewer extends Viewer = Viewer>(builder: Builder<TEnt, TViewer, any>, edgeType: string, id1: ID, options?: AssocEdgeInputOptions): Promise<EntChangeset<any, TViewer>>;
129
129
  executor(): Executor;
130
130
  }
131
131
  export {};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@snowtop/ent",
3
- "version": "0.1.13",
3
+ "version": "0.1.14-test1",
4
4
  "description": "snowtop ent framework",
5
5
  "main": "index.js",
6
6
  "types": "index.d.ts",
@@ -7,7 +7,7 @@ import { MockLogs } from "../../testutils/mock_log";
7
7
  import { Table } from "../db/temp_db";
8
8
  export declare function setupTest(): void;
9
9
  export declare function getML(): MockLogs;
10
- export declare function getOperations(): DataOperation<Ent<Viewer<Ent<any> | null, ID | null>>>[];
10
+ export declare function getOperations(): DataOperation<any, Viewer<Ent<any> | null, ID | null>>[];
11
11
  export declare const UserSchema: BuilderSchema<User>;
12
12
  export declare class UserWithBalance extends User {
13
13
  }
@@ -45,7 +45,7 @@ export declare class UserAction extends SimpleAction<User> {
45
45
  getTriggers(): Trigger<User, SimpleBuilder<User>>[];
46
46
  getObservers(): Observer<User, SimpleBuilder<User>>[];
47
47
  }
48
- type getMembershipFunction = (viewer: Viewer, edge: EdgeInputData) => SimpleAction<Ent>;
48
+ type getMembershipFunction = (viewer: Viewer, edge: EdgeInputData<Ent, Viewer>) => SimpleAction<Ent>;
49
49
  export declare class GroupMembershipTrigger implements Trigger<Group, SimpleBuilder<Group>> {
50
50
  private getter;
51
51
  constructor(getter: getMembershipFunction);