@thisisagile/easy 12.19.15 → 12.21.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,14 +1,18 @@
1
- import { Gateway, Id, Json, List } from '../types';
1
+ import { Gateway, Id, Json, List, PageOptions } from '../types';
2
2
  import { QueryProvider } from '../data';
3
3
  import { Table } from './Table';
4
- export declare class TableGateway<T extends Table> extends Gateway {
4
+ export declare type TableOptions = PageOptions & {
5
+ provider?: QueryProvider;
6
+ };
7
+ export declare class TableGateway<T extends Table> extends Gateway<PageOptions> {
5
8
  readonly table: T;
6
9
  readonly provider: QueryProvider;
7
10
  constructor(table: T, provider?: QueryProvider);
8
- all(): Promise<List<Json>>;
9
- byId(id: Id): Promise<Json | undefined>;
10
- exists(id: Id): Promise<boolean>;
11
- add(item: Json): Promise<Json>;
12
- remove(id: Id): Promise<boolean>;
13
- update(item: Json): Promise<Json>;
11
+ protected provide: ({ provider }?: TableOptions) => QueryProvider;
12
+ all(options?: TableOptions): Promise<List<Json>>;
13
+ byId(id: Id, options?: TableOptions): Promise<Json | undefined>;
14
+ exists(id: Id, options?: TableOptions): Promise<boolean>;
15
+ add(item: Json, options?: TableOptions): Promise<Json>;
16
+ remove(id: Id, options?: TableOptions): Promise<boolean>;
17
+ update(item: Json, options?: TableOptions): Promise<Json>;
14
18
  }
@@ -9,30 +9,35 @@ class TableGateway extends types_1.Gateway {
9
9
  super();
10
10
  this.table = table;
11
11
  this.provider = provider;
12
+ this.provide = ({ provider } = {}) => provider ?? this.provider;
12
13
  }
13
- all() {
14
- return this.provider.query(this.table.select()).then(js => js.map(j => this.table.in(j)));
14
+ all(options) {
15
+ return this.provide(options)
16
+ .query(this.table.select())
17
+ .then(js => js.map(j => this.table.in(j)));
15
18
  }
16
- byId(id) {
17
- return this.provider
19
+ byId(id, options) {
20
+ return this.provide(options)
18
21
  .query(this.table.select().where(this.table.id.is(id)))
19
22
  .then(js => js.first())
20
23
  .then(j => (0, utils_1.ifDefined)(j, this.table.in(j)));
21
24
  }
22
- exists(id) {
25
+ exists(id, options) {
23
26
  return this.byId(id).then(j => (0, types_1.isDefined)(j));
24
27
  }
25
- add(item) {
26
- return this.provider
28
+ add(item, options) {
29
+ return this.provide(options)
27
30
  .query(this.table.insert(item))
28
31
  .then(js => (0, validation_1.when)(js.first()).not.isDefined.reject(`Could not add items with id ${item.id}`))
29
32
  .then(j => this.table.in(j));
30
33
  }
31
- remove(id) {
32
- return this.provider.command(this.table.delete().where(this.table.id.is(id))).then(() => true);
34
+ remove(id, options) {
35
+ return this.provide(options)
36
+ .command(this.table.delete().where(this.table.id.is(id)))
37
+ .then(() => true);
33
38
  }
34
- update(item) {
35
- return this.provider
39
+ update(item, options) {
40
+ return this.provide(options)
36
41
  .query(this.table.update(item).where(this.table.id.is(item.id)))
37
42
  .then(js => (0, validation_1.when)(js.first()).not.isDefined.reject(`Could not update item with id ${item.id}`))
38
43
  .then(j => this.table.in(j));
@@ -1 +1 @@
1
- {"version":3,"file":"TableGateway.js","sourceRoot":"","sources":["../../src/sql/TableGateway.ts"],"names":[],"mappings":";;;AAAA,oCAA8D;AAE9D,8CAAqC;AACrC,oCAAqC;AAGrC,MAAa,YAA8B,SAAQ,eAAO;IACxD,YAAqB,KAAQ,EAAW,WAAW,KAAK,CAAC,EAAE,CAAC,OAAO,EAAiB;QAClF,KAAK,EAAE,CAAC;QADW,UAAK,GAAL,KAAK,CAAG;QAAW,aAAQ,GAAR,QAAQ,CAAoC;IAEpF,CAAC;IAED,GAAG;QACD,OAAO,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5F,CAAC;IAED,IAAI,CAAC,EAAM;QACT,OAAO,IAAI,CAAC,QAAQ;aACjB,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;aACtD,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,KAAK,EAAE,CAAC;aACtB,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,IAAA,iBAAS,EAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/C,CAAC;IAED,MAAM,CAAC,EAAM;QACX,OAAO,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,IAAA,iBAAS,EAAC,CAAC,CAAC,CAAC,CAAC;IAC/C,CAAC;IAED,GAAG,CAAC,IAAU;QACZ,OAAO,IAAI,CAAC,QAAQ;aACjB,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;aAC9B,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,IAAA,iBAAI,EAAC,EAAE,CAAC,KAAK,EAAE,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,CAAC,+BAA+B,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC;aAC3F,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IACjC,CAAC;IAED,MAAM,CAAC,EAAM;QACX,OAAO,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC;IACjG,CAAC;IAED,MAAM,CAAC,IAAU;QACf,OAAO,IAAI,CAAC,QAAQ;aACjB,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;aAC/D,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,IAAA,iBAAI,EAAC,EAAE,CAAC,KAAK,EAAE,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,CAAC,iCAAiC,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC;aAC7F,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IACjC,CAAC;CACF;AArCD,oCAqCC"}
1
+ {"version":3,"file":"TableGateway.js","sourceRoot":"","sources":["../../src/sql/TableGateway.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@thisisagile/easy",
3
- "version": "12.19.15",
3
+ "version": "12.21.0",
4
4
  "description": "Straightforward library for building domain-driven microservice architectures",
5
5
  "author": "Sander Hoogendoorn",
6
6
  "license": "MIT",
@@ -31,7 +31,7 @@
31
31
  "access": "public"
32
32
  },
33
33
  "devDependencies": {
34
- "@thisisagile/easy-test": "12.19.15",
34
+ "@thisisagile/easy-test": "12.21.0",
35
35
  "@types/form-urlencoded": "^4.4.0",
36
36
  "@types/jsonwebtoken": "^8.5.9",
37
37
  "@types/luxon": "3.1.0",
@@ -1,42 +1,50 @@
1
- import { Gateway, Id, isDefined, Json, List } from '../types';
1
+ import { Gateway, Id, isDefined, Json, List, PageOptions } from '../types';
2
2
  import { QueryProvider } from '../data';
3
3
  import { when } from '../validation';
4
4
  import { ifDefined } from '../utils';
5
5
  import { Table } from './Table';
6
6
 
7
- export class TableGateway<T extends Table> extends Gateway {
7
+ export type TableOptions = PageOptions & { provider?: QueryProvider };
8
+
9
+ export class TableGateway<T extends Table> extends Gateway<PageOptions> {
8
10
  constructor(readonly table: T, readonly provider = table.db.provide<QueryProvider>()) {
9
11
  super();
10
12
  }
11
13
 
12
- all(): Promise<List<Json>> {
13
- return this.provider.query(this.table.select()).then(js => js.map(j => this.table.in(j)));
14
+ protected provide = ({ provider }: TableOptions = {}): QueryProvider => provider ?? this.provider;
15
+
16
+ all(options?: TableOptions): Promise<List<Json>> {
17
+ return this.provide(options)
18
+ .query(this.table.select())
19
+ .then(js => js.map(j => this.table.in(j)));
14
20
  }
15
21
 
16
- byId(id: Id): Promise<Json | undefined> {
17
- return this.provider
22
+ byId(id: Id, options?: TableOptions): Promise<Json | undefined> {
23
+ return this.provide(options)
18
24
  .query(this.table.select().where(this.table.id.is(id)))
19
25
  .then(js => js.first())
20
26
  .then(j => ifDefined(j, this.table.in(j)));
21
27
  }
22
28
 
23
- exists(id: Id): Promise<boolean> {
29
+ exists(id: Id, options?: TableOptions): Promise<boolean> {
24
30
  return this.byId(id).then(j => isDefined(j));
25
31
  }
26
32
 
27
- add(item: Json): Promise<Json> {
28
- return this.provider
33
+ add(item: Json, options?: TableOptions): Promise<Json> {
34
+ return this.provide(options)
29
35
  .query(this.table.insert(item))
30
36
  .then(js => when(js.first()).not.isDefined.reject(`Could not add items with id ${item.id}`))
31
37
  .then(j => this.table.in(j));
32
38
  }
33
39
 
34
- remove(id: Id): Promise<boolean> {
35
- return this.provider.command(this.table.delete().where(this.table.id.is(id))).then(() => true);
40
+ remove(id: Id, options?: TableOptions): Promise<boolean> {
41
+ return this.provide(options)
42
+ .command(this.table.delete().where(this.table.id.is(id)))
43
+ .then(() => true);
36
44
  }
37
45
 
38
- update(item: Json): Promise<Json> {
39
- return this.provider
46
+ update(item: Json, options?: TableOptions): Promise<Json> {
47
+ return this.provide(options)
40
48
  .query(this.table.update(item).where(this.table.id.is(item.id)))
41
49
  .then(js => when(js.first()).not.isDefined.reject(`Could not update item with id ${item.id}`))
42
50
  .then(j => this.table.in(j));