@ddd-ts/store-firestore 0.0.3-5 → 0.0.3-50

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,19 +1,23 @@
1
- import { Serializer, Store } from "@ddd-ts/model";
2
- import { CollectionReference, Firestore, FirestoreDataConverter, DocumentData, Transaction } from "firebase-admin/firestore";
3
- export declare class FirestoreStore<Model, Id extends {
4
- toString(): string;
5
- }> implements Store<Model, Id> {
1
+ import { Store, Model } from "@ddd-ts/model";
2
+ import { CollectionReference, Firestore, FirestoreDataConverter, DocumentData } from "firebase-admin/firestore";
3
+ import { FirestoreTransaction } from "./firestore.transaction";
4
+ import { ISerializer } from "@ddd-ts/serialization";
5
+ export declare class FirestoreStore<M extends Model> implements Store<M> {
6
6
  readonly collectionName: string;
7
7
  readonly firestore: Firestore;
8
- readonly serializer: Serializer<Model>;
8
+ readonly serializer: ISerializer<M>;
9
9
  readonly converter?: FirestoreDataConverter<DocumentData> | undefined;
10
10
  collection: CollectionReference;
11
- constructor(collectionName: string, firestore: Firestore, serializer: Serializer<Model>, converter?: FirestoreDataConverter<DocumentData> | undefined);
12
- protected executeQuery(query: FirebaseFirestore.Query<any>): Promise<Model[]>;
13
- protected streamQuery(query: FirebaseFirestore.Query<any>): AsyncIterable<Model>;
14
- save(model: Model, trx?: Transaction): Promise<void>;
15
- load(id: Id, trx?: Transaction): Promise<Model | undefined>;
16
- loadAll(): Promise<Model[]>;
17
- delete(id: Id, trx?: Transaction): Promise<void>;
11
+ constructor(collectionName: string, firestore: Firestore, serializer: ISerializer<M>, converter?: FirestoreDataConverter<DocumentData> | undefined);
12
+ private getIdFromModel;
13
+ protected executeQuery(query: FirebaseFirestore.Query<any>, trx?: FirestoreTransaction): Promise<M[]>;
14
+ private streamPages;
15
+ protected streamQuery(query: FirebaseFirestore.Query<any>, pageSize?: number): AsyncIterable<M>;
16
+ save(model: M, trx?: FirestoreTransaction): Promise<void>;
17
+ load(id: M["id"], trx?: FirestoreTransaction): Promise<M | undefined>;
18
+ loadAll(transaction?: FirestoreTransaction): Promise<M[]>;
19
+ delete(id: M["id"], trx?: FirestoreTransaction): Promise<void>;
20
+ loadMany(ids: M["id"][], trx?: FirestoreTransaction): Promise<M[]>;
21
+ streamAll(pageSize?: number): AsyncIterable<M>;
18
22
  }
19
23
  //# sourceMappingURL=firestore.store.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"firestore.store.d.ts","sourceRoot":"","sources":["../src/firestore.store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAClD,OAAO,EACL,mBAAmB,EACnB,SAAS,EACT,sBAAsB,EACtB,YAAY,EACZ,WAAW,EAEZ,MAAM,0BAA0B,CAAC;AAElC,qBAAa,cAAc,CAAC,KAAK,EAAE,EAAE,SAAS;IAAE,QAAQ,IAAI,MAAM,CAAA;CAAE,CAClE,YAAW,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC;aAKT,cAAc,EAAE,MAAM;aACtB,SAAS,EAAE,SAAS;aACpB,UAAU,EAAE,UAAU,CAAC,KAAK,CAAC;aAC7B,SAAS,CAAC;IAN5B,UAAU,EAAE,mBAAmB,CAAC;gBAGd,cAAc,EAAE,MAAM,EACtB,SAAS,EAAE,SAAS,EACpB,UAAU,EAAE,UAAU,CAAC,KAAK,CAAC,EAC7B,SAAS,CAAC,kDAAsC;cAWlD,YAAY,CAC1B,KAAK,EAAE,iBAAiB,CAAC,KAAK,CAAC,GAAG,CAAC,GAClC,OAAO,CAAC,KAAK,EAAE,CAAC;cAQF,WAAW,CAC1B,KAAK,EAAE,iBAAiB,CAAC,KAAK,CAAC,GAAG,CAAC,GAClC,aAAa,CAAC,KAAK,CAAC;IAOjB,IAAI,CAAC,KAAK,EAAE,KAAK,EAAE,GAAG,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IASpD,IAAI,CAAC,EAAE,EAAE,EAAE,EAAE,GAAG,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC,KAAK,GAAG,SAAS,CAAC;IAY3D,OAAO,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;IAO3B,MAAM,CAAC,EAAE,EAAE,EAAE,EAAE,GAAG,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;CAOvD"}
1
+ {"version":3,"file":"firestore.store.d.ts","sourceRoot":"","sources":["../src/firestore.store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAC7C,OAAO,EACL,mBAAmB,EACnB,SAAS,EACT,sBAAsB,EACtB,YAAY,EAGb,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAE,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AAC/D,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAEpD,qBAAa,cAAc,CAAC,CAAC,SAAS,KAAK,CAAE,YAAW,KAAK,CAAC,CAAC,CAAC;aAI5C,cAAc,EAAE,MAAM;aACtB,SAAS,EAAE,SAAS;aACpB,UAAU,EAAE,WAAW,CAAC,CAAC,CAAC;aAC1B,SAAS,CAAC;IAN5B,UAAU,EAAE,mBAAmB,CAAC;gBAGd,cAAc,EAAE,MAAM,EACtB,SAAS,EAAE,SAAS,EACpB,UAAU,EAAE,WAAW,CAAC,CAAC,CAAC,EAC1B,SAAS,CAAC,kDAAsC;IAWlE,OAAO,CAAC,cAAc;cASN,YAAY,CAC1B,KAAK,EAAE,iBAAiB,CAAC,KAAK,CAAC,GAAG,CAAC,EACnC,GAAG,CAAC,EAAE,oBAAoB,GACzB,OAAO,CAAC,CAAC,EAAE,CAAC;YAUA,WAAW;cA4BT,WAAW,CAC1B,KAAK,EAAE,iBAAiB,CAAC,KAAK,CAAC,GAAG,CAAC,EACnC,QAAQ,CAAC,EAAE,MAAM,GAChB,aAAa,CAAC,CAAC,CAAC;IAUb,IAAI,CAAC,KAAK,EAAE,CAAC,EAAE,GAAG,CAAC,EAAE,oBAAoB,GAAG,OAAO,CAAC,IAAI,CAAC;IAOzD,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,GAAG,CAAC,EAAE,oBAAoB,GAAG,OAAO,CAAC,CAAC,GAAG,SAAS,CAAC;IAerE,OAAO,CAAC,WAAW,CAAC,EAAE,oBAAoB,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;IAezD,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,GAAG,CAAC,EAAE,oBAAoB,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ9D,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,GAAG,CAAC,EAAE,oBAAoB,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;IAKxE,SAAS,CAAC,QAAQ,CAAC,EAAE,MAAM,GAAG,aAAa,CAAC,CAAC,CAAC;CAG/C"}
@@ -21,40 +21,87 @@ class FirestoreStore {
21
21
  this.collection = this.firestore.collection(collectionName);
22
22
  }
23
23
  }
24
- async executeQuery(query) {
25
- return Promise.all((await query.get()).docs.map((doc) => this.serializer.deserialize(doc.data())));
24
+ getIdFromModel(m) {
25
+ if (Object.getOwnPropertyNames(m.id).includes("serialize")) {
26
+ if ("serialize" in m.id) {
27
+ return m.id.serialize();
28
+ }
29
+ }
30
+ return m.id.toString();
31
+ }
32
+ async executeQuery(query, trx) {
33
+ const result = trx ? await trx.transaction.get(query) : await query.get();
34
+ return Promise.all(result.docs.map((doc) => this.serializer.deserialize({ id: doc.id, ...doc.data() })));
26
35
  }
27
- async *streamQuery(query) {
28
- const stream = query.stream();
36
+ async *streamPages(query, pageSize) {
37
+ let last;
38
+ let nextPagePromise;
39
+ function getNextPagePromise(cursor) {
40
+ return cursor
41
+ ? query.limit(pageSize).startAfter(cursor).get()
42
+ : query.limit(pageSize).get();
43
+ }
44
+ do {
45
+ const paginatedQuery = nextPagePromise ?? getNextPagePromise(last);
46
+ const { docs } = await paginatedQuery;
47
+ last = docs[pageSize - 1];
48
+ if (last) {
49
+ nextPagePromise = getNextPagePromise(last);
50
+ }
51
+ for (const doc of docs) {
52
+ yield doc;
53
+ }
54
+ } while (last);
55
+ }
56
+ async *streamQuery(query, pageSize) {
57
+ const stream = pageSize === 1
58
+ ? query.stream()
59
+ : this.streamPages(query, pageSize ?? 50);
29
60
  for await (const doc of stream) {
30
- yield this.serializer.deserialize(doc.data());
61
+ yield this.serializer.deserialize({ id: doc.id, ...doc.data() });
31
62
  }
32
63
  }
33
64
  async save(model, trx) {
34
65
  const serialized = await this.serializer.serialize(model);
35
- const ref = this.collection.doc(this.serializer.getIdFromModel(model).toString());
36
- trx ? trx.set(ref, serialized) : await ref.set(serialized);
66
+ const ref = this.collection.doc(this.getIdFromModel(model));
67
+ trx ? trx.transaction.set(ref, serialized) : await ref.set(serialized);
37
68
  }
38
69
  async load(id, trx) {
39
70
  const ref = this.collection.doc(id.toString());
40
- const snapshot = trx ? await trx.get(ref) : await ref.get();
71
+ const snapshot = trx ? await trx.transaction.get(ref) : await ref.get();
41
72
  if (!snapshot.exists) {
42
73
  return undefined;
43
74
  }
44
- return this.serializer.deserialize(snapshot.data());
75
+ return this.serializer.deserialize({
76
+ id: id.toString(),
77
+ ...snapshot.data(),
78
+ });
45
79
  }
46
- async loadAll() {
47
- const snapshot = await this.collection.get();
48
- return Promise.all(snapshot.docs.map((doc) => this.serializer.deserialize(doc.data())));
80
+ async loadAll(transaction) {
81
+ let docs;
82
+ if (transaction) {
83
+ docs = await transaction.transaction.getAll();
84
+ }
85
+ else {
86
+ ({ docs } = await this.collection.get());
87
+ }
88
+ return Promise.all(docs.map((doc) => this.serializer.deserialize({ id: doc.id, ...doc.data() })));
49
89
  }
50
90
  async delete(id, trx) {
51
91
  if (trx) {
52
- trx.delete(this.collection.doc(id.toString()));
92
+ trx.transaction.delete(this.collection.doc(id.toString()));
53
93
  }
54
94
  else {
55
95
  await this.collection.doc(id.toString()).delete();
56
96
  }
57
97
  }
98
+ async loadMany(ids, trx) {
99
+ const result = await Promise.all(ids.map((id) => this.load(id, trx)));
100
+ return result.filter((m) => m !== undefined);
101
+ }
102
+ streamAll(pageSize) {
103
+ return this.streamQuery(this.collection, pageSize);
104
+ }
58
105
  }
59
106
  exports.FirestoreStore = FirestoreStore;
60
107
  //# sourceMappingURL=firestore.store.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"firestore.store.js","sourceRoot":"","sources":["../src/firestore.store.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"firestore.store.js","sourceRoot":"","sources":["../src/firestore.store.ts"],"names":[],"mappings":";;;AAYA,MAAa,cAAc;IAIP;IACA;IACA;IACA;IANlB,UAAU,CAAsB;IAEhC,YACkB,cAAsB,EACtB,SAAoB,EACpB,UAA0B,EAC1B,SAAgD;QAHhD,mBAAc,GAAd,cAAc,CAAQ;QACtB,cAAS,GAAT,SAAS,CAAW;QACpB,eAAU,GAAV,UAAU,CAAgB;QAC1B,cAAS,GAAT,SAAS,CAAuC;QAEhE,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,SAAS;iBAC7B,UAAU,CAAC,cAAc,CAAC;iBAC1B,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;SAClC;aAAM;YACL,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC;SAC7D;IACH,CAAC;IAEO,cAAc,CAAC,CAAI;QACzB,IAAI,MAAM,CAAC,mBAAmB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE;YAC1D,IAAI,WAAW,IAAI,CAAC,CAAC,EAAE,EAAE;gBACvB,OAAO,CAAC,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC;aACzB;SACF;QACD,OAAO,CAAC,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC;IACzB,CAAC;IAES,KAAK,CAAC,YAAY,CAC1B,KAAmC,EACnC,GAA0B;QAE1B,MAAM,MAAM,GAAG,GAAG,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC,GAAG,EAAE,CAAC;QAE1E,OAAO,OAAO,CAAC,GAAG,CAChB,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CACtB,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,EAAE,EAAE,EAAE,GAAG,CAAC,EAAE,EAAE,GAAG,GAAG,CAAC,IAAI,EAAE,EAAE,CAAC,CAC3D,CACF,CAAC;IACJ,CAAC;IAEO,KAAK,CAAC,CAAC,WAAW,CACxB,KAAmC,EACnC,QAAgB;QAEhB,IAAI,IAAkC,CAAC;QACvC,IAAI,eAES,CAAC;QAEd,SAAS,kBAAkB,CAAC,MAAoC;YAC9D,OAAO,MAAM;gBACX,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE;gBAChD,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC;QAClC,CAAC;QAED,GAAG;YACD,MAAM,cAAc,GAAG,eAAe,IAAI,kBAAkB,CAAC,IAAI,CAAC,CAAC;YACnE,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,cAAc,CAAC;YACtC,IAAI,GAAG,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;YAC1B,IAAI,IAAI,EAAE;gBACR,eAAe,GAAG,kBAAkB,CAAC,IAAI,CAAC,CAAC;aAC5C;YACD,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE;gBACtB,MAAM,GAAG,CAAC;aACX;SACF,QAAQ,IAAI,EAAE;IACjB,CAAC;IAES,KAAK,CAAC,CAAC,WAAW,CAC1B,KAAmC,EACnC,QAAiB;QAEjB,MAAM,MAAM,GACV,QAAQ,KAAK,CAAC;YACZ,CAAC,CAAE,KAAK,CAAC,MAAM,EAA2C;YAC1D,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,QAAQ,IAAI,EAAE,CAAC,CAAC;QAC9C,IAAI,KAAK,EAAE,MAAM,GAAG,IAAI,MAAM,EAAE;YAC9B,MAAM,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,EAAE,EAAE,EAAE,GAAG,CAAC,EAAE,EAAE,GAAI,GAAG,CAAC,IAAI,EAAU,EAAE,CAAC,CAAC;SAC3E;IACH,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,KAAQ,EAAE,GAA0B;QAC7C,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAC1D,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC;QAE5D,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IACzE,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,EAAW,EAAE,GAA0B;QAChD,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC;QAE/C,MAAM,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,GAAG,EAAE,CAAC;QAExE,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,OAAO,SAAS,CAAC;SAClB;QAED,OAAO,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC;YACjC,EAAE,EAAE,EAAE,CAAC,QAAQ,EAAE;YACjB,GAAI,QAAQ,CAAC,IAAI,EAAU;SAC5B,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,WAAkC;QAC9C,IAAI,IAAwB,CAAC;QAE7B,IAAI,WAAW,EAAE;YACf,IAAI,GAAG,MAAM,WAAW,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;SAC/C;aAAM;YACL,CAAC,EAAE,IAAI,EAAE,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC,CAAC;SAC1C;QACD,OAAO,OAAO,CAAC,GAAG,CAChB,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CACf,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,EAAE,EAAE,EAAE,GAAG,CAAC,EAAE,EAAE,GAAI,GAAG,CAAC,IAAI,EAAU,EAAE,CAAC,CACpE,CACF,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,EAAW,EAAE,GAA0B;QAClD,IAAI,GAAG,EAAE;YACP,GAAG,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;SAC5D;aAAM;YACL,MAAM,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC;SACnD;IACH,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,GAAc,EAAE,GAA0B;QACvD,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;QACtE,OAAO,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,SAAS,CAAQ,CAAC;IACtD,CAAC;IAED,SAAS,CAAC,QAAiB;QACzB,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC;IACrD,CAAC;CACF;AAtID,wCAsIC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=firestore.store.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"firestore.store.spec.d.ts","sourceRoot":"","sources":["../src/firestore.store.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,62 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ process.env.FIRESTORE_EMULATOR_HOST = "localhost:8080";
27
+ const fb = __importStar(require("firebase-admin"));
28
+ const tests_1 = require("@ddd-ts/tests");
29
+ const _1 = require(".");
30
+ class MyElementStore extends _1.FirestoreStore {
31
+ constructor(database) {
32
+ super("my_collection", database, new tests_1.MyElementSerializer());
33
+ }
34
+ loadEven() {
35
+ return this.executeQuery(this.collection.where("even", "==", true));
36
+ }
37
+ }
38
+ describe("FirestoreStore", () => {
39
+ const app = fb.initializeApp({ projectId: "demo-es" });
40
+ const firestore = app.firestore();
41
+ function getStore() {
42
+ return {
43
+ store: new MyElementStore(firestore),
44
+ transactionPerformer: new _1.FirestoreTransactionPerformer(firestore),
45
+ };
46
+ }
47
+ (0, tests_1.StoreSuite)(getStore);
48
+ it("streams all the database 10 by 10", async () => {
49
+ const { store } = getStore();
50
+ const elements = [...Array.from({ length: 100 }).keys()].map((_, index) => new tests_1.MyElement(index.toString(), `name-${index.toString()}`, index % 2 === 0));
51
+ await Promise.all(elements.map((e) => store.save(e)));
52
+ const streamed = [];
53
+ for await (const element of store.streamAll(10)) {
54
+ streamed.push(element.name);
55
+ }
56
+ expect(streamed.length).toBe(100);
57
+ expect(streamed.sort()).toEqual([...Array.from({ length: 100 }).keys()]
58
+ .map((_, index) => `name-${index.toString()}`)
59
+ .sort());
60
+ });
61
+ });
62
+ //# sourceMappingURL=firestore.store.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"firestore.store.spec.js","sourceRoot":"","sources":["../src/firestore.store.spec.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAAA,OAAO,CAAC,GAAG,CAAC,uBAAuB,GAAG,gBAAgB,CAAC;AACvD,mDAAqC;AACrC,yCAA2E;AAE3E,wBAAkE;AAGlE,MAAM,cAAe,SAAQ,iBAAyB;IACpD,YAAY,QAAmB;QAC7B,KAAK,CAAC,eAAe,EAAE,QAAQ,EAAE,IAAI,2BAAmB,EAAE,CAAC,CAAC;IAC9D,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;IACtE,CAAC;CACF;AAED,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;IAC9B,MAAM,GAAG,GAAG,EAAE,CAAC,aAAa,CAAC,EAAE,SAAS,EAAE,SAAS,EAAE,CAAC,CAAC;IACvD,MAAM,SAAS,GAAG,GAAG,CAAC,SAAS,EAAE,CAAC;IAElC,SAAS,QAAQ;QACf,OAAO;YACL,KAAK,EAAE,IAAI,cAAc,CAAC,SAAS,CAAC;YACpC,oBAAoB,EAAE,IAAI,gCAA6B,CAAC,SAAS,CAAC;SACnE,CAAC;IACJ,CAAC;IAED,IAAA,kBAAU,EAAC,QAAQ,CAAC,CAAC;IAErB,EAAE,CAAC,mCAAmC,EAAE,KAAK,IAAI,EAAE;QACjD,MAAM,EAAE,KAAK,EAAE,GAAG,QAAQ,EAAE,CAAC;QAE7B,MAAM,QAAQ,GAAG,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,GAAG,CAC1D,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CACX,IAAI,iBAAS,CACX,KAAK,CAAC,QAAQ,EAAE,EAChB,QAAQ,KAAK,CAAC,QAAQ,EAAE,EAAE,EAC1B,KAAK,GAAG,CAAC,KAAK,CAAC,CAChB,CACJ,CAAC;QACF,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACtD,MAAM,QAAQ,GAAa,EAAE,CAAC;QAC9B,IAAI,KAAK,EAAE,MAAM,OAAO,IAAI,KAAK,CAAC,SAAS,CAAC,EAAE,CAAC,EAAE;YAC/C,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;SAC7B;QACD,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAClC,MAAM,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAC,OAAO,CAC7B,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;aACpC,GAAG,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,QAAQ,KAAK,CAAC,QAAQ,EAAE,EAAE,CAAC;aAC7C,IAAI,EAAE,CACV,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,14 @@
1
+ import { Firestore } from "firebase-admin/firestore";
2
+ import { TransactionPerformer } from "@ddd-ts/model";
3
+ import { CommitListener } from "@ddd-ts/model/dist/model/transaction";
4
+ export declare class FirestoreTransaction {
5
+ readonly transaction: FirebaseFirestore.Transaction;
6
+ commitListeners: CommitListener[];
7
+ constructor(transaction: FirebaseFirestore.Transaction);
8
+ onCommit(callback: CommitListener): void;
9
+ executeCommitListeners(): Promise<void>;
10
+ }
11
+ export declare class FirestoreTransactionPerformer extends TransactionPerformer<FirestoreTransaction> {
12
+ constructor(db: Firestore);
13
+ }
14
+ //# sourceMappingURL=firestore.transaction.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"firestore.transaction.d.ts","sourceRoot":"","sources":["../src/firestore.transaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AACrD,OAAO,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AACrD,OAAO,EAAE,cAAc,EAAE,MAAM,sCAAsC,CAAC;AAGtE,qBAAa,oBAAoB;aAEH,WAAW,EAAE,iBAAiB,CAAC,WAAW;IADtE,eAAe,EAAE,cAAc,EAAE,CAAM;gBACX,WAAW,EAAE,iBAAiB,CAAC,WAAW;IAEtE,QAAQ,CAAC,QAAQ,EAAE,cAAc;IAI3B,sBAAsB;CAG7B;AAED,qBAAa,6BAA8B,SAAQ,oBAAoB,CAAC,oBAAoB,CAAC;gBAC/E,EAAE,EAAE,SAAS;CAG1B"}
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FirestoreTransactionPerformer = exports.FirestoreTransaction = void 0;
4
+ const model_1 = require("@ddd-ts/model");
5
+ class FirestoreTransaction {
6
+ transaction;
7
+ commitListeners = [];
8
+ constructor(transaction) {
9
+ this.transaction = transaction;
10
+ }
11
+ onCommit(callback) {
12
+ this.commitListeners.push(callback);
13
+ }
14
+ async executeCommitListeners() {
15
+ await Promise.all(this.commitListeners.map((cb) => cb()));
16
+ }
17
+ }
18
+ exports.FirestoreTransaction = FirestoreTransaction;
19
+ class FirestoreTransactionPerformer extends model_1.TransactionPerformer {
20
+ constructor(db) {
21
+ super((effect) => db.runTransaction((trx) => effect(new FirestoreTransaction(trx))));
22
+ }
23
+ }
24
+ exports.FirestoreTransactionPerformer = FirestoreTransactionPerformer;
25
+ //# sourceMappingURL=firestore.transaction.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"firestore.transaction.js","sourceRoot":"","sources":["../src/firestore.transaction.ts"],"names":[],"mappings":";;;AACA,yCAAqD;AAIrD,MAAa,oBAAoB;IAEH;IAD5B,eAAe,GAAqB,EAAE,CAAC;IACvC,YAA4B,WAA0C;QAA1C,gBAAW,GAAX,WAAW,CAA+B;IAAG,CAAC;IAE1E,QAAQ,CAAC,QAAwB;QAC/B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACtC,CAAC;IAED,KAAK,CAAC,sBAAsB;QAC1B,MAAM,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;IAC5D,CAAC;CACF;AAXD,oDAWC;AAED,MAAa,6BAA8B,SAAQ,4BAA0C;IAC3F,YAAY,EAAa;QACvB,KAAK,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,oBAAoB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACvF,CAAC;CACF;AAJD,sEAIC"}
package/dist/index.d.ts CHANGED
@@ -1,3 +1,3 @@
1
1
  export { FirestoreStore } from "./firestore.store";
2
- export { FirebaseTransactionPerformer } from "./firebase.transaction";
2
+ export { FirestoreTransactionPerformer, FirestoreTransaction } from "./firestore.transaction";
3
3
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAE,4BAA4B,EAAE,MAAM,wBAAwB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAE,6BAA6B,EAAE,oBAAoB,EAAE,MAAM,yBAAyB,CAAC"}
package/dist/index.js CHANGED
@@ -1,8 +1,9 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.FirebaseTransactionPerformer = exports.FirestoreStore = void 0;
3
+ exports.FirestoreTransaction = exports.FirestoreTransactionPerformer = exports.FirestoreStore = void 0;
4
4
  var firestore_store_1 = require("./firestore.store");
5
5
  Object.defineProperty(exports, "FirestoreStore", { enumerable: true, get: function () { return firestore_store_1.FirestoreStore; } });
6
- var firebase_transaction_1 = require("./firebase.transaction");
7
- Object.defineProperty(exports, "FirebaseTransactionPerformer", { enumerable: true, get: function () { return firebase_transaction_1.FirebaseTransactionPerformer; } });
6
+ var firestore_transaction_1 = require("./firestore.transaction");
7
+ Object.defineProperty(exports, "FirestoreTransactionPerformer", { enumerable: true, get: function () { return firestore_transaction_1.FirestoreTransactionPerformer; } });
8
+ Object.defineProperty(exports, "FirestoreTransaction", { enumerable: true, get: function () { return firestore_transaction_1.FirestoreTransaction; } });
8
9
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AAAA,qDAAmD;AAA1C,iHAAA,cAAc,OAAA;AACvB,+DAAsE;AAA7D,oIAAA,4BAA4B,OAAA"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AAAA,qDAAmD;AAA1C,iHAAA,cAAc,OAAA;AACvB,iEAA8F;AAArF,sIAAA,6BAA6B,OAAA;AAAE,6HAAA,oBAAoB,OAAA"}
package/package.json CHANGED
@@ -1,20 +1,19 @@
1
1
  {
2
- "name": "@ddd-ts/store-firestore",
3
- "version": "0.0.3-5",
4
- "main": "dist/index.js",
5
- "types": "dist/index.d.ts",
6
- "license": "MIT",
7
- "scripts": {
8
- "build": "builder"
9
- },
10
- "dependencies": {
11
- "firebase-admin": "^11.5.0"
12
- },
13
- "peerDependencies": {
14
- "@ddd-ts/model": "*"
15
- },
16
- "devDependencies": {
17
- "@ddd-ts/dev": "*",
18
- "@ddd-ts/types": "*"
19
- }
2
+ "name": "@ddd-ts/store-firestore",
3
+ "version": "0.0.3-50",
4
+ "main": "dist/index.js",
5
+ "types": "dist/index.d.ts",
6
+ "license": "MIT",
7
+ "scripts": {
8
+ "build": "builder"
9
+ },
10
+ "dependencies": {
11
+ "@ddd-ts/model": "*",
12
+ "@ddd-ts/serialization": "*",
13
+ "firebase-admin": "^11.5.0"
14
+ },
15
+ "devDependencies": {
16
+ "@ddd-ts/dev": "*",
17
+ "@ddd-ts/types": "*"
18
+ }
20
19
  }
@@ -1,6 +0,0 @@
1
- import { Firestore } from "firebase-admin/firestore";
2
- import { TransactionPerformer } from "@ddd-ts/model";
3
- export declare class FirebaseTransactionPerformer extends TransactionPerformer<FirebaseFirestore.Transaction> {
4
- constructor(db: Firestore);
5
- }
6
- //# sourceMappingURL=firebase.transaction.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"firebase.transaction.d.ts","sourceRoot":"","sources":["../src/firebase.transaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AACrD,OAAO,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AAErD,qBAAa,4BAA6B,SAAQ,oBAAoB,CAAC,iBAAiB,CAAC,WAAW,CAAC;gBACvF,EAAE,EAAE,SAAS;CAG1B"}
@@ -1,11 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.FirebaseTransactionPerformer = void 0;
4
- const model_1 = require("@ddd-ts/model");
5
- class FirebaseTransactionPerformer extends model_1.TransactionPerformer {
6
- constructor(db) {
7
- super((effect) => db.runTransaction(effect));
8
- }
9
- }
10
- exports.FirebaseTransactionPerformer = FirebaseTransactionPerformer;
11
- //# sourceMappingURL=firebase.transaction.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"firebase.transaction.js","sourceRoot":"","sources":["../src/firebase.transaction.ts"],"names":[],"mappings":";;;AACA,yCAAqD;AAErD,MAAa,4BAA6B,SAAQ,4BAAmD;IACnG,YAAY,EAAa;QACvB,KAAK,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC;IAC/C,CAAC;CACF;AAJD,oEAIC"}