@ddd-ts/event-sourcing-inmemory 0.0.35 → 0.0.37

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 (61) hide show
  1. package/package.json +20 -11
  2. package/dist/in-memory.event-lake.aggregate-store.d.ts +0 -37
  3. package/dist/in-memory.event-lake.aggregate-store.d.ts.map +0 -1
  4. package/dist/in-memory.event-lake.aggregate-store.js +0 -50
  5. package/dist/in-memory.event-lake.aggregate-store.js.map +0 -1
  6. package/dist/in-memory.event-lake.aggregate-store.spec.d.ts +0 -2
  7. package/dist/in-memory.event-lake.aggregate-store.spec.d.ts.map +0 -1
  8. package/dist/in-memory.event-lake.aggregate-store.spec.js +0 -21
  9. package/dist/in-memory.event-lake.aggregate-store.spec.js.map +0 -1
  10. package/dist/in-memory.event-lake.storage-layer.d.ts +0 -10
  11. package/dist/in-memory.event-lake.storage-layer.d.ts.map +0 -1
  12. package/dist/in-memory.event-lake.storage-layer.js +0 -55
  13. package/dist/in-memory.event-lake.storage-layer.js.map +0 -1
  14. package/dist/in-memory.event-lake.store.d.ts +0 -6
  15. package/dist/in-memory.event-lake.store.d.ts.map +0 -1
  16. package/dist/in-memory.event-lake.store.js +0 -12
  17. package/dist/in-memory.event-lake.store.js.map +0 -1
  18. package/dist/in-memory.event-lake.store.spec.d.ts +0 -2
  19. package/dist/in-memory.event-lake.store.spec.d.ts.map +0 -1
  20. package/dist/in-memory.event-lake.store.spec.js +0 -14
  21. package/dist/in-memory.event-lake.store.spec.js.map +0 -1
  22. package/dist/in-memory.event-stream.aggregate-store.d.ts +0 -30
  23. package/dist/in-memory.event-stream.aggregate-store.d.ts.map +0 -1
  24. package/dist/in-memory.event-stream.aggregate-store.js +0 -40
  25. package/dist/in-memory.event-stream.aggregate-store.js.map +0 -1
  26. package/dist/in-memory.event-stream.aggregate-store.spec.d.ts +0 -2
  27. package/dist/in-memory.event-stream.aggregate-store.spec.d.ts.map +0 -1
  28. package/dist/in-memory.event-stream.aggregate-store.spec.js +0 -17
  29. package/dist/in-memory.event-stream.aggregate-store.spec.js.map +0 -1
  30. package/dist/in-memory.event-stream.storage-layer.d.ts +0 -11
  31. package/dist/in-memory.event-stream.storage-layer.d.ts.map +0 -1
  32. package/dist/in-memory.event-stream.storage-layer.js +0 -45
  33. package/dist/in-memory.event-stream.storage-layer.js.map +0 -1
  34. package/dist/in-memory.event-stream.store.d.ts +0 -6
  35. package/dist/in-memory.event-stream.store.d.ts.map +0 -1
  36. package/dist/in-memory.event-stream.store.js +0 -12
  37. package/dist/in-memory.event-stream.store.js.map +0 -1
  38. package/dist/in-memory.event-stream.store.spec.d.ts +0 -2
  39. package/dist/in-memory.event-stream.store.spec.d.ts.map +0 -1
  40. package/dist/in-memory.event-stream.store.spec.js +0 -14
  41. package/dist/in-memory.event-stream.store.spec.js.map +0 -1
  42. package/dist/in-memory.projected-stream.reader.d.ts +0 -6
  43. package/dist/in-memory.projected-stream.reader.d.ts.map +0 -1
  44. package/dist/in-memory.projected-stream.reader.js +0 -12
  45. package/dist/in-memory.projected-stream.reader.js.map +0 -1
  46. package/dist/in-memory.projected-stream.reader.spec.d.ts +0 -2
  47. package/dist/in-memory.projected-stream.reader.spec.d.ts.map +0 -1
  48. package/dist/in-memory.projected-stream.reader.spec.js +0 -17
  49. package/dist/in-memory.projected-stream.reader.spec.js.map +0 -1
  50. package/dist/in-memory.projected-stream.storage-layer.d.ts +0 -27
  51. package/dist/in-memory.projected-stream.storage-layer.d.ts.map +0 -1
  52. package/dist/in-memory.projected-stream.storage-layer.js +0 -121
  53. package/dist/in-memory.projected-stream.storage-layer.js.map +0 -1
  54. package/dist/in-memory.snapshotter.d.ts +0 -6
  55. package/dist/in-memory.snapshotter.d.ts.map +0 -1
  56. package/dist/in-memory.snapshotter.js +0 -30
  57. package/dist/in-memory.snapshotter.js.map +0 -1
  58. package/dist/index.d.ts +0 -10
  59. package/dist/index.d.ts.map +0 -1
  60. package/dist/index.js +0 -26
  61. package/dist/index.js.map +0 -1
package/package.json CHANGED
@@ -1,7 +1,6 @@
1
1
  {
2
2
  "name": "@ddd-ts/event-sourcing-inmemory",
3
- "version": "0.0.35",
4
- "main": "dist/index.js",
3
+ "version": "0.0.37",
5
4
  "types": "dist/index.d.ts",
6
5
  "license": "MIT",
7
6
  "repository": {
@@ -9,20 +8,30 @@
9
8
  },
10
9
  "scripts": {
11
10
  "test": "jest --config node_modules/@ddd-ts/tools/jest.config.js",
12
- "build": "tsc"
11
+ "build": "tsdown --config node_modules/@ddd-ts/tools/tsdown.config.js"
13
12
  },
14
13
  "dependencies": {
15
- "@ddd-ts/core": "0.0.35",
16
- "@ddd-ts/shape": "0.0.35",
17
- "@ddd-ts/store-inmemory": "0.0.35",
18
- "@ddd-ts/types": "0.0.35"
14
+ "@ddd-ts/core": "0.0.37",
15
+ "@ddd-ts/shape": "0.0.37",
16
+ "@ddd-ts/store-inmemory": "0.0.37",
17
+ "@ddd-ts/types": "0.0.37"
19
18
  },
20
19
  "devDependencies": {
21
- "@ddd-ts/shape": "0.0.35",
22
- "@ddd-ts/tests": "0.0.35",
23
- "@ddd-ts/tools": "0.0.35",
24
- "@ddd-ts/traits": "0.0.35",
20
+ "@ddd-ts/shape": "0.0.37",
21
+ "@ddd-ts/tests": "0.0.37",
22
+ "@ddd-ts/tools": "0.0.37",
23
+ "@ddd-ts/traits": "0.0.37",
25
24
  "@types/jest": "^29.5.1",
26
25
  "@types/node": "^20.12.4"
26
+ },
27
+ "exports": {
28
+ ".": "./src/index.ts",
29
+ "./package.json": "./package.json"
30
+ },
31
+ "publishConfig": {
32
+ "exports": {
33
+ ".": "./dist/index.js",
34
+ "./package.json": "./package.json"
35
+ }
27
36
  }
28
37
  }
@@ -1,37 +0,0 @@
1
- import { LakeId, type IEventBus, EventLakeStore, EventOf, ISerializer, IEventSourced, IIdentifiable, EventSourced, Identifiable } from "@ddd-ts/core";
2
- import { InMemoryDatabase, InMemoryStore, InMemoryTransaction, InMemoryTransactionPerformer } from "@ddd-ts/store-inmemory";
3
- import { HasTrait } from "@ddd-ts/traits";
4
- export declare const MakeInMemoryEventLakeAggregateStore: <A extends HasTrait<typeof EventSourced> & HasTrait<typeof Identifiable>>(AGGREGATE: A) => abstract new (database: InMemoryDatabase, collection: string, serializer: ISerializer<InstanceType<A>> & ISerializer<EventOf<InstanceType<A>>>, eventBus?: IEventBus) => {
5
- readonly database: InMemoryDatabase;
6
- readonly collection: string;
7
- getLakeId(instance: InstanceType<A>): LakeId;
8
- transaction: InMemoryTransactionPerformer;
9
- lakeStore: EventLakeStore<EventOf<InstanceType<A>>>;
10
- readonly serializer: ISerializer<EventOf<InstanceType<A>>, {}> & ISerializer<InstanceType<A>, {}>;
11
- readonly eventBus?: IEventBus | undefined;
12
- readonly $name?: string | undefined;
13
- save(aggregate: InstanceType<A>, trx?: InMemoryTransaction): Promise<void>;
14
- filter(predicate: (model: InstanceType<A>) => boolean, trx?: InMemoryTransaction): Promise<InstanceType<A>[]>;
15
- clear(): void;
16
- create(model: InstanceType<A>, trx?: InMemoryTransaction): Promise<void>;
17
- saveAll(models: InstanceType<A>[], trx?: InMemoryTransaction): Promise<void>;
18
- load(id: InstanceType<A>["id"], trx?: InMemoryTransaction): Promise<InstanceType<A> | undefined>;
19
- loadAll(trx?: InMemoryTransaction): Promise<InstanceType<A>[]>;
20
- loadMany(ids: InstanceType<A>["id"][], trx?: InMemoryTransaction): Promise<InstanceType<A>[]>;
21
- delete(id: InstanceType<A>["id"], trx?: InMemoryTransaction): Promise<void>;
22
- countAll(): Promise<number>;
23
- streamAll(): AsyncIterable<InstanceType<A>>;
24
- };
25
- export declare abstract class InMemoryEventLakeAggregateStore<A extends IEventSourced & IIdentifiable> extends InMemoryStore<A> {
26
- readonly database: InMemoryDatabase;
27
- readonly collection: string;
28
- readonly serializer: ISerializer<EventOf<A>> & ISerializer<A>;
29
- readonly eventBus?: IEventBus | undefined;
30
- readonly $name?: string | undefined;
31
- transaction: InMemoryTransactionPerformer;
32
- lakeStore: EventLakeStore<EventOf<A>>;
33
- constructor(database: InMemoryDatabase, collection: string, serializer: ISerializer<EventOf<A>> & ISerializer<A>, eventBus?: IEventBus | undefined, $name?: string | undefined);
34
- abstract getLakeId(instance: A): LakeId;
35
- save(aggregate: A, trx?: InMemoryTransaction): Promise<void>;
36
- }
37
- //# sourceMappingURL=in-memory.event-lake.aggregate-store.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.event-lake.aggregate-store.d.ts","sourceRoot":"","sources":["../src/in-memory.event-lake.aggregate-store.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,MAAM,EACN,KAAK,SAAS,EACd,cAAc,EACd,OAAO,EACP,WAAW,EACX,aAAa,EACb,aAAa,EAEb,YAAY,EACZ,YAAY,EACb,MAAM,cAAc,CAAC;AACtB,OAAO,EACL,gBAAgB,EAChB,aAAa,EACb,mBAAmB,EACnB,4BAA4B,EAC7B,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAE1C,eAAO,MAAM,mCAAmC,GAC9C,CAAC,SAAS,QAAQ,CAAC,OAAO,YAAY,CAAC,GAAG,QAAQ,CAAC,OAAO,YAAY,CAAC,aAE5D,CAAC,6BAMkB,gBAAgB,cACd,MAAM,cACtB,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,GACtC,WAAW,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,aAC5B,SAAS;uBAJM,gBAAgB;yBACd,MAAM;wBAQP,YAAY,CAAC,CAAC,CAAC,GAAG,MAAM;iBAS1C,4BAA4B;;;wBAMZ,SAAS;qBACZ,MAAM;2CAcQ,mBAAmB;;;;;;;;;;;CA1B5D,CAAC;AAEF,8BAAsB,+BAA+B,CACnD,CAAC,SAAS,aAAa,GAAG,aAAa,CACvC,SAAQ,aAAa,CAAC,CAAC,CAAC;aAIN,QAAQ,EAAE,gBAAgB;aAC1B,UAAU,EAAE,MAAM;aAClB,UAAU,EAAE,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC;aACpD,QAAQ,CAAC,EAAE,SAAS;aACpB,KAAK,CAAC,EAAE,MAAM;IAPhC,WAAW,EAAE,4BAA4B,CAAC;IAC1C,SAAS,EAAE,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;gBAEpB,QAAQ,EAAE,gBAAgB,EAC1B,UAAU,EAAE,MAAM,EAClB,UAAU,EAAE,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC,EACpD,QAAQ,CAAC,EAAE,SAAS,YAAA,EACpB,KAAK,CAAC,EAAE,MAAM,YAAA;IAYhC,QAAQ,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC,GAAG,MAAM;IAExB,IAAI,CAAC,SAAS,EAAE,CAAC,EAAE,GAAG,CAAC,EAAE,mBAAmB;CAW5D"}
@@ -1,50 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.InMemoryEventLakeAggregateStore = exports.MakeInMemoryEventLakeAggregateStore = void 0;
4
- const core_1 = require("@ddd-ts/core");
5
- const store_inmemory_1 = require("@ddd-ts/store-inmemory");
6
- const in_memory_event_lake_storage_layer_1 = require("./in-memory.event-lake.storage-layer");
7
- const MakeInMemoryEventLakeAggregateStore = (AGGREGATE) => {
8
- class $InMemoryEventLakeAggregateStore extends InMemoryEventLakeAggregateStore {
9
- database;
10
- collection;
11
- constructor(database, collection, serializer, eventBus) {
12
- super(database, collection, serializer, eventBus, AGGREGATE.name);
13
- this.database = database;
14
- this.collection = collection;
15
- }
16
- }
17
- return $InMemoryEventLakeAggregateStore;
18
- };
19
- exports.MakeInMemoryEventLakeAggregateStore = MakeInMemoryEventLakeAggregateStore;
20
- class InMemoryEventLakeAggregateStore extends store_inmemory_1.InMemoryStore {
21
- database;
22
- collection;
23
- serializer;
24
- eventBus;
25
- $name;
26
- transaction;
27
- lakeStore;
28
- constructor(database, collection, serializer, eventBus, $name) {
29
- const storageLayer = new in_memory_event_lake_storage_layer_1.InMemoryEventLakeStorageLayer(database);
30
- super(collection, database, serializer, $name);
31
- this.database = database;
32
- this.collection = collection;
33
- this.serializer = serializer;
34
- this.eventBus = eventBus;
35
- this.$name = $name;
36
- this.lakeStore = new core_1.EventLakeStore(storageLayer, serializer, eventBus);
37
- this.transaction = new store_inmemory_1.InMemoryTransactionPerformer(database);
38
- }
39
- async save(aggregate, trx) {
40
- const changes = aggregate.changes;
41
- await this.transaction.performWith(trx, async (trx) => {
42
- const lakeId = this.getLakeId(aggregate);
43
- await super.save(aggregate, trx);
44
- await this.lakeStore.append(lakeId, changes, trx);
45
- aggregate.clearChanges();
46
- });
47
- }
48
- }
49
- exports.InMemoryEventLakeAggregateStore = InMemoryEventLakeAggregateStore;
50
- //# sourceMappingURL=in-memory.event-lake.aggregate-store.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.event-lake.aggregate-store.js","sourceRoot":"","sources":["../src/in-memory.event-lake.aggregate-store.ts"],"names":[],"mappings":";;;AAAA,uCAWsB;AACtB,2DAKgC;AAChC,6FAAqF;AAG9E,MAAM,mCAAmC,GAAG,CAGjD,SAAY,EACZ,EAAE;IACF,MAAe,gCAAiC,SAAQ,+BAEvD;QAEmB;QACA;QAFlB,YACkB,QAA0B,EAC1B,UAAkB,EAClC,UACuC,EACvC,QAAoB;YAEpB,KAAK,CAAC,QAAQ,EAAE,UAAU,EAAE,UAAU,EAAE,QAAQ,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC;YANlD,aAAQ,GAAR,QAAQ,CAAkB;YAC1B,eAAU,GAAV,UAAU,CAAQ;QAMpC,CAAC;KAGF;IAED,OAAO,gCAAgC,CAAC;AAC1C,CAAC,CAAC;AAtBW,QAAA,mCAAmC,uCAsB9C;AAEF,MAAsB,+BAEpB,SAAQ,8BAAgB;IAIN;IACA;IACA;IACA;IACA;IAPlB,WAAW,CAA+B;IAC1C,SAAS,CAA6B;IACtC,YACkB,QAA0B,EAC1B,UAAkB,EAClB,UAAoD,EACpD,QAAoB,EACpB,KAAc;QAE9B,MAAM,YAAY,GAAG,IAAI,kEAA6B,CAAC,QAAQ,CAAC,CAAC;QACjE,KAAK,CAAC,UAAU,EAAE,QAAQ,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC;QAP/B,aAAQ,GAAR,QAAQ,CAAkB;QAC1B,eAAU,GAAV,UAAU,CAAQ;QAClB,eAAU,GAAV,UAAU,CAA0C;QACpD,aAAQ,GAAR,QAAQ,CAAY;QACpB,UAAK,GAAL,KAAK,CAAS;QAI9B,IAAI,CAAC,SAAS,GAAG,IAAI,qBAAc,CACjC,YAAY,EACZ,UAAU,EACV,QAAQ,CACT,CAAC;QACF,IAAI,CAAC,WAAW,GAAG,IAAI,6CAA4B,CAAC,QAAQ,CAAC,CAAC;IAChE,CAAC;IAIQ,KAAK,CAAC,IAAI,CAAC,SAAY,EAAE,GAAyB;QACzD,MAAM,OAAO,GAAG,SAAS,CAAC,OAAgC,CAAC;QAE3D,MAAM,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,GAAG,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE;YACpD,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;YAEzC,MAAM,KAAK,CAAC,IAAI,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;YACjC,MAAM,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,EAAE,GAAG,CAAC,CAAC;YAClD,SAAS,CAAC,YAAY,EAAE,CAAC;QAC3B,CAAC,CAAC,CAAC;IACL,CAAC;CACF;AAnCD,0EAmCC","sourcesContent":["import {\n LakeId,\n type IEventBus,\n EventLakeStore,\n EventOf,\n ISerializer,\n IEventSourced,\n IIdentifiable,\n IChange,\n EventSourced,\n Identifiable,\n} from \"@ddd-ts/core\";\nimport {\n InMemoryDatabase,\n InMemoryStore,\n InMemoryTransaction,\n InMemoryTransactionPerformer,\n} from \"@ddd-ts/store-inmemory\";\nimport { InMemoryEventLakeStorageLayer } from \"./in-memory.event-lake.storage-layer\";\nimport { HasTrait } from \"@ddd-ts/traits\";\n\nexport const MakeInMemoryEventLakeAggregateStore = <\n A extends HasTrait<typeof EventSourced> & HasTrait<typeof Identifiable>,\n>(\n AGGREGATE: A,\n) => {\n abstract class $InMemoryEventLakeAggregateStore extends InMemoryEventLakeAggregateStore<\n InstanceType<A>\n > {\n constructor(\n public readonly database: InMemoryDatabase,\n public readonly collection: string,\n serializer: ISerializer<InstanceType<A>> &\n ISerializer<EventOf<InstanceType<A>>>,\n eventBus?: IEventBus,\n ) {\n super(database, collection, serializer, eventBus, AGGREGATE.name);\n }\n\n abstract getLakeId(instance: InstanceType<A>): LakeId;\n }\n\n return $InMemoryEventLakeAggregateStore;\n};\n\nexport abstract class InMemoryEventLakeAggregateStore<\n A extends IEventSourced & IIdentifiable,\n> extends InMemoryStore<A> {\n transaction: InMemoryTransactionPerformer;\n lakeStore: EventLakeStore<EventOf<A>>;\n constructor(\n public readonly database: InMemoryDatabase,\n public readonly collection: string,\n public readonly serializer: ISerializer<EventOf<A>> & ISerializer<A>,\n public readonly eventBus?: IEventBus,\n public readonly $name?: string,\n ) {\n const storageLayer = new InMemoryEventLakeStorageLayer(database);\n super(collection, database, serializer, $name);\n this.lakeStore = new EventLakeStore<EventOf<A>>(\n storageLayer,\n serializer,\n eventBus,\n );\n this.transaction = new InMemoryTransactionPerformer(database);\n }\n\n abstract getLakeId(instance: A): LakeId;\n\n override async save(aggregate: A, trx?: InMemoryTransaction) {\n const changes = aggregate.changes as IChange<EventOf<A>>[];\n\n await this.transaction.performWith(trx, async (trx) => {\n const lakeId = this.getLakeId(aggregate);\n\n await super.save(aggregate, trx);\n await this.lakeStore.append(lakeId, changes, trx);\n aggregate.clearChanges();\n });\n }\n}\n"]}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=in-memory.event-lake.aggregate-store.spec.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.event-lake.aggregate-store.spec.d.ts","sourceRoot":"","sources":["../src/in-memory.event-lake.aggregate-store.spec.ts"],"names":[],"mappings":""}
@@ -1,21 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const core_1 = require("@ddd-ts/core");
4
- const store_inmemory_1 = require("@ddd-ts/store-inmemory");
5
- const in_memory_event_lake_aggregate_store_1 = require("./in-memory.event-lake.aggregate-store");
6
- describe("InMemoryEventLakeAggregateStore", () => {
7
- const database = new store_inmemory_1.InMemoryDatabase();
8
- class AggregateStore extends in_memory_event_lake_aggregate_store_1.InMemoryEventLakeAggregateStore {
9
- getLakeId(instance) {
10
- return core_1.LakeId.from(instance.constructor.name, instance.id.serialize());
11
- }
12
- }
13
- (0, core_1.EventLakeAggregateStoreSuite)({
14
- transaction: new store_inmemory_1.InMemoryTransactionPerformer(database),
15
- getAggregateStore: (AGGREGATE, serializer, eventBus) => {
16
- return new AggregateStore(database, AGGREGATE.name, serializer, eventBus);
17
- },
18
- getStore: (name, serializer) => new store_inmemory_1.InMemoryStore(name, database, serializer),
19
- });
20
- });
21
- //# sourceMappingURL=in-memory.event-lake.aggregate-store.spec.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.event-lake.aggregate-store.spec.js","sourceRoot":"","sources":["../src/in-memory.event-lake.aggregate-store.spec.ts"],"names":[],"mappings":";;AAAA,uCAKsB;AACtB,2DAIgC;AAChC,iGAAyF;AAEzF,QAAQ,CAAC,iCAAiC,EAAE,GAAG,EAAE;IAC/C,MAAM,QAAQ,GAAG,IAAI,iCAAgB,EAAE,CAAC;IAExC,MAAM,cAEJ,SAAQ,sEAAkC;QAC1C,SAAS,CAAC,QAAW;YACnB,OAAO,aAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,EAAE,QAAQ,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC,CAAC;QACzE,CAAC;KACF;IAED,IAAA,mCAA4B,EAAC;QAC3B,WAAW,EAAE,IAAI,6CAA4B,CAAC,QAAQ,CAAC;QACvD,iBAAiB,EAAE,CAAC,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,EAAE;YACrD,OAAO,IAAI,cAAc,CACvB,QAAQ,EACR,SAAS,CAAC,IAAI,EACd,UAAU,EACV,QAAQ,CACT,CAAC;QACJ,CAAC;QACD,QAAQ,EAAE,CAAC,IAAI,EAAE,UAAU,EAAE,EAAE,CAC7B,IAAI,8BAAa,CAAC,IAAI,EAAE,QAAQ,EAAE,UAAU,CAAC;KAChD,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import {\n EventLakeAggregateStoreSuite,\n IEventSourced,\n IIdentifiable,\n LakeId,\n} from \"@ddd-ts/core\";\nimport {\n InMemoryDatabase,\n InMemoryStore,\n InMemoryTransactionPerformer,\n} from \"@ddd-ts/store-inmemory\";\nimport { InMemoryEventLakeAggregateStore } from \"./in-memory.event-lake.aggregate-store\";\n\ndescribe(\"InMemoryEventLakeAggregateStore\", () => {\n const database = new InMemoryDatabase();\n\n class AggregateStore<\n T extends IEventSourced & IIdentifiable,\n > extends InMemoryEventLakeAggregateStore<T> {\n getLakeId(instance: T): LakeId {\n return LakeId.from(instance.constructor.name, instance.id.serialize());\n }\n }\n\n EventLakeAggregateStoreSuite({\n transaction: new InMemoryTransactionPerformer(database),\n getAggregateStore: (AGGREGATE, serializer, eventBus) => {\n return new AggregateStore<InstanceType<typeof AGGREGATE>>(\n database,\n AGGREGATE.name,\n serializer,\n eventBus,\n );\n },\n getStore: (name, serializer) =>\n new InMemoryStore(name, database, serializer),\n });\n});\n"]}
@@ -1,10 +0,0 @@
1
- import { LakeId, type ISerializedChange, type ISerializedFact, EventLakeStorageLayer, EventId } from "@ddd-ts/core";
2
- import { ISerializedSavedChange } from "@ddd-ts/core/dist/interfaces/es-event";
3
- import { InMemoryDatabase, InMemoryTransaction } from "@ddd-ts/store-inmemory";
4
- export declare class InMemoryEventLakeStorageLayer implements EventLakeStorageLayer {
5
- readonly database: InMemoryDatabase;
6
- constructor(database: InMemoryDatabase);
7
- append(lakeId: LakeId, changes: ISerializedChange[], trx: InMemoryTransaction): Promise<ISerializedSavedChange[]>;
8
- read(lakeId: LakeId, startAfter?: EventId, endAt?: EventId): AsyncIterable<ISerializedFact>;
9
- }
10
- //# sourceMappingURL=in-memory.event-lake.storage-layer.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.event-lake.storage-layer.d.ts","sourceRoot":"","sources":["../src/in-memory.event-lake.storage-layer.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,MAAM,EACN,KAAK,iBAAiB,EACtB,KAAK,eAAe,EACpB,qBAAqB,EACrB,OAAO,EACR,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,sBAAsB,EAAE,MAAM,uCAAuC,CAAC;AAC/E,OAAO,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAE/E,qBAAa,6BAA8B,YAAW,qBAAqB;aAC7C,QAAQ,EAAE,gBAAgB;gBAA1B,QAAQ,EAAE,gBAAgB;IAEhD,MAAM,CACV,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,iBAAiB,EAAE,EAC5B,GAAG,EAAE,mBAAmB;IA+BnB,IAAI,CACT,MAAM,EAAE,MAAM,EACd,UAAU,CAAC,EAAE,OAAO,EACpB,KAAK,CAAC,EAAE,OAAO,GACd,aAAa,CAAC,eAAe,CAAC;CA6BlC"}
@@ -1,55 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.InMemoryEventLakeStorageLayer = void 0;
4
- class InMemoryEventLakeStorageLayer {
5
- database;
6
- constructor(database) {
7
- this.database = database;
8
- }
9
- async append(lakeId, changes, trx) {
10
- const result = [];
11
- let revision = 0;
12
- for (const change of changes) {
13
- const ref = `${lakeId.serialize()}/${change.id}`;
14
- const stored = {
15
- ...change,
16
- ref: ref,
17
- revision: revision,
18
- };
19
- this.database.save(lakeId.serialize(), change.id, stored, trx.transaction);
20
- result.push({
21
- ...change,
22
- ref: ref,
23
- revision: revision,
24
- occurredAt: undefined,
25
- });
26
- revision++;
27
- }
28
- return result;
29
- }
30
- async *read(lakeId, startAfter, endAt) {
31
- const events = this.database.loadAll(lakeId.serialize());
32
- const sorted = events.sort((a, b) => a.data.savedAt === b.data.savedAt
33
- ? a.data.data.revision - b.data.data.revision
34
- : a.data.savedAt < b.data.savedAt
35
- ? -1
36
- : 1);
37
- const facts = sorted.map((e) => e.data);
38
- let started = !startAfter;
39
- for (const fact of facts) {
40
- if (startAfter && fact.data.id === startAfter.serialize()) {
41
- started = true;
42
- continue;
43
- }
44
- if (endAt && fact.data.id === endAt.serialize()) {
45
- yield { ...fact.data, occurredAt: fact.data.savedAt };
46
- break;
47
- }
48
- if (started) {
49
- yield { ...fact.data, occurredAt: fact.data.savedAt };
50
- }
51
- }
52
- }
53
- }
54
- exports.InMemoryEventLakeStorageLayer = InMemoryEventLakeStorageLayer;
55
- //# sourceMappingURL=in-memory.event-lake.storage-layer.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.event-lake.storage-layer.js","sourceRoot":"","sources":["../src/in-memory.event-lake.storage-layer.ts"],"names":[],"mappings":";;;AAUA,MAAa,6BAA6B;IACZ;IAA5B,YAA4B,QAA0B;QAA1B,aAAQ,GAAR,QAAQ,CAAkB;IAAG,CAAC;IAE1D,KAAK,CAAC,MAAM,CACV,MAAc,EACd,OAA4B,EAC5B,GAAwB;QAExB,MAAM,MAAM,GAA6B,EAAE,CAAC;QAE5C,IAAI,QAAQ,GAAG,CAAC,CAAC;QACjB,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC7B,MAAM,GAAG,GAAG,GAAG,MAAM,CAAC,SAAS,EAAE,IAAI,MAAM,CAAC,EAAE,EAAE,CAAC;YAEjD,MAAM,MAAM,GAAG;gBACb,GAAG,MAAM;gBACT,GAAG,EAAE,GAAG;gBACR,QAAQ,EAAE,QAAQ;aACnB,CAAC;YAEF,IAAI,CAAC,QAAQ,CAAC,IAAI,CAChB,MAAM,CAAC,SAAS,EAAE,EAClB,MAAM,CAAC,EAAE,EACT,MAAM,EACN,GAAG,CAAC,WAAW,CAChB,CAAC;YACF,MAAM,CAAC,IAAI,CAAC;gBACV,GAAG,MAAM;gBACT,GAAG,EAAE,GAAG;gBACR,QAAQ,EAAE,QAAQ;gBAClB,UAAU,EAAE,SAAS;aACtB,CAAC,CAAC;YACH,QAAQ,EAAE,CAAC;QACb,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,KAAK,CAAC,CAAC,IAAI,CACT,MAAc,EACd,UAAoB,EACpB,KAAe;QAEf,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC,CAAC;QAEzD,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAClC,CAAC,CAAC,IAAI,CAAC,OAAO,KAAK,CAAC,CAAC,IAAI,CAAC,OAAO;YAC/B,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ;YAC7C,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,OAAO;gBAC/B,CAAC,CAAC,CAAC,CAAC;gBACJ,CAAC,CAAC,CAAC,CACR,CAAC;QAEF,MAAM,KAAK,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QAExC,IAAI,OAAO,GAAG,CAAC,UAAU,CAAC;QAE1B,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,IAAI,UAAU,IAAI,IAAI,CAAC,IAAI,CAAC,EAAE,KAAK,UAAU,CAAC,SAAS,EAAE,EAAE,CAAC;gBAC1D,OAAO,GAAG,IAAI,CAAC;gBACf,SAAS;YACX,CAAC;YACD,IAAI,KAAK,IAAI,IAAI,CAAC,IAAI,CAAC,EAAE,KAAK,KAAK,CAAC,SAAS,EAAE,EAAE,CAAC;gBAChD,MAAM,EAAE,GAAG,IAAI,CAAC,IAAI,EAAE,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;gBACtD,MAAM;YACR,CAAC;YACD,IAAI,OAAO,EAAE,CAAC;gBACZ,MAAM,EAAE,GAAG,IAAI,CAAC,IAAI,EAAE,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YACxD,CAAC;QACH,CAAC;IACH,CAAC;CACF;AAtED,sEAsEC","sourcesContent":["import {\n LakeId,\n type ISerializedChange,\n type ISerializedFact,\n EventLakeStorageLayer,\n EventId,\n} from \"@ddd-ts/core\";\nimport { ISerializedSavedChange } from \"@ddd-ts/core/dist/interfaces/es-event\";\nimport { InMemoryDatabase, InMemoryTransaction } from \"@ddd-ts/store-inmemory\";\n\nexport class InMemoryEventLakeStorageLayer implements EventLakeStorageLayer {\n constructor(public readonly database: InMemoryDatabase) {}\n\n async append(\n lakeId: LakeId,\n changes: ISerializedChange[],\n trx: InMemoryTransaction,\n ) {\n const result: ISerializedSavedChange[] = [];\n\n let revision = 0;\n for (const change of changes) {\n const ref = `${lakeId.serialize()}/${change.id}`;\n\n const stored = {\n ...change,\n ref: ref,\n revision: revision,\n };\n\n this.database.save(\n lakeId.serialize(),\n change.id,\n stored,\n trx.transaction,\n );\n result.push({\n ...change,\n ref: ref,\n revision: revision,\n occurredAt: undefined,\n });\n revision++;\n }\n return result;\n }\n\n async *read(\n lakeId: LakeId,\n startAfter?: EventId,\n endAt?: EventId,\n ): AsyncIterable<ISerializedFact> {\n const events = this.database.loadAll(lakeId.serialize());\n\n const sorted = events.sort((a, b) =>\n a.data.savedAt === b.data.savedAt\n ? a.data.data.revision - b.data.data.revision\n : a.data.savedAt < b.data.savedAt\n ? -1\n : 1,\n );\n\n const facts = sorted.map((e) => e.data);\n\n let started = !startAfter;\n\n for (const fact of facts) {\n if (startAfter && fact.data.id === startAfter.serialize()) {\n started = true;\n continue;\n }\n if (endAt && fact.data.id === endAt.serialize()) {\n yield { ...fact.data, occurredAt: fact.data.savedAt };\n break;\n }\n if (started) {\n yield { ...fact.data, occurredAt: fact.data.savedAt };\n }\n }\n }\n}\n"]}
@@ -1,6 +0,0 @@
1
- import { IEsEvent, EventLakeStore, ISerializer } from "@ddd-ts/core";
2
- import type { InMemoryDatabase } from "@ddd-ts/store-inmemory";
3
- export declare class InMemoryEventLakeStore<Event extends IEsEvent> extends EventLakeStore<Event> {
4
- constructor(database: InMemoryDatabase, serializer: ISerializer<Event>);
5
- }
6
- //# sourceMappingURL=in-memory.event-lake.store.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.event-lake.store.d.ts","sourceRoot":"","sources":["../src/in-memory.event-lake.store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AACrE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAG/D,qBAAa,sBAAsB,CACjC,KAAK,SAAS,QAAQ,CACtB,SAAQ,cAAc,CAAC,KAAK,CAAC;gBACjB,QAAQ,EAAE,gBAAgB,EAAE,UAAU,EAAE,WAAW,CAAC,KAAK,CAAC;CAGvE"}
@@ -1,12 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.InMemoryEventLakeStore = void 0;
4
- const core_1 = require("@ddd-ts/core");
5
- const in_memory_event_lake_storage_layer_1 = require("./in-memory.event-lake.storage-layer");
6
- class InMemoryEventLakeStore extends core_1.EventLakeStore {
7
- constructor(database, serializer) {
8
- super(new in_memory_event_lake_storage_layer_1.InMemoryEventLakeStorageLayer(database), serializer);
9
- }
10
- }
11
- exports.InMemoryEventLakeStore = InMemoryEventLakeStore;
12
- //# sourceMappingURL=in-memory.event-lake.store.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.event-lake.store.js","sourceRoot":"","sources":["../src/in-memory.event-lake.store.ts"],"names":[],"mappings":";;;AAAA,uCAAqE;AAErE,6FAAqF;AAErF,MAAa,sBAEX,SAAQ,qBAAqB;IAC7B,YAAY,QAA0B,EAAE,UAA8B;QACpE,KAAK,CAAC,IAAI,kEAA6B,CAAC,QAAQ,CAAC,EAAE,UAAU,CAAC,CAAC;IACjE,CAAC;CACF;AAND,wDAMC","sourcesContent":["import { IEsEvent, EventLakeStore, ISerializer } from \"@ddd-ts/core\";\nimport type { InMemoryDatabase } from \"@ddd-ts/store-inmemory\";\nimport { InMemoryEventLakeStorageLayer } from \"./in-memory.event-lake.storage-layer\";\n\nexport class InMemoryEventLakeStore<\n Event extends IEsEvent,\n> extends EventLakeStore<Event> {\n constructor(database: InMemoryDatabase, serializer: ISerializer<Event>) {\n super(new InMemoryEventLakeStorageLayer(database), serializer);\n }\n}\n"]}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=in-memory.event-lake.store.spec.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.event-lake.store.spec.d.ts","sourceRoot":"","sources":["../src/in-memory.event-lake.store.spec.ts"],"names":[],"mappings":""}
@@ -1,14 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const store_inmemory_1 = require("@ddd-ts/store-inmemory");
4
- const core_1 = require("@ddd-ts/core");
5
- const in_memory_event_lake_storage_layer_1 = require("./in-memory.event-lake.storage-layer");
6
- describe("FirestoreEventLakeStore", () => {
7
- const database = new store_inmemory_1.InMemoryDatabase();
8
- const transaction = new store_inmemory_1.InMemoryTransactionPerformer(database);
9
- (0, core_1.EventLakeStoreSuite)({
10
- transaction: transaction,
11
- lakeStorageLayer: new in_memory_event_lake_storage_layer_1.InMemoryEventLakeStorageLayer(database),
12
- });
13
- });
14
- //# sourceMappingURL=in-memory.event-lake.store.spec.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.event-lake.store.spec.js","sourceRoot":"","sources":["../src/in-memory.event-lake.store.spec.ts"],"names":[],"mappings":";;AAAA,2DAGgC;AAEhC,uCAAmD;AACnD,6FAAqF;AAErF,QAAQ,CAAC,yBAAyB,EAAE,GAAG,EAAE;IACvC,MAAM,QAAQ,GAAG,IAAI,iCAAgB,EAAE,CAAC;IACxC,MAAM,WAAW,GAAG,IAAI,6CAA4B,CAAC,QAAQ,CAAC,CAAC;IAE/D,IAAA,0BAAmB,EAAC;QAClB,WAAW,EAAE,WAAW;QACxB,gBAAgB,EAAE,IAAI,kEAA6B,CAAC,QAAQ,CAAC;KAC9D,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import {\n InMemoryDatabase,\n InMemoryTransactionPerformer,\n} from \"@ddd-ts/store-inmemory\";\n\nimport { EventLakeStoreSuite } from \"@ddd-ts/core\";\nimport { InMemoryEventLakeStorageLayer } from \"./in-memory.event-lake.storage-layer\";\n\ndescribe(\"FirestoreEventLakeStore\", () => {\n const database = new InMemoryDatabase();\n const transaction = new InMemoryTransactionPerformer(database);\n\n EventLakeStoreSuite({\n transaction: transaction,\n lakeStorageLayer: new InMemoryEventLakeStorageLayer(database),\n });\n});\n"]}
@@ -1,30 +0,0 @@
1
- import { HasTrait } from "@ddd-ts/traits";
2
- import { StreamId, EventsOf, EventSourced, type Identifiable, type IEventBus, EventStreamStore, EventStreamAggregateStore, EventOf, ISerializer, IEventSourced, IIdentifiable } from "@ddd-ts/core";
3
- import { InMemoryDatabase } from "@ddd-ts/store-inmemory";
4
- import { InMemorySnapshotter } from "./in-memory.snapshotter";
5
- export declare const MakeInMemoryEventStreamAggregateStore: <A extends HasTrait<typeof EventSourced> & HasTrait<typeof Identifiable>>(AGGREGATE: A) => {
6
- new (database: InMemoryDatabase, serializer: ISerializer<InstanceType<A>> & ISerializer<EventOf<InstanceType<A>>>, eventBus?: IEventBus): {
7
- loadFirst(event: EventsOf<A>[number]): InstanceType<A>;
8
- getStreamId(id: InstanceType<A>["id"]): StreamId;
9
- readonly database: InMemoryDatabase;
10
- readonly serializer: ISerializer<EventOf<InstanceType<A>>, {}>;
11
- readonly snapshotter: InMemorySnapshotter<InstanceType<A>>;
12
- readonly eventBus?: IEventBus | undefined;
13
- readonly streamStore: EventStreamStore<EventOf<InstanceType<A>>>;
14
- readonly transaction: import("@ddd-ts/core").TransactionPerformer;
15
- loadFromSnapshot(snapshot: InstanceType<A>): Promise<InstanceType<A>>;
16
- loadFromScratch(id: InstanceType<A>["id"]): Promise<InstanceType<A> | undefined>;
17
- loadForce(id: InstanceType<A>["id"]): Promise<InstanceType<A> | undefined>;
18
- load(id: InstanceType<A>["id"]): Promise<InstanceType<A> | undefined>;
19
- saveAll(aggregates: InstanceType<A>[], parentTrx?: import("@ddd-ts/core").Transaction, attempts?: number): Promise<void>;
20
- save(aggregate: InstanceType<A>, trx?: import("@ddd-ts/core").Transaction, attempts?: number): Promise<void>;
21
- };
22
- };
23
- export declare abstract class InMemoryEventStreamAggregateStore<A extends IEventSourced & IIdentifiable> extends EventStreamAggregateStore<A> {
24
- readonly database: InMemoryDatabase;
25
- readonly serializer: ISerializer<EventOf<A>>;
26
- readonly snapshotter: InMemorySnapshotter<A>;
27
- readonly eventBus?: IEventBus | undefined;
28
- constructor(database: InMemoryDatabase, serializer: ISerializer<EventOf<A>>, snapshotter: InMemorySnapshotter<A>, eventBus?: IEventBus | undefined);
29
- }
30
- //# sourceMappingURL=in-memory.event-stream.aggregate-store.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.event-stream.aggregate-store.d.ts","sourceRoot":"","sources":["../src/in-memory.event-stream.aggregate-store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EACL,QAAQ,EACR,QAAQ,EACR,YAAY,EACZ,KAAK,YAAY,EACjB,KAAK,SAAS,EACd,gBAAgB,EAChB,yBAAyB,EAEzB,OAAO,EACP,WAAW,EACX,aAAa,EACb,aAAa,EACd,MAAM,cAAc,CAAC;AACtB,OAAO,EACL,gBAAgB,EAEjB,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAG9D,eAAO,MAAM,qCAAqC,GAChD,CAAC,SAAS,QAAQ,CAAC,OAAO,YAAY,CAAC,GAAG,QAAQ,CAAC,OAAO,YAAY,CAAC,aAE5D,CAAC;mBAME,gBAAgB,cACd,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,GACtC,WAAW,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,aAC5B,SAAS;yBAUL,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,YAAY,CAAC,CAAC,CAAC;wBAItC,YAAY,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,QAAQ;2BAUtB,gBAAgB;;;4BAGf,SAAS;;;;;;;;;;CATvC,CAAC;AAEF,8BAAsB,iCAAiC,CACrD,CAAC,SAAS,aAAa,GAAG,aAAa,CACvC,SAAQ,yBAAyB,CAAC,CAAC,CAAC;aAElB,QAAQ,EAAE,gBAAgB;aAC1B,UAAU,EAAE,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;aACnC,WAAW,EAAE,mBAAmB,CAAC,CAAC,CAAC;aACnC,QAAQ,CAAC,EAAE,SAAS;gBAHpB,QAAQ,EAAE,gBAAgB,EAC1B,UAAU,EAAE,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EACnC,WAAW,EAAE,mBAAmB,CAAC,CAAC,CAAC,EACnC,QAAQ,CAAC,EAAE,SAAS,YAAA;CAWvC"}
@@ -1,40 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.InMemoryEventStreamAggregateStore = exports.MakeInMemoryEventStreamAggregateStore = void 0;
4
- const core_1 = require("@ddd-ts/core");
5
- const store_inmemory_1 = require("@ddd-ts/store-inmemory");
6
- const in_memory_snapshotter_1 = require("./in-memory.snapshotter");
7
- const in_memory_event_stream_storage_layer_1 = require("./in-memory.event-stream.storage-layer");
8
- const MakeInMemoryEventStreamAggregateStore = (AGGREGATE) => {
9
- return class $InMemoryEventStreamAggregateStore extends InMemoryEventStreamAggregateStore {
10
- constructor(database, serializer, eventBus) {
11
- const snapshotter = new in_memory_snapshotter_1.InMemorySnapshotter(AGGREGATE.name, database, serializer);
12
- super(database, serializer, snapshotter, eventBus);
13
- }
14
- loadFirst(event) {
15
- return AGGREGATE.loadFirst(event);
16
- }
17
- getStreamId(id) {
18
- return core_1.StreamId.from(AGGREGATE.name, id.serialize());
19
- }
20
- };
21
- };
22
- exports.MakeInMemoryEventStreamAggregateStore = MakeInMemoryEventStreamAggregateStore;
23
- class InMemoryEventStreamAggregateStore extends core_1.EventStreamAggregateStore {
24
- database;
25
- serializer;
26
- snapshotter;
27
- eventBus;
28
- constructor(database, serializer, snapshotter, eventBus) {
29
- const storageLayer = new in_memory_event_stream_storage_layer_1.InMemoryEventStreamStorageLayer(database);
30
- const transaction = new store_inmemory_1.InMemoryTransactionPerformer(database);
31
- const streamStore = new core_1.EventStreamStore(storageLayer, serializer, eventBus);
32
- super(streamStore, transaction, snapshotter);
33
- this.database = database;
34
- this.serializer = serializer;
35
- this.snapshotter = snapshotter;
36
- this.eventBus = eventBus;
37
- }
38
- }
39
- exports.InMemoryEventStreamAggregateStore = InMemoryEventStreamAggregateStore;
40
- //# sourceMappingURL=in-memory.event-stream.aggregate-store.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.event-stream.aggregate-store.js","sourceRoot":"","sources":["../src/in-memory.event-stream.aggregate-store.ts"],"names":[],"mappings":";;;AACA,uCAasB;AACtB,2DAGgC;AAChC,mEAA8D;AAC9D,iGAAyF;AAElF,MAAM,qCAAqC,GAAG,CAGnD,SAAY,EACZ,EAAE;IACF,OAAO,MAAM,kCAAmC,SAAQ,iCAEvD;QACC,YACE,QAA0B,EAC1B,UACuC,EACvC,QAAoB;YAEpB,MAAM,WAAW,GAAG,IAAI,2CAAmB,CACzC,SAAS,CAAC,IAAI,EACd,QAAQ,EACR,UAAU,CACX,CAAC;YACF,KAAK,CAAC,QAAQ,EAAE,UAAU,EAAE,WAAW,EAAE,QAAQ,CAAC,CAAC;QACrD,CAAC;QAED,SAAS,CAAC,KAA0B;YAClC,OAAO,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACpC,CAAC;QAED,WAAW,CAAC,EAAyB;YACnC,OAAO,eAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,EAAE,CAAC,SAAS,EAAE,CAAC,CAAC;QACvD,CAAC;KACF,CAAC;AACJ,CAAC,CAAC;AA9BW,QAAA,qCAAqC,yCA8BhD;AAEF,MAAsB,iCAEpB,SAAQ,gCAA4B;IAElB;IACA;IACA;IACA;IAJlB,YACkB,QAA0B,EAC1B,UAAmC,EACnC,WAAmC,EACnC,QAAoB;QAEpC,MAAM,YAAY,GAAG,IAAI,sEAA+B,CAAC,QAAQ,CAAC,CAAC;QACnE,MAAM,WAAW,GAAG,IAAI,6CAA4B,CAAC,QAAQ,CAAC,CAAC;QAC/D,MAAM,WAAW,GAAG,IAAI,uBAAgB,CACtC,YAAY,EACZ,UAAU,EACV,QAAQ,CACT,CAAC;QACF,KAAK,CAAC,WAAW,EAAE,WAAW,EAAE,WAAW,CAAC,CAAC;QAZ7B,aAAQ,GAAR,QAAQ,CAAkB;QAC1B,eAAU,GAAV,UAAU,CAAyB;QACnC,gBAAW,GAAX,WAAW,CAAwB;QACnC,aAAQ,GAAR,QAAQ,CAAY;IAUtC,CAAC;CACF;AAlBD,8EAkBC","sourcesContent":["import { HasTrait } from \"@ddd-ts/traits\";\nimport {\n StreamId,\n EventsOf,\n EventSourced,\n type Identifiable,\n type IEventBus,\n EventStreamStore,\n EventStreamAggregateStore,\n Named,\n EventOf,\n ISerializer,\n IEventSourced,\n IIdentifiable,\n} from \"@ddd-ts/core\";\nimport {\n InMemoryDatabase,\n InMemoryTransactionPerformer,\n} from \"@ddd-ts/store-inmemory\";\nimport { InMemorySnapshotter } from \"./in-memory.snapshotter\";\nimport { InMemoryEventStreamStorageLayer } from \"./in-memory.event-stream.storage-layer\";\n\nexport const MakeInMemoryEventStreamAggregateStore = <\n A extends HasTrait<typeof EventSourced> & HasTrait<typeof Identifiable>,\n>(\n AGGREGATE: A,\n) => {\n return class $InMemoryEventStreamAggregateStore extends InMemoryEventStreamAggregateStore<\n InstanceType<A>\n > {\n constructor(\n database: InMemoryDatabase,\n serializer: ISerializer<InstanceType<A>> &\n ISerializer<EventOf<InstanceType<A>>>,\n eventBus?: IEventBus,\n ) {\n const snapshotter = new InMemorySnapshotter<InstanceType<A>>(\n AGGREGATE.name,\n database,\n serializer,\n );\n super(database, serializer, snapshotter, eventBus);\n }\n\n loadFirst(event: EventsOf<A>[number]): InstanceType<A> {\n return AGGREGATE.loadFirst(event);\n }\n\n getStreamId(id: InstanceType<A>[\"id\"]): StreamId {\n return StreamId.from(AGGREGATE.name, id.serialize());\n }\n };\n};\n\nexport abstract class InMemoryEventStreamAggregateStore<\n A extends IEventSourced & IIdentifiable,\n> extends EventStreamAggregateStore<A> {\n constructor(\n public readonly database: InMemoryDatabase,\n public readonly serializer: ISerializer<EventOf<A>>,\n public readonly snapshotter: InMemorySnapshotter<A>,\n public readonly eventBus?: IEventBus,\n ) {\n const storageLayer = new InMemoryEventStreamStorageLayer(database);\n const transaction = new InMemoryTransactionPerformer(database);\n const streamStore = new EventStreamStore<EventOf<A>>(\n storageLayer,\n serializer,\n eventBus,\n );\n super(streamStore, transaction, snapshotter);\n }\n}\n"]}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=in-memory.event-stream.aggregate-store.spec.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.event-stream.aggregate-store.spec.d.ts","sourceRoot":"","sources":["../src/in-memory.event-stream.aggregate-store.spec.ts"],"names":[],"mappings":""}
@@ -1,17 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const core_1 = require("@ddd-ts/core");
4
- const store_inmemory_1 = require("@ddd-ts/store-inmemory");
5
- const in_memory_event_stream_aggregate_store_1 = require("./in-memory.event-stream.aggregate-store");
6
- describe("InMemoryEventStreamAggregateStore", () => {
7
- const database = new store_inmemory_1.InMemoryDatabase();
8
- (0, core_1.EventStreamAggregateStoreSuite)({
9
- transaction: new store_inmemory_1.InMemoryTransactionPerformer(database),
10
- getAggregateStore: (AGGREGATE, serializer, eventBus) => {
11
- const Store = (0, in_memory_event_stream_aggregate_store_1.MakeInMemoryEventStreamAggregateStore)(AGGREGATE);
12
- return new Store(database, serializer, eventBus);
13
- },
14
- getStore: (name, serializer) => new store_inmemory_1.InMemoryStore(name, database, serializer),
15
- });
16
- });
17
- //# sourceMappingURL=in-memory.event-stream.aggregate-store.spec.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.event-stream.aggregate-store.spec.js","sourceRoot":"","sources":["../src/in-memory.event-stream.aggregate-store.spec.ts"],"names":[],"mappings":";;AAAA,uCAA8D;AAC9D,2DAIgC;AAChC,qGAAiG;AAEjG,QAAQ,CAAC,mCAAmC,EAAE,GAAG,EAAE;IACjD,MAAM,QAAQ,GAAG,IAAI,iCAAgB,EAAE,CAAC;IAExC,IAAA,qCAA8B,EAAC;QAC7B,WAAW,EAAE,IAAI,6CAA4B,CAAC,QAAQ,CAAC;QACvD,iBAAiB,EAAE,CAAC,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,EAAE;YACrD,MAAM,KAAK,GAAG,IAAA,8EAAqC,EAAC,SAAS,CAAC,CAAC;YAC/D,OAAO,IAAI,KAAK,CAAC,QAAQ,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;QACnD,CAAC;QACD,QAAQ,EAAE,CAAC,IAAI,EAAE,UAAU,EAAE,EAAE,CAC7B,IAAI,8BAAa,CAAC,IAAI,EAAE,QAAQ,EAAE,UAAU,CAAC;KAChD,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import { EventStreamAggregateStoreSuite } from \"@ddd-ts/core\";\nimport {\n InMemoryDatabase,\n InMemoryStore,\n InMemoryTransactionPerformer,\n} from \"@ddd-ts/store-inmemory\";\nimport { MakeInMemoryEventStreamAggregateStore } from \"./in-memory.event-stream.aggregate-store\";\n\ndescribe(\"InMemoryEventStreamAggregateStore\", () => {\n const database = new InMemoryDatabase();\n\n EventStreamAggregateStoreSuite({\n transaction: new InMemoryTransactionPerformer(database),\n getAggregateStore: (AGGREGATE, serializer, eventBus) => {\n const Store = MakeInMemoryEventStreamAggregateStore(AGGREGATE);\n return new Store(database, serializer, eventBus);\n },\n getStore: (name, serializer) =>\n new InMemoryStore(name, database, serializer),\n });\n});\n"]}
@@ -1,11 +0,0 @@
1
- import { StreamId, type ISerializedChange, type ISerializedFact, EventStreamStorageLayer } from "@ddd-ts/core";
2
- import { ISerializedSavedChange } from "@ddd-ts/core/dist/interfaces/es-event";
3
- import { InMemoryDatabase, InMemoryTransaction } from "@ddd-ts/store-inmemory";
4
- export declare class InMemoryEventStreamStorageLayer implements EventStreamStorageLayer {
5
- readonly database: InMemoryDatabase;
6
- constructor(database: InMemoryDatabase);
7
- isLocalRevisionOutdatedError(error: unknown): boolean;
8
- append(streamId: StreamId, changes: ISerializedChange[], expectedRevision: number, trx: InMemoryTransaction): Promise<ISerializedSavedChange[]>;
9
- read(streamId: StreamId, from?: number): AsyncIterable<ISerializedFact>;
10
- }
11
- //# sourceMappingURL=in-memory.event-stream.storage-layer.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.event-stream.storage-layer.d.ts","sourceRoot":"","sources":["../src/in-memory.event-stream.storage-layer.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EACR,KAAK,iBAAiB,EACtB,KAAK,eAAe,EACpB,uBAAuB,EAExB,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,sBAAsB,EAAE,MAAM,uCAAuC,CAAC;AAC/E,OAAO,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAE/E,qBAAa,+BACX,YAAW,uBAAuB;aAEN,QAAQ,EAAE,gBAAgB;gBAA1B,QAAQ,EAAE,gBAAgB;IAEtD,4BAA4B,CAAC,KAAK,EAAE,OAAO,GAAG,OAAO;IAI/C,MAAM,CACV,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,iBAAiB,EAAE,EAC5B,gBAAgB,EAAE,MAAM,EACxB,GAAG,EAAE,mBAAmB;IAkCnB,IAAI,CACT,QAAQ,EAAE,QAAQ,EAClB,IAAI,CAAC,EAAE,MAAM,GACZ,aAAa,CAAC,eAAe,CAAC;CAclC"}
@@ -1,45 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.InMemoryEventStreamStorageLayer = void 0;
4
- const core_1 = require("@ddd-ts/core");
5
- class InMemoryEventStreamStorageLayer {
6
- database;
7
- constructor(database) {
8
- this.database = database;
9
- }
10
- isLocalRevisionOutdatedError(error) {
11
- return error instanceof core_1.ConcurrencyError;
12
- }
13
- async append(streamId, changes, expectedRevision, trx) {
14
- const result = [];
15
- let revision = expectedRevision + 1;
16
- for (const change of changes) {
17
- const ref = `${streamId.serialize()}/${revision}`;
18
- const stored = {
19
- ...change,
20
- ref: ref,
21
- revision: revision,
22
- };
23
- this.database.create(streamId.serialize(), `${revision}`, stored, trx.transaction);
24
- result.push({
25
- ...change,
26
- ref: ref,
27
- revision: revision,
28
- occurredAt: undefined,
29
- });
30
- revision++;
31
- }
32
- return result;
33
- }
34
- async *read(streamId, from) {
35
- const events = this.database.loadAll(streamId.serialize());
36
- const sorted = events.sort((a, b) => a.data.data.revision - b.data.data.revision);
37
- const facts = sorted.map((e) => ({
38
- ...e.data.data,
39
- occurredAt: e.data.savedAt,
40
- }));
41
- yield* facts.slice(from !== undefined ? from : 0);
42
- }
43
- }
44
- exports.InMemoryEventStreamStorageLayer = InMemoryEventStreamStorageLayer;
45
- //# sourceMappingURL=in-memory.event-stream.storage-layer.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.event-stream.storage-layer.js","sourceRoot":"","sources":["../src/in-memory.event-stream.storage-layer.ts"],"names":[],"mappings":";;;AAAA,uCAMsB;AAItB,MAAa,+BAA+B;IAGd;IAA5B,YAA4B,QAA0B;QAA1B,aAAQ,GAAR,QAAQ,CAAkB;IAAG,CAAC;IAE1D,4BAA4B,CAAC,KAAc;QACzC,OAAO,KAAK,YAAY,uBAAgB,CAAC;IAC3C,CAAC;IAED,KAAK,CAAC,MAAM,CACV,QAAkB,EAClB,OAA4B,EAC5B,gBAAwB,EACxB,GAAwB;QAExB,MAAM,MAAM,GAA6B,EAAE,CAAC;QAE5C,IAAI,QAAQ,GAAG,gBAAgB,GAAG,CAAC,CAAC;QAEpC,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC7B,MAAM,GAAG,GAAG,GAAG,QAAQ,CAAC,SAAS,EAAE,IAAI,QAAQ,EAAE,CAAC;YAElD,MAAM,MAAM,GAAG;gBACb,GAAG,MAAM;gBACT,GAAG,EAAE,GAAG;gBACR,QAAQ,EAAE,QAAQ;aACnB,CAAC;YAEF,IAAI,CAAC,QAAQ,CAAC,MAAM,CAClB,QAAQ,CAAC,SAAS,EAAE,EACpB,GAAG,QAAQ,EAAE,EACb,MAAM,EACN,GAAG,CAAC,WAAW,CAChB,CAAC;YAEF,MAAM,CAAC,IAAI,CAAC;gBACV,GAAG,MAAM;gBACT,GAAG,EAAE,GAAG;gBACR,QAAQ,EAAE,QAAQ;gBAClB,UAAU,EAAE,SAAS;aACtB,CAAC,CAAC;YAEH,QAAQ,EAAE,CAAC;QACb,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,KAAK,CAAC,CAAC,IAAI,CACT,QAAkB,EAClB,IAAa;QAEb,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC,CAAC;QAE3D,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CACxB,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CACtD,CAAC;QAEF,MAAM,KAAK,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YAC/B,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI;YACd,UAAU,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO;SAC3B,CAAC,CAAC,CAAC;QAEJ,KAAK,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACpD,CAAC;CACF;AAhED,0EAgEC","sourcesContent":["import {\n StreamId,\n type ISerializedChange,\n type ISerializedFact,\n EventStreamStorageLayer,\n ConcurrencyError,\n} from \"@ddd-ts/core\";\nimport { ISerializedSavedChange } from \"@ddd-ts/core/dist/interfaces/es-event\";\nimport { InMemoryDatabase, InMemoryTransaction } from \"@ddd-ts/store-inmemory\";\n\nexport class InMemoryEventStreamStorageLayer\n implements EventStreamStorageLayer\n{\n constructor(public readonly database: InMemoryDatabase) {}\n\n isLocalRevisionOutdatedError(error: unknown): boolean {\n return error instanceof ConcurrencyError;\n }\n\n async append(\n streamId: StreamId,\n changes: ISerializedChange[],\n expectedRevision: number,\n trx: InMemoryTransaction,\n ) {\n const result: ISerializedSavedChange[] = [];\n\n let revision = expectedRevision + 1;\n\n for (const change of changes) {\n const ref = `${streamId.serialize()}/${revision}`;\n\n const stored = {\n ...change,\n ref: ref,\n revision: revision,\n };\n\n this.database.create(\n streamId.serialize(),\n `${revision}`,\n stored,\n trx.transaction,\n );\n\n result.push({\n ...change,\n ref: ref,\n revision: revision,\n occurredAt: undefined,\n });\n\n revision++;\n }\n return result;\n }\n\n async *read(\n streamId: StreamId,\n from?: number,\n ): AsyncIterable<ISerializedFact> {\n const events = this.database.loadAll(streamId.serialize());\n\n const sorted = events.sort(\n (a, b) => a.data.data.revision - b.data.data.revision,\n );\n\n const facts = sorted.map((e) => ({\n ...e.data.data,\n occurredAt: e.data.savedAt,\n }));\n\n yield* facts.slice(from !== undefined ? from : 0);\n }\n}\n"]}
@@ -1,6 +0,0 @@
1
- import { EventStreamStore, IEsEvent, ISerializer } from "@ddd-ts/core";
2
- import type { InMemoryDatabase } from "@ddd-ts/store-inmemory";
3
- export declare class InMemoryEventStreamStore<Event extends IEsEvent> extends EventStreamStore<Event> {
4
- constructor(database: InMemoryDatabase, serializer: ISerializer<Event>);
5
- }
6
- //# sourceMappingURL=in-memory.event-stream.store.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.event-stream.store.d.ts","sourceRoot":"","sources":["../src/in-memory.event-stream.store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,QAAQ,EAAU,WAAW,EAAE,MAAM,cAAc,CAAC;AAC/E,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAG/D,qBAAa,wBAAwB,CACnC,KAAK,SAAS,QAAQ,CACtB,SAAQ,gBAAgB,CAAC,KAAK,CAAC;gBACnB,QAAQ,EAAE,gBAAgB,EAAE,UAAU,EAAE,WAAW,CAAC,KAAK,CAAC;CAGvE"}
@@ -1,12 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.InMemoryEventStreamStore = void 0;
4
- const core_1 = require("@ddd-ts/core");
5
- const in_memory_event_stream_storage_layer_1 = require("./in-memory.event-stream.storage-layer");
6
- class InMemoryEventStreamStore extends core_1.EventStreamStore {
7
- constructor(database, serializer) {
8
- super(new in_memory_event_stream_storage_layer_1.InMemoryEventStreamStorageLayer(database), serializer);
9
- }
10
- }
11
- exports.InMemoryEventStreamStore = InMemoryEventStreamStore;
12
- //# sourceMappingURL=in-memory.event-stream.store.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.event-stream.store.js","sourceRoot":"","sources":["../src/in-memory.event-stream.store.ts"],"names":[],"mappings":";;;AAAA,uCAA+E;AAE/E,iGAAyF;AAEzF,MAAa,wBAEX,SAAQ,uBAAuB;IAC/B,YAAY,QAA0B,EAAE,UAA8B;QACpE,KAAK,CAAC,IAAI,sEAA+B,CAAC,QAAQ,CAAC,EAAE,UAAU,CAAC,CAAC;IACnE,CAAC;CACF;AAND,4DAMC","sourcesContent":["import { EventStreamStore, IEsEvent, INamed, ISerializer } from \"@ddd-ts/core\";\nimport type { InMemoryDatabase } from \"@ddd-ts/store-inmemory\";\nimport { InMemoryEventStreamStorageLayer } from \"./in-memory.event-stream.storage-layer\";\n\nexport class InMemoryEventStreamStore<\n Event extends IEsEvent,\n> extends EventStreamStore<Event> {\n constructor(database: InMemoryDatabase, serializer: ISerializer<Event>) {\n super(new InMemoryEventStreamStorageLayer(database), serializer);\n }\n}\n"]}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=in-memory.event-stream.store.spec.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.event-stream.store.spec.d.ts","sourceRoot":"","sources":["../src/in-memory.event-stream.store.spec.ts"],"names":[],"mappings":""}
@@ -1,14 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const store_inmemory_1 = require("@ddd-ts/store-inmemory");
4
- const core_1 = require("@ddd-ts/core");
5
- const in_memory_event_stream_storage_layer_1 = require("./in-memory.event-stream.storage-layer");
6
- describe("FirestoreEventStreamStore", () => {
7
- const database = new store_inmemory_1.InMemoryDatabase();
8
- const transaction = new store_inmemory_1.InMemoryTransactionPerformer(database);
9
- (0, core_1.EventStreamStoreSuite)({
10
- transaction: transaction,
11
- streamStorageLayer: new in_memory_event_stream_storage_layer_1.InMemoryEventStreamStorageLayer(database),
12
- });
13
- });
14
- //# sourceMappingURL=in-memory.event-stream.store.spec.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.event-stream.store.spec.js","sourceRoot":"","sources":["../src/in-memory.event-stream.store.spec.ts"],"names":[],"mappings":";;AAAA,2DAGgC;AAEhC,uCAAqD;AACrD,iGAAyF;AAEzF,QAAQ,CAAC,2BAA2B,EAAE,GAAG,EAAE;IACzC,MAAM,QAAQ,GAAG,IAAI,iCAAgB,EAAE,CAAC;IACxC,MAAM,WAAW,GAAG,IAAI,6CAA4B,CAAC,QAAQ,CAAC,CAAC;IAE/D,IAAA,4BAAqB,EAAC;QACpB,WAAW,EAAE,WAAW;QACxB,kBAAkB,EAAE,IAAI,sEAA+B,CAAC,QAAQ,CAAC;KAClE,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import {\n InMemoryDatabase,\n InMemoryTransactionPerformer,\n} from \"@ddd-ts/store-inmemory\";\n\nimport { EventStreamStoreSuite } from \"@ddd-ts/core\";\nimport { InMemoryEventStreamStorageLayer } from \"./in-memory.event-stream.storage-layer\";\n\ndescribe(\"FirestoreEventStreamStore\", () => {\n const database = new InMemoryDatabase();\n const transaction = new InMemoryTransactionPerformer(database);\n\n EventStreamStoreSuite({\n transaction: transaction,\n streamStorageLayer: new InMemoryEventStreamStorageLayer(database),\n });\n});\n"]}
@@ -1,6 +0,0 @@
1
- import { IEsEvent, ISerializer, ProjectedStreamReader } from "@ddd-ts/core";
2
- import { InMemoryDatabase } from "@ddd-ts/store-inmemory";
3
- export declare class InMemoryProjectedStreamReader<Events extends IEsEvent> extends ProjectedStreamReader<Events> {
4
- constructor(database: InMemoryDatabase, serializer: ISerializer<Events>);
5
- }
6
- //# sourceMappingURL=in-memory.projected-stream.reader.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.projected-stream.reader.d.ts","sourceRoot":"","sources":["../src/in-memory.projected-stream.reader.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAC;AAC5E,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAG1D,qBAAa,6BAA6B,CACxC,MAAM,SAAS,QAAQ,CACvB,SAAQ,qBAAqB,CAAC,MAAM,CAAC;gBACzB,QAAQ,EAAE,gBAAgB,EAAE,UAAU,EAAE,WAAW,CAAC,MAAM,CAAC;CAGxE"}
@@ -1,12 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.InMemoryProjectedStreamReader = void 0;
4
- const core_1 = require("@ddd-ts/core");
5
- const in_memory_projected_stream_storage_layer_1 = require("./in-memory.projected-stream.storage-layer");
6
- class InMemoryProjectedStreamReader extends core_1.ProjectedStreamReader {
7
- constructor(database, serializer) {
8
- super(new in_memory_projected_stream_storage_layer_1.InMemoryProjectedStreamStorageLayer(database), serializer);
9
- }
10
- }
11
- exports.InMemoryProjectedStreamReader = InMemoryProjectedStreamReader;
12
- //# sourceMappingURL=in-memory.projected-stream.reader.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.projected-stream.reader.js","sourceRoot":"","sources":["../src/in-memory.projected-stream.reader.ts"],"names":[],"mappings":";;;AAAA,uCAA4E;AAE5E,yGAAiG;AAEjG,MAAa,6BAEX,SAAQ,4BAA6B;IACrC,YAAY,QAA0B,EAAE,UAA+B;QACrE,KAAK,CAAC,IAAI,8EAAmC,CAAC,QAAQ,CAAC,EAAE,UAAU,CAAC,CAAC;IACvE,CAAC;CACF;AAND,sEAMC","sourcesContent":["import { IEsEvent, ISerializer, ProjectedStreamReader } from \"@ddd-ts/core\";\nimport { InMemoryDatabase } from \"@ddd-ts/store-inmemory\";\nimport { InMemoryProjectedStreamStorageLayer } from \"./in-memory.projected-stream.storage-layer\";\n\nexport class InMemoryProjectedStreamReader<\n Events extends IEsEvent,\n> extends ProjectedStreamReader<Events> {\n constructor(database: InMemoryDatabase, serializer: ISerializer<Events>) {\n super(new InMemoryProjectedStreamStorageLayer(database), serializer);\n }\n}\n"]}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=in-memory.projected-stream.reader.spec.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.projected-stream.reader.spec.d.ts","sourceRoot":"","sources":["../src/in-memory.projected-stream.reader.spec.ts"],"names":[],"mappings":""}
@@ -1,17 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const core_1 = require("@ddd-ts/core");
4
- const store_inmemory_1 = require("@ddd-ts/store-inmemory");
5
- const in_memory_event_lake_storage_layer_1 = require("./in-memory.event-lake.storage-layer");
6
- const in_memory_event_stream_storage_layer_1 = require("./in-memory.event-stream.storage-layer");
7
- const in_memory_projected_stream_storage_layer_1 = require("./in-memory.projected-stream.storage-layer");
8
- describe("InMemoryProjectedStreamReader", () => {
9
- const database = new store_inmemory_1.InMemoryDatabase();
10
- (0, core_1.ProjectedStreamReaderSuite)({
11
- transaction: new store_inmemory_1.InMemoryTransactionPerformer(database),
12
- lakeStorageLayer: new in_memory_event_lake_storage_layer_1.InMemoryEventLakeStorageLayer(database),
13
- streamStorageLayer: new in_memory_event_stream_storage_layer_1.InMemoryEventStreamStorageLayer(database),
14
- readerStorageLayer: new in_memory_projected_stream_storage_layer_1.InMemoryProjectedStreamStorageLayer(database),
15
- });
16
- });
17
- //# sourceMappingURL=in-memory.projected-stream.reader.spec.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.projected-stream.reader.spec.js","sourceRoot":"","sources":["../src/in-memory.projected-stream.reader.spec.ts"],"names":[],"mappings":";;AAAA,uCAA0D;AAC1D,2DAGgC;AAEhC,6FAAqF;AACrF,iGAAyF;AACzF,yGAAiG;AAEjG,QAAQ,CAAC,+BAA+B,EAAE,GAAG,EAAE;IAC7C,MAAM,QAAQ,GAAG,IAAI,iCAAgB,EAAE,CAAC;IAExC,IAAA,iCAA0B,EAAC;QACzB,WAAW,EAAE,IAAI,6CAA4B,CAAC,QAAQ,CAAC;QACvD,gBAAgB,EAAE,IAAI,kEAA6B,CAAC,QAAQ,CAAC;QAC7D,kBAAkB,EAAE,IAAI,sEAA+B,CAAC,QAAQ,CAAC;QACjE,kBAAkB,EAAE,IAAI,8EAAmC,CAAC,QAAQ,CAAC;KACtE,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import { ProjectedStreamReaderSuite } from \"@ddd-ts/core\";\nimport {\n InMemoryDatabase,\n InMemoryTransactionPerformer,\n} from \"@ddd-ts/store-inmemory\";\n\nimport { InMemoryEventLakeStorageLayer } from \"./in-memory.event-lake.storage-layer\";\nimport { InMemoryEventStreamStorageLayer } from \"./in-memory.event-stream.storage-layer\";\nimport { InMemoryProjectedStreamStorageLayer } from \"./in-memory.projected-stream.storage-layer\";\n\ndescribe(\"InMemoryProjectedStreamReader\", () => {\n const database = new InMemoryDatabase();\n\n ProjectedStreamReaderSuite({\n transaction: new InMemoryTransactionPerformer(database),\n lakeStorageLayer: new InMemoryEventLakeStorageLayer(database),\n streamStorageLayer: new InMemoryEventStreamStorageLayer(database),\n readerStorageLayer: new InMemoryProjectedStreamStorageLayer(database),\n });\n});\n"]}
@@ -1,27 +0,0 @@
1
- import { ISerializedFact, LakeSource, ProjectedStream, ProjectedStreamStorageLayer, StreamSource, Cursor, ISerializedSavedChange } from "@ddd-ts/core";
2
- import { InMemoryDatabase } from "@ddd-ts/store-inmemory";
3
- export declare class InMemoryStreamSourceFilter {
4
- private readonly database;
5
- constructor(database: InMemoryDatabase);
6
- all(source: StreamSource, shard: string): Generator<{
7
- savedAt: bigint;
8
- data: any;
9
- }, void, unknown>;
10
- }
11
- export declare class InMemoryLakeSourceFilter {
12
- private readonly database;
13
- constructor(database: InMemoryDatabase);
14
- all(source: LakeSource, shard: string): Generator<{
15
- savedAt: bigint;
16
- data: any;
17
- }, void, unknown>;
18
- }
19
- export declare class InMemoryProjectedStreamStorageLayer implements ProjectedStreamStorageLayer {
20
- private readonly database;
21
- constructor(database: InMemoryDatabase);
22
- getCursor(savedChange: ISerializedSavedChange): Promise<Cursor | undefined>;
23
- get(cursor: Cursor): Promise<ISerializedFact | undefined>;
24
- read(projectedStream: ProjectedStream, shard: string, startAfter?: Cursor, endAt?: Cursor): AsyncGenerator<any, void, unknown>;
25
- slice(projectedStream: ProjectedStream, shard: string, startAfter?: Cursor, endAt?: Cursor, count?: number): Promise<ISerializedFact[]>;
26
- }
27
- //# sourceMappingURL=in-memory.projected-stream.storage-layer.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.projected-stream.storage-layer.d.ts","sourceRoot":"","sources":["../src/in-memory.projected-stream.storage-layer.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,eAAe,EAEf,UAAU,EACV,eAAe,EACf,2BAA2B,EAC3B,YAAY,EACZ,MAAM,EACN,sBAAsB,EACvB,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAG1D,qBAAa,0BAA0B;IACzB,OAAO,CAAC,QAAQ,CAAC,QAAQ;gBAAR,QAAQ,EAAE,gBAAgB;IAEtD,GAAG,CAAC,MAAM,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM;;;;CAezC;AAED,qBAAa,wBAAwB;IACvB,OAAO,CAAC,QAAQ,CAAC,QAAQ;gBAAR,QAAQ,EAAE,gBAAgB;IAEtD,GAAG,CAAC,MAAM,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM;;;;CAYvC;AAED,qBAAa,mCACX,YAAW,2BAA2B;IAE1B,OAAO,CAAC,QAAQ,CAAC,QAAQ;gBAAR,QAAQ,EAAE,gBAAgB;IAEjD,SAAS,CACb,WAAW,EAAE,sBAAsB,GAClC,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC;IAexB,GAAG,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,GAAG,SAAS,CAAC;IAUxD,IAAI,CACT,eAAe,EAAE,eAAe,EAChC,KAAK,EAAE,MAAM,EACb,UAAU,CAAC,EAAE,MAAM,EACnB,KAAK,CAAC,EAAE,MAAM;IAmCV,KAAK,CACT,eAAe,EAAE,eAAe,EAChC,KAAK,EAAE,MAAM,EACb,UAAU,CAAC,EAAE,MAAM,EACnB,KAAK,CAAC,EAAE,MAAM,EACd,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,eAAe,EAAE,CAAC;CAa9B"}
@@ -1,121 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.InMemoryProjectedStreamStorageLayer = exports.InMemoryLakeSourceFilter = exports.InMemoryStreamSourceFilter = void 0;
4
- const core_1 = require("@ddd-ts/core");
5
- const shape_1 = require("@ddd-ts/shape");
6
- class InMemoryStreamSourceFilter {
7
- database;
8
- constructor(database) {
9
- this.database = database;
10
- }
11
- *all(source, shard) {
12
- const cols = [...this.database.storage.collections.keys()];
13
- const streams = cols.filter((it) => it.startsWith(source.aggregateType));
14
- for (const stream of streams) {
15
- yield* this.database
16
- .loadAll(stream)
17
- .filter((event) => {
18
- if (!source.events.includes(event.data.data.name))
19
- return false;
20
- const payload = event.data.data.payload;
21
- if (!payload)
22
- return false;
23
- return payload[source.shardKey] === shard;
24
- })
25
- .map((event) => event.data);
26
- }
27
- }
28
- }
29
- exports.InMemoryStreamSourceFilter = InMemoryStreamSourceFilter;
30
- class InMemoryLakeSourceFilter {
31
- database;
32
- constructor(database) {
33
- this.database = database;
34
- }
35
- *all(source, shard) {
36
- const lakeId = core_1.LakeId.from(source.shardType, shard);
37
- yield* this.database
38
- .loadAll(lakeId.serialize())
39
- .filter((event) => {
40
- if (!source.events.includes(event.data.data.name))
41
- return false;
42
- const payload = event.data.data.payload;
43
- if (!payload)
44
- return false;
45
- return payload[source.shardKey] === shard;
46
- })
47
- .map((event) => event.data);
48
- }
49
- }
50
- exports.InMemoryLakeSourceFilter = InMemoryLakeSourceFilter;
51
- class InMemoryProjectedStreamStorageLayer {
52
- database;
53
- constructor(database) {
54
- this.database = database;
55
- }
56
- async getCursor(savedChange) {
57
- const [collection, id] = savedChange.ref.split("/");
58
- if (!collection || !id)
59
- return undefined;
60
- const raw = this.database.storage.getCollection(collection).getRaw(id);
61
- if (!raw)
62
- return undefined;
63
- return new core_1.Cursor({
64
- ref: savedChange.ref,
65
- eventId: new core_1.EventId(savedChange.id),
66
- occurredAt: shape_1.MicrosecondTimestamp.fromMicroseconds(raw.savedAt),
67
- revision: savedChange.revision,
68
- });
69
- }
70
- async get(cursor) {
71
- const [collection, id] = cursor.ref.split("/");
72
- if (!collection || !id)
73
- return undefined;
74
- const raw = this.database.storage.getCollection(collection).getRaw(id);
75
- if (!raw)
76
- return undefined;
77
- return { ...raw.data, occurredAt: raw.savedAt };
78
- }
79
- async *read(projectedStream, shard, startAfter, endAt) {
80
- const sources = projectedStream.sources.map((source) => {
81
- if (source instanceof core_1.StreamSource) {
82
- return new InMemoryStreamSourceFilter(this.database).all(source, shard);
83
- }
84
- return new InMemoryLakeSourceFilter(this.database).all(source, shard);
85
- });
86
- const all = sources
87
- .flatMap((source) => [...source])
88
- .sort((a, b) => a.savedAt === b.savedAt
89
- ? a.data.revision - b.data.revision
90
- : a.savedAt > b.savedAt
91
- ? 1
92
- : -1);
93
- let started = !startAfter?.ref;
94
- for (const fact of all) {
95
- if (startAfter && fact.data.ref === startAfter.ref) {
96
- started = true;
97
- continue;
98
- }
99
- if (endAt?.ref && fact.data.ref === endAt.ref) {
100
- yield { ...fact.data, occurredAt: fact.savedAt };
101
- break;
102
- }
103
- if (started) {
104
- yield { ...fact.data, occurredAt: fact.savedAt };
105
- }
106
- }
107
- }
108
- async slice(projectedStream, shard, startAfter, endAt, count) {
109
- const stream = this.read(projectedStream, shard, startAfter, endAt);
110
- const result = [];
111
- let limit = count ?? Number.POSITIVE_INFINITY;
112
- for await (const fact of stream) {
113
- if (!limit--)
114
- break;
115
- result.push(fact);
116
- }
117
- return result;
118
- }
119
- }
120
- exports.InMemoryProjectedStreamStorageLayer = InMemoryProjectedStreamStorageLayer;
121
- //# sourceMappingURL=in-memory.projected-stream.storage-layer.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.projected-stream.storage-layer.js","sourceRoot":"","sources":["../src/in-memory.projected-stream.storage-layer.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n EventId,\n ISerializedFact,\n LakeId,\n LakeSource,\n ProjectedStream,\n ProjectedStreamStorageLayer,\n StreamSource,\n Cursor,\n ISerializedSavedChange,\n} from \"@ddd-ts/core\";\nimport { InMemoryDatabase } from \"@ddd-ts/store-inmemory\";\nimport { MicrosecondTimestamp } from \"@ddd-ts/shape\";\n\nexport class InMemoryStreamSourceFilter {\n constructor(private readonly database: InMemoryDatabase) {}\n\n *all(source: StreamSource, shard: string) {\n const cols = [...this.database.storage.collections.keys()];\n const streams = cols.filter((it) => it.startsWith(source.aggregateType));\n for (const stream of streams) {\n yield* this.database\n .loadAll(stream)\n .filter((event) => {\n if (!source.events.includes(event.data.data.name)) return false;\n const payload = event.data.data.payload;\n if (!payload) return false;\n return payload[source.shardKey] === shard;\n })\n .map((event) => event.data);\n }\n }\n}\n\nexport class InMemoryLakeSourceFilter {\n constructor(private readonly database: InMemoryDatabase) {}\n\n *all(source: LakeSource, shard: string) {\n const lakeId = LakeId.from(source.shardType, shard);\n yield* this.database\n .loadAll(lakeId.serialize())\n .filter((event) => {\n if (!source.events.includes(event.data.data.name)) return false;\n const payload = event.data.data.payload;\n if (!payload) return false;\n return payload[source.shardKey] === shard;\n })\n .map((event) => event.data);\n }\n}\n\nexport class InMemoryProjectedStreamStorageLayer\n implements ProjectedStreamStorageLayer\n{\n constructor(private readonly database: InMemoryDatabase) {}\n\n async getCursor(\n savedChange: ISerializedSavedChange,\n ): Promise<Cursor | undefined> {\n const [collection, id] = savedChange.ref.split(\"/\");\n if (!collection || !id) return undefined;\n\n const raw = this.database.storage.getCollection(collection).getRaw(id);\n\n if (!raw) return undefined;\n return new Cursor({\n ref: savedChange.ref,\n eventId: new EventId(savedChange.id),\n occurredAt: MicrosecondTimestamp.fromMicroseconds(raw.savedAt),\n revision: savedChange.revision,\n });\n }\n\n async get(cursor: Cursor): Promise<ISerializedFact | undefined> {\n const [collection, id] = cursor.ref.split(\"/\");\n if (!collection || !id) return undefined;\n\n const raw = this.database.storage.getCollection(collection).getRaw(id);\n\n if (!raw) return undefined;\n return { ...raw.data, occurredAt: raw.savedAt };\n }\n\n async *read(\n projectedStream: ProjectedStream,\n shard: string,\n startAfter?: Cursor,\n endAt?: Cursor,\n ) {\n const sources = projectedStream.sources.map((source) => {\n if (source instanceof StreamSource) {\n return new InMemoryStreamSourceFilter(this.database).all(source, shard);\n }\n return new InMemoryLakeSourceFilter(this.database).all(source, shard);\n });\n\n const all = sources\n .flatMap((source) => [...source])\n .sort((a, b) =>\n a.savedAt === b.savedAt\n ? a.data.revision - b.data.revision\n : a.savedAt > b.savedAt\n ? 1\n : -1,\n );\n\n let started = !startAfter?.ref;\n for (const fact of all) {\n if (startAfter && fact.data.ref === startAfter.ref) {\n started = true;\n continue;\n }\n if (endAt?.ref && fact.data.ref === endAt.ref) {\n yield { ...fact.data, occurredAt: fact.savedAt };\n break;\n }\n if (started) {\n yield { ...fact.data, occurredAt: fact.savedAt };\n }\n }\n }\n\n async slice(\n projectedStream: ProjectedStream,\n shard: string,\n startAfter?: Cursor,\n endAt?: Cursor,\n count?: number,\n ): Promise<ISerializedFact[]> {\n const stream = this.read(projectedStream, shard, startAfter, endAt);\n\n const result: ISerializedFact[] = [];\n\n let limit = count ?? Number.POSITIVE_INFINITY;\n for await (const fact of stream) {\n if (!limit--) break;\n result.push(fact);\n }\n\n return result;\n }\n}\n"]}
@@ -1,6 +0,0 @@
1
- import { type IEsAggregateStore, type IEventSourced, type IIdentifiable, type ISerializer } from "@ddd-ts/core";
2
- import { InMemoryDatabase, InMemoryStore } from "@ddd-ts/store-inmemory";
3
- export declare class InMemorySnapshotter<A extends IEventSourced & IIdentifiable> extends InMemoryStore<A> implements IEsAggregateStore<A> {
4
- constructor(aggregate: string, db: InMemoryDatabase, serializer: ISerializer<A>);
5
- }
6
- //# sourceMappingURL=in-memory.snapshotter.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.snapshotter.d.ts","sourceRoot":"","sources":["../src/in-memory.snapshotter.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,iBAAiB,EACtB,KAAK,aAAa,EAClB,KAAK,aAAa,EAClB,KAAK,WAAW,EACjB,MAAM,cAAc,CAAC;AAEtB,OAAO,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAqBzE,qBAAa,mBAAmB,CAAC,CAAC,SAAS,aAAa,GAAG,aAAa,CACtE,SAAQ,aAAa,CAAC,CAAC,CACvB,YAAW,iBAAiB,CAAC,CAAC,CAAC;gBAG7B,SAAS,EAAE,MAAM,EACjB,EAAE,EAAE,gBAAgB,EACpB,UAAU,EAAE,WAAW,CAAC,CAAC,CAAC;CAI7B"}
@@ -1,30 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.InMemorySnapshotter = void 0;
4
- const store_inmemory_1 = require("@ddd-ts/store-inmemory");
5
- class SnapshotSerializer {
6
- serializer;
7
- constructor(serializer) {
8
- this.serializer = serializer;
9
- }
10
- async serialize(instance) {
11
- const serialized = await this.serializer.serialize(instance);
12
- return {
13
- ...serialized,
14
- revision: instance.acknowledgedRevision,
15
- };
16
- }
17
- async deserialize(serialized) {
18
- const { revision, ...content } = serialized;
19
- const instance = await this.serializer.deserialize(content);
20
- instance.acknowledgedRevision = Number(revision);
21
- return instance;
22
- }
23
- }
24
- class InMemorySnapshotter extends store_inmemory_1.InMemoryStore {
25
- constructor(aggregate, db, serializer) {
26
- super(`snapshots-${aggregate}`, db, new SnapshotSerializer(serializer));
27
- }
28
- }
29
- exports.InMemorySnapshotter = InMemorySnapshotter;
30
- //# sourceMappingURL=in-memory.snapshotter.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"in-memory.snapshotter.js","sourceRoot":"","sources":["../src/in-memory.snapshotter.ts"],"names":[],"mappings":";;;AAOA,2DAAyE;AAEzE,MAAM,kBAAkB;IACO;IAA7B,YAA6B,UAA0B;QAA1B,eAAU,GAAV,UAAU,CAAgB;IAAG,CAAC;IAE3D,KAAK,CAAC,SAAS,CAAC,QAAW;QACzB,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QAC7D,OAAO;YACL,GAAG,UAAU;YACb,QAAQ,EAAE,QAAQ,CAAC,oBAAoB;SACxC,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,UAAe;QAC/B,MAAM,EAAE,QAAQ,EAAE,GAAG,OAAO,EAAE,GAAG,UAAU,CAAC;QAC5C,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QAC5D,QAAQ,CAAC,oBAAoB,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;QACjD,OAAO,QAAQ,CAAC;IAClB,CAAC;CACF;AAED,MAAa,mBACX,SAAQ,8BAAgB;IAGxB,YACE,SAAiB,EACjB,EAAoB,EACpB,UAA0B;QAE1B,KAAK,CAAC,aAAa,SAAS,EAAE,EAAE,EAAE,EAAE,IAAI,kBAAkB,CAAC,UAAU,CAAC,CAAC,CAAC;IAC1E,CAAC;CACF;AAXD,kDAWC","sourcesContent":["import {\n type IEsAggregateStore,\n type IEventSourced,\n type IIdentifiable,\n type ISerializer,\n} from \"@ddd-ts/core\";\n\nimport { InMemoryDatabase, InMemoryStore } from \"@ddd-ts/store-inmemory\";\n\nclass SnapshotSerializer<A extends IEventSourced & IIdentifiable> {\n constructor(private readonly serializer: ISerializer<A>) {}\n\n async serialize(instance: A) {\n const serialized = await this.serializer.serialize(instance);\n return {\n ...serialized,\n revision: instance.acknowledgedRevision,\n };\n }\n\n async deserialize(serialized: any) {\n const { revision, ...content } = serialized;\n const instance = await this.serializer.deserialize(content);\n instance.acknowledgedRevision = Number(revision);\n return instance;\n }\n}\n\nexport class InMemorySnapshotter<A extends IEventSourced & IIdentifiable>\n extends InMemoryStore<A>\n implements IEsAggregateStore<A>\n{\n constructor(\n aggregate: string,\n db: InMemoryDatabase,\n serializer: ISerializer<A>,\n ) {\n super(`snapshots-${aggregate}`, db, new SnapshotSerializer(serializer));\n }\n}\n"]}
package/dist/index.d.ts DELETED
@@ -1,10 +0,0 @@
1
- export { InMemoryEventLakeStorageLayer } from "./in-memory.event-lake.storage-layer";
2
- export { InMemoryEventLakeStore } from "./in-memory.event-lake.store";
3
- export { InMemoryEventStreamStorageLayer } from "./in-memory.event-stream.storage-layer";
4
- export { InMemoryEventStreamStore } from "./in-memory.event-stream.store";
5
- export { InMemoryEventStreamAggregateStore, MakeInMemoryEventStreamAggregateStore, } from "./in-memory.event-stream.aggregate-store";
6
- export { InMemoryEventLakeAggregateStore, MakeInMemoryEventLakeAggregateStore, } from "./in-memory.event-lake.aggregate-store";
7
- export { InMemoryProjectedStreamStorageLayer, InMemoryLakeSourceFilter, InMemoryStreamSourceFilter, } from "./in-memory.projected-stream.storage-layer";
8
- export { InMemoryProjectedStreamReader } from "./in-memory.projected-stream.reader";
9
- export { InMemorySnapshotter } from "./in-memory.snapshotter";
10
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,6BAA6B,EAAE,MAAM,sCAAsC,CAAC;AACrF,OAAO,EAAE,sBAAsB,EAAE,MAAM,8BAA8B,CAAC;AACtE,OAAO,EAAE,+BAA+B,EAAE,MAAM,wCAAwC,CAAC;AACzF,OAAO,EAAE,wBAAwB,EAAE,MAAM,gCAAgC,CAAC;AAE1E,OAAO,EACL,iCAAiC,EACjC,qCAAqC,GACtC,MAAM,0CAA0C,CAAC;AAElD,OAAO,EACL,+BAA+B,EAC/B,mCAAmC,GACpC,MAAM,wCAAwC,CAAC;AAEhD,OAAO,EACL,mCAAmC,EACnC,wBAAwB,EACxB,0BAA0B,GAC3B,MAAM,4CAA4C,CAAC;AAEpD,OAAO,EAAE,6BAA6B,EAAE,MAAM,qCAAqC,CAAC;AAEpF,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC"}
package/dist/index.js DELETED
@@ -1,26 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.InMemorySnapshotter = exports.InMemoryProjectedStreamReader = exports.InMemoryStreamSourceFilter = exports.InMemoryLakeSourceFilter = exports.InMemoryProjectedStreamStorageLayer = exports.MakeInMemoryEventLakeAggregateStore = exports.InMemoryEventLakeAggregateStore = exports.MakeInMemoryEventStreamAggregateStore = exports.InMemoryEventStreamAggregateStore = exports.InMemoryEventStreamStore = exports.InMemoryEventStreamStorageLayer = exports.InMemoryEventLakeStore = exports.InMemoryEventLakeStorageLayer = void 0;
4
- var in_memory_event_lake_storage_layer_1 = require("./in-memory.event-lake.storage-layer");
5
- Object.defineProperty(exports, "InMemoryEventLakeStorageLayer", { enumerable: true, get: function () { return in_memory_event_lake_storage_layer_1.InMemoryEventLakeStorageLayer; } });
6
- var in_memory_event_lake_store_1 = require("./in-memory.event-lake.store");
7
- Object.defineProperty(exports, "InMemoryEventLakeStore", { enumerable: true, get: function () { return in_memory_event_lake_store_1.InMemoryEventLakeStore; } });
8
- var in_memory_event_stream_storage_layer_1 = require("./in-memory.event-stream.storage-layer");
9
- Object.defineProperty(exports, "InMemoryEventStreamStorageLayer", { enumerable: true, get: function () { return in_memory_event_stream_storage_layer_1.InMemoryEventStreamStorageLayer; } });
10
- var in_memory_event_stream_store_1 = require("./in-memory.event-stream.store");
11
- Object.defineProperty(exports, "InMemoryEventStreamStore", { enumerable: true, get: function () { return in_memory_event_stream_store_1.InMemoryEventStreamStore; } });
12
- var in_memory_event_stream_aggregate_store_1 = require("./in-memory.event-stream.aggregate-store");
13
- Object.defineProperty(exports, "InMemoryEventStreamAggregateStore", { enumerable: true, get: function () { return in_memory_event_stream_aggregate_store_1.InMemoryEventStreamAggregateStore; } });
14
- Object.defineProperty(exports, "MakeInMemoryEventStreamAggregateStore", { enumerable: true, get: function () { return in_memory_event_stream_aggregate_store_1.MakeInMemoryEventStreamAggregateStore; } });
15
- var in_memory_event_lake_aggregate_store_1 = require("./in-memory.event-lake.aggregate-store");
16
- Object.defineProperty(exports, "InMemoryEventLakeAggregateStore", { enumerable: true, get: function () { return in_memory_event_lake_aggregate_store_1.InMemoryEventLakeAggregateStore; } });
17
- Object.defineProperty(exports, "MakeInMemoryEventLakeAggregateStore", { enumerable: true, get: function () { return in_memory_event_lake_aggregate_store_1.MakeInMemoryEventLakeAggregateStore; } });
18
- var in_memory_projected_stream_storage_layer_1 = require("./in-memory.projected-stream.storage-layer");
19
- Object.defineProperty(exports, "InMemoryProjectedStreamStorageLayer", { enumerable: true, get: function () { return in_memory_projected_stream_storage_layer_1.InMemoryProjectedStreamStorageLayer; } });
20
- Object.defineProperty(exports, "InMemoryLakeSourceFilter", { enumerable: true, get: function () { return in_memory_projected_stream_storage_layer_1.InMemoryLakeSourceFilter; } });
21
- Object.defineProperty(exports, "InMemoryStreamSourceFilter", { enumerable: true, get: function () { return in_memory_projected_stream_storage_layer_1.InMemoryStreamSourceFilter; } });
22
- var in_memory_projected_stream_reader_1 = require("./in-memory.projected-stream.reader");
23
- Object.defineProperty(exports, "InMemoryProjectedStreamReader", { enumerable: true, get: function () { return in_memory_projected_stream_reader_1.InMemoryProjectedStreamReader; } });
24
- var in_memory_snapshotter_1 = require("./in-memory.snapshotter");
25
- Object.defineProperty(exports, "InMemorySnapshotter", { enumerable: true, get: function () { return in_memory_snapshotter_1.InMemorySnapshotter; } });
26
- //# sourceMappingURL=index.js.map
package/dist/index.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AAAA,2FAAqF;AAA5E,mJAAA,6BAA6B,OAAA;AACtC,2EAAsE;AAA7D,oIAAA,sBAAsB,OAAA;AAC/B,+FAAyF;AAAhF,uJAAA,+BAA+B,OAAA;AACxC,+EAA0E;AAAjE,wIAAA,wBAAwB,OAAA;AAEjC,mGAGkD;AAFhD,2JAAA,iCAAiC,OAAA;AACjC,+JAAA,qCAAqC,OAAA;AAGvC,+FAGgD;AAF9C,uJAAA,+BAA+B,OAAA;AAC/B,2JAAA,mCAAmC,OAAA;AAGrC,uGAIoD;AAHlD,+JAAA,mCAAmC,OAAA;AACnC,oJAAA,wBAAwB,OAAA;AACxB,sJAAA,0BAA0B,OAAA;AAG5B,yFAAoF;AAA3E,kJAAA,6BAA6B,OAAA;AAEtC,iEAA8D;AAArD,4HAAA,mBAAmB,OAAA","sourcesContent":["export { InMemoryEventLakeStorageLayer } from \"./in-memory.event-lake.storage-layer\";\nexport { InMemoryEventLakeStore } from \"./in-memory.event-lake.store\";\nexport { InMemoryEventStreamStorageLayer } from \"./in-memory.event-stream.storage-layer\";\nexport { InMemoryEventStreamStore } from \"./in-memory.event-stream.store\";\n\nexport {\n InMemoryEventStreamAggregateStore,\n MakeInMemoryEventStreamAggregateStore,\n} from \"./in-memory.event-stream.aggregate-store\";\n\nexport {\n InMemoryEventLakeAggregateStore,\n MakeInMemoryEventLakeAggregateStore,\n} from \"./in-memory.event-lake.aggregate-store\";\n\nexport {\n InMemoryProjectedStreamStorageLayer,\n InMemoryLakeSourceFilter,\n InMemoryStreamSourceFilter,\n} from \"./in-memory.projected-stream.storage-layer\";\n\nexport { InMemoryProjectedStreamReader } from \"./in-memory.projected-stream.reader\";\n\nexport { InMemorySnapshotter } from \"./in-memory.snapshotter\";\n"]}