@ddd-ts/event-sourcing-inmemory 0.0.0-feat.alpha.045d9c5

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 (53) hide show
  1. package/dist/event-store/in-memory.event-store.d.ts +33 -0
  2. package/dist/event-store/in-memory.event-store.d.ts.map +1 -0
  3. package/dist/event-store/in-memory.event-store.js +99 -0
  4. package/dist/event-store/in-memory.event-store.js.map +1 -0
  5. package/dist/event-store/in-memory.event-store.spec.d.ts +2 -0
  6. package/dist/event-store/in-memory.event-store.spec.d.ts.map +1 -0
  7. package/dist/event-store/in-memory.event-store.spec.js +8 -0
  8. package/dist/event-store/in-memory.event-store.spec.js.map +1 -0
  9. package/dist/event-store/projected-stream.d.ts +26 -0
  10. package/dist/event-store/projected-stream.d.ts.map +1 -0
  11. package/dist/event-store/projected-stream.js +61 -0
  12. package/dist/event-store/projected-stream.js.map +1 -0
  13. package/dist/event-store/stream.d.ts +13 -0
  14. package/dist/event-store/stream.d.ts.map +1 -0
  15. package/dist/event-store/stream.js +34 -0
  16. package/dist/event-store/stream.js.map +1 -0
  17. package/dist/in-memory.checkpoint.d.ts +11 -0
  18. package/dist/in-memory.checkpoint.d.ts.map +1 -0
  19. package/dist/in-memory.checkpoint.js +31 -0
  20. package/dist/in-memory.checkpoint.js.map +1 -0
  21. package/dist/in-memory.snapshotter.d.ts +11 -0
  22. package/dist/in-memory.snapshotter.d.ts.map +1 -0
  23. package/dist/in-memory.snapshotter.js +30 -0
  24. package/dist/in-memory.snapshotter.js.map +1 -0
  25. package/dist/in-memory.transaction-performer.d.ts +6 -0
  26. package/dist/in-memory.transaction-performer.d.ts.map +1 -0
  27. package/dist/in-memory.transaction-performer.js +11 -0
  28. package/dist/in-memory.transaction-performer.js.map +1 -0
  29. package/dist/index.d.ts +7 -0
  30. package/dist/index.d.ts.map +1 -0
  31. package/dist/index.js +16 -0
  32. package/dist/index.js.map +1 -0
  33. package/dist/store/in-memory.collection.d.ts +17 -0
  34. package/dist/store/in-memory.collection.d.ts.map +1 -0
  35. package/dist/store/in-memory.collection.js +58 -0
  36. package/dist/store/in-memory.collection.js.map +1 -0
  37. package/dist/store/in-memory.database.d.ts +17 -0
  38. package/dist/store/in-memory.database.d.ts.map +1 -0
  39. package/dist/store/in-memory.database.js +86 -0
  40. package/dist/store/in-memory.database.js.map +1 -0
  41. package/dist/store/in-memory.storage.d.ts +10 -0
  42. package/dist/store/in-memory.storage.d.ts.map +1 -0
  43. package/dist/store/in-memory.storage.js +41 -0
  44. package/dist/store/in-memory.storage.js.map +1 -0
  45. package/dist/store/in-memory.store.d.ts +14 -0
  46. package/dist/store/in-memory.store.d.ts.map +1 -0
  47. package/dist/store/in-memory.store.js +41 -0
  48. package/dist/store/in-memory.store.js.map +1 -0
  49. package/dist/test/bank.spec.d.ts +2 -0
  50. package/dist/test/bank.spec.d.ts.map +1 -0
  51. package/dist/test/bank.spec.js +24 -0
  52. package/dist/test/bank.spec.js.map +1 -0
  53. package/package.json +19 -0
@@ -0,0 +1,33 @@
1
+ /// <reference types="node" />
2
+ import { EsAggregate, Constructor, EsChange, EventStore, ProjectedStreamConfiguration } from "@ddd-ts/event-sourcing";
3
+ export declare class InMemoryEventStore extends EventStore {
4
+ private streams;
5
+ private projectedStreams;
6
+ private newStreamSubscribers;
7
+ close(): Promise<void>;
8
+ clear(): Promise<void>;
9
+ appendToAggregateStream<A extends EsAggregate>(AGGREGATE: Constructor<A>, accountId: A extends EsAggregate<infer Id> ? Id : never, changes: EsChange[], expectedRevision: bigint): Promise<void>;
10
+ readAggregateStream<A extends EsAggregate>(AGGREGATE: Constructor<A>, accountId: A extends EsAggregate<infer Id> ? Id : never, from?: bigint): AsyncGenerator<{
11
+ id: string;
12
+ type: string;
13
+ payload: import("@ddd-ts/event-sourcing").Serializable;
14
+ revision: bigint;
15
+ }, void, unknown>;
16
+ private getProjectedStream;
17
+ readProjectedStream(config: ProjectedStreamConfiguration, from?: bigint): AsyncGenerator<{
18
+ id: string;
19
+ type: string;
20
+ payload: import("@ddd-ts/event-sourcing").Serializable;
21
+ revision: bigint;
22
+ }, void, unknown>;
23
+ followProjectedStream(config: ProjectedStreamConfiguration, from?: bigint): Promise<import("@ddd-ts/event-sourcing").Queue<import("@ddd-ts/event-sourcing").EsFact>>;
24
+ competeForProjectedStream(config: ProjectedStreamConfiguration, competition: string): Promise<AsyncIterableIterator<{
25
+ fact: import("@ddd-ts/event-sourcing").EsFact;
26
+ retry: () => NodeJS.Immediate;
27
+ succeed: () => void;
28
+ skip: () => void;
29
+ }> & {
30
+ close: () => Promise<void>;
31
+ }>;
32
+ }
33
+ //# sourceMappingURL=in-memory.event-store.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"in-memory.event-store.d.ts","sourceRoot":"","sources":["../../src/event-store/in-memory.event-store.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,WAAW,EACX,WAAW,EACX,QAAQ,EACR,UAAU,EACV,4BAA4B,EAC7B,MAAM,wBAAwB,CAAC;AAIhC,qBAAa,kBAAmB,SAAQ,UAAU;IAChD,OAAO,CAAC,OAAO,CAA6B;IAC5C,OAAO,CAAC,gBAAgB,CAAsC;IAE9D,OAAO,CAAC,oBAAoB,CAAuC;IAE7D,KAAK;IAIL,KAAK;IAQL,uBAAuB,CAAC,CAAC,SAAS,WAAW,EACjD,SAAS,EAAE,WAAW,CAAC,CAAC,CAAC,EACzB,SAAS,EAAE,CAAC,SAAS,WAAW,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,GAAG,KAAK,EACvD,OAAO,EAAE,QAAQ,EAAE,EACnB,gBAAgB,EAAE,MAAM;IAwBnB,mBAAmB,CAAC,CAAC,SAAS,WAAW,EAC9C,SAAS,EAAE,WAAW,CAAC,CAAC,CAAC,EACzB,SAAS,EAAE,CAAC,SAAS,WAAW,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,GAAG,KAAK,EACvD,IAAI,SAAK;;;;;;IAcX,OAAO,CAAC,kBAAkB;IAiDnB,mBAAmB,CAAC,MAAM,EAAE,4BAA4B,EAAE,IAAI,SAAK;;;;;;IAMpE,qBAAqB,CAAC,MAAM,EAAE,4BAA4B,EAAE,IAAI,SAAK;IAMrE,yBAAyB,CAC7B,MAAM,EAAE,4BAA4B,EACpC,WAAW,EAAE,MAAM;;;;;;;;CAMtB"}
@@ -0,0 +1,99 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.InMemoryEventStore = void 0;
4
+ const event_sourcing_1 = require("@ddd-ts/event-sourcing");
5
+ const projected_stream_1 = require("./projected-stream");
6
+ const stream_1 = require("./stream");
7
+ class InMemoryEventStore extends event_sourcing_1.EventStore {
8
+ streams = new Map();
9
+ projectedStreams = new Map();
10
+ newStreamSubscribers = new Set();
11
+ async close() {
12
+ this.clear();
13
+ }
14
+ async clear() {
15
+ this.streams.clear();
16
+ for (const [key, value] of this.projectedStreams) {
17
+ value.onCloseCallbacks.forEach((callback) => callback());
18
+ }
19
+ this.projectedStreams.clear();
20
+ }
21
+ async appendToAggregateStream(AGGREGATE, accountId, changes, expectedRevision) {
22
+ const streamName = `${AGGREGATE.name}-${accountId.toString()}`;
23
+ if (!this.streams.has(streamName)) {
24
+ const stream = new stream_1.Stream();
25
+ this.streams.set(streamName, stream);
26
+ this.newStreamSubscribers.forEach((subscriber) => subscriber(stream));
27
+ }
28
+ const stream = this.streams.get(streamName);
29
+ const currentRevision = stream.facts.length - 1;
30
+ if (currentRevision !== Number(expectedRevision)) {
31
+ throw new Error(`Expected revision ${expectedRevision} but got ${currentRevision}`);
32
+ }
33
+ for (const change of changes) {
34
+ stream.append(change);
35
+ }
36
+ }
37
+ async *readAggregateStream(AGGREGATE, accountId, from = 0n) {
38
+ const streamName = `${AGGREGATE.name}-${accountId.toString()}`;
39
+ const stream = this.streams.get(streamName);
40
+ if (!stream) {
41
+ return;
42
+ }
43
+ for await (const { occuredAt, ...fact } of stream.readRaw(from)) {
44
+ yield fact;
45
+ }
46
+ }
47
+ getProjectedStream(config) {
48
+ const streamName = config
49
+ .map((a) => a.name)
50
+ .sort()
51
+ .join("+");
52
+ if (this.projectedStreams.has(streamName)) {
53
+ return this.projectedStreams.get(streamName);
54
+ }
55
+ const streams = [...this.streams.keys()];
56
+ const correspondingStreams = streams
57
+ .filter((name) => config.some((a) => a.name === name.split("-")[0]))
58
+ .map((name) => this.streams.get(name));
59
+ const orderedFacts = correspondingStreams
60
+ .map((stream) => stream.facts)
61
+ .flat()
62
+ .sort((a, b) => a.occuredAt.getTime() - b.occuredAt.getTime());
63
+ const projectedStream = new projected_stream_1.ProjectedStream();
64
+ for (const fact of orderedFacts) {
65
+ projectedStream.append(fact);
66
+ }
67
+ for (const stream of correspondingStreams) {
68
+ const unsubscribe = stream.subscribe((fact) => {
69
+ projectedStream.append(fact);
70
+ projectedStream.onClose(unsubscribe);
71
+ });
72
+ // here we need to unsubscribe
73
+ }
74
+ this.newStreamSubscribers.add((stream) => {
75
+ // handle non corresponding streams
76
+ const unsubscribe = stream.subscribe((fact) => {
77
+ projectedStream.append(fact);
78
+ });
79
+ projectedStream.onClose(unsubscribe);
80
+ // here we need to unsubscribe
81
+ });
82
+ this.projectedStreams.set(streamName, projectedStream);
83
+ return projectedStream;
84
+ }
85
+ async *readProjectedStream(config, from = 0n) {
86
+ const projectedStream = this.getProjectedStream(config);
87
+ yield* projectedStream.read(from);
88
+ }
89
+ async followProjectedStream(config, from = 0n) {
90
+ const projectedStream = this.getProjectedStream(config);
91
+ return projectedStream.follow(from);
92
+ }
93
+ async competeForProjectedStream(config, competition) {
94
+ const projectedStream = this.getProjectedStream(config);
95
+ return projectedStream.compete(competition);
96
+ }
97
+ }
98
+ exports.InMemoryEventStore = InMemoryEventStore;
99
+ //# sourceMappingURL=in-memory.event-store.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"in-memory.event-store.js","sourceRoot":"","sources":["../../src/event-store/in-memory.event-store.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=in-memory.event-store.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"in-memory.event-store.spec.d.ts","sourceRoot":"","sources":["../../src/event-store/in-memory.event-store.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const tests_1 = require("@ddd-ts/tests");
4
+ const in_memory_event_store_1 = require("./in-memory.event-store");
5
+ describe("InMemoryEventStore", () => {
6
+ (0, tests_1.EsAggregateStoreSuite)(new in_memory_event_store_1.InMemoryEventStore());
7
+ });
8
+ //# sourceMappingURL=in-memory.event-store.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"in-memory.event-store.spec.js","sourceRoot":"","sources":["../../src/event-store/in-memory.event-store.spec.ts"],"names":[],"mappings":";;AAAA,yCAAsD;AACtD,mEAA6D;AAE7D,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IAClC,IAAA,6BAAqB,EAAC,IAAI,0CAAkB,EAAE,CAAC,CAAC;AAClD,CAAC,CAAC,CAAC"}
@@ -0,0 +1,26 @@
1
+ /// <reference types="node" />
2
+ import { EsFact, Queue } from "@ddd-ts/event-sourcing";
3
+ import { Stream } from "./stream";
4
+ export declare class ProjectedStream extends Stream {
5
+ followers: Set<Queue<EsFact>>;
6
+ competitions: Map<string, Queue<EsFact>>;
7
+ onCloseCallbacks: any[];
8
+ read(from?: bigint): AsyncGenerator<{
9
+ id: string;
10
+ type: string;
11
+ payload: import("@ddd-ts/event-sourcing").Serializable;
12
+ revision: bigint;
13
+ }, void, unknown>;
14
+ onClose(callback: any): void;
15
+ follow(from?: bigint): Promise<Queue<EsFact>>;
16
+ private getCompetition;
17
+ compete(competitionName: string): Promise<AsyncIterableIterator<{
18
+ fact: EsFact;
19
+ retry: () => NodeJS.Immediate;
20
+ succeed: () => void;
21
+ skip: () => void;
22
+ }> & {
23
+ close: () => Promise<void>;
24
+ }>;
25
+ }
26
+ //# sourceMappingURL=projected-stream.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"projected-stream.d.ts","sourceRoot":"","sources":["../../src/event-store/projected-stream.ts"],"names":[],"mappings":";AAAA,OAAO,EAAa,MAAM,EAAO,KAAK,EAAE,MAAM,wBAAwB,CAAC;AACvE,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAElC,qBAAa,eAAgB,SAAQ,MAAM;IACzC,SAAS,qBAA4B;IACrC,YAAY,6BAAoC;IAEhD,gBAAgB,EAAE,GAAG,EAAE,CAAM;IAEtB,IAAI,CAAC,IAAI,SAAK;;;;;;IAOrB,OAAO,CAAC,QAAQ,EAAE,GAAG;IAIf,MAAM,CAAC,IAAI,SAAK;IAmBtB,OAAO,CAAC,cAAc;IAahB,OAAO,CAAC,eAAe,EAAE,MAAM;;;;;;;;CAiBtC"}
@@ -0,0 +1,61 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ProjectedStream = void 0;
4
+ const event_sourcing_1 = require("@ddd-ts/event-sourcing");
5
+ const stream_1 = require("./stream");
6
+ class ProjectedStream extends stream_1.Stream {
7
+ followers = new Set();
8
+ competitions = new Map();
9
+ onCloseCallbacks = [];
10
+ async *read(from = 0n) {
11
+ for await (const datedFact of super.readRaw(from)) {
12
+ const { occuredAt, ...fact } = datedFact;
13
+ yield fact;
14
+ }
15
+ }
16
+ onClose(callback) {
17
+ this.onCloseCallbacks.push(callback);
18
+ }
19
+ async follow(from = 0n) {
20
+ const follower = new event_sourcing_1.Queue();
21
+ this.followers.add(follower);
22
+ for await (const fact of this.read(from)) {
23
+ follower.push(fact);
24
+ }
25
+ const unsubscribe = this.subscribe((datedFact) => {
26
+ const { occuredAt, ...fact } = datedFact;
27
+ if (fact.revision >= from) {
28
+ follower.push(fact);
29
+ }
30
+ });
31
+ follower.onClose(unsubscribe);
32
+ return follower;
33
+ }
34
+ getCompetition(competitionName) {
35
+ if (!this.competitions.has(competitionName)) {
36
+ const competition = new event_sourcing_1.Queue();
37
+ const unsubscribe = this.subscribe((datedFact) => {
38
+ const { occuredAt, ...fact } = datedFact;
39
+ competition.push(fact);
40
+ });
41
+ competition.onClose(unsubscribe);
42
+ this.competitions.set(competitionName, competition);
43
+ }
44
+ return this.competitions.get(competitionName);
45
+ }
46
+ async compete(competitionName) {
47
+ const competition = this.getCompetition(competitionName);
48
+ return (0, event_sourcing_1.closeable)((0, event_sourcing_1.map)(competition[Symbol.asyncIterator](), (fact) => ({
49
+ fact,
50
+ retry: () => setImmediate(() => competition.push(fact)),
51
+ succeed: () => { },
52
+ skip: () => { },
53
+ })), async () => {
54
+ // competition.close();
55
+ // this.competitions.delete(competitionName);
56
+ // console.log("closing competitor");
57
+ });
58
+ }
59
+ }
60
+ exports.ProjectedStream = ProjectedStream;
61
+ //# sourceMappingURL=projected-stream.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"projected-stream.js","sourceRoot":"","sources":["../../src/event-store/projected-stream.ts"],"names":[],"mappings":";;;AAAA,2DAAuE;AACvE,qCAAkC;AAElC,MAAa,eAAgB,SAAQ,eAAM;IACzC,SAAS,GAAG,IAAI,GAAG,EAAiB,CAAC;IACrC,YAAY,GAAG,IAAI,GAAG,EAAyB,CAAC;IAEhD,gBAAgB,GAAU,EAAE,CAAC;IAE7B,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,GAAG,EAAE;QACnB,IAAI,KAAK,EAAE,MAAM,SAAS,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACjD,MAAM,EAAE,SAAS,EAAE,GAAG,IAAI,EAAE,GAAG,SAAS,CAAC;YACzC,MAAM,IAAI,CAAC;SACZ;IACH,CAAC;IAED,OAAO,CAAC,QAAa;QACnB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACvC,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,IAAI,GAAG,EAAE;QACpB,MAAM,QAAQ,GAAG,IAAI,sBAAK,EAAU,CAAC;QACrC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAE7B,IAAI,KAAK,EAAE,MAAM,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;YACxC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SACrB;QAED,MAAM,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,SAAS,EAAE,EAAE;YAC/C,MAAM,EAAE,SAAS,EAAE,GAAG,IAAI,EAAE,GAAG,SAAS,CAAC;YACzC,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,EAAE;gBACzB,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aACrB;QACH,CAAC,CAAC,CAAC;QACH,QAAQ,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAE9B,OAAO,QAAQ,CAAC;IAClB,CAAC;IAEO,cAAc,CAAC,eAAuB;QAC5C,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,eAAe,CAAC,EAAE;YAC3C,MAAM,WAAW,GAAG,IAAI,sBAAK,EAAU,CAAC;YACxC,MAAM,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,SAAS,EAAE,EAAE;gBAC/C,MAAM,EAAE,SAAS,EAAE,GAAG,IAAI,EAAE,GAAG,SAAS,CAAC;gBACzC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACzB,CAAC,CAAC,CAAC;YACH,WAAW,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;YACjC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,eAAe,EAAE,WAAW,CAAC,CAAC;SACrD;QACD,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,eAAe,CAAE,CAAC;IACjD,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,eAAuB;QACnC,MAAM,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,CAAC;QAEzD,OAAO,IAAA,0BAAS,EACd,IAAA,oBAAG,EAAC,WAAW,CAAC,MAAM,CAAC,aAAa,CAAC,EAAE,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;YAClD,IAAI;YACJ,KAAK,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,GAAG,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACvD,OAAO,EAAE,GAAG,EAAE,GAAE,CAAC;YACjB,IAAI,EAAE,GAAG,EAAE,GAAE,CAAC;SACf,CAAC,CAAC,EACH,KAAK,IAAI,EAAE;YACT,uBAAuB;YACvB,6CAA6C;YAC7C,qCAAqC;QACvC,CAAC,CACF,CAAC;IACJ,CAAC;CACF;AAlED,0CAkEC"}
@@ -0,0 +1,13 @@
1
+ import { EsFact, EsEvent } from "@ddd-ts/event-sourcing";
2
+ type DatedFact = EsFact & {
3
+ occuredAt: Date;
4
+ };
5
+ export declare class Stream {
6
+ facts: DatedFact[];
7
+ subscribers: Set<(fact: DatedFact) => void>;
8
+ append(change: EsEvent): void;
9
+ subscribe(subscriber: (fact: DatedFact) => void): () => void;
10
+ readRaw(from?: bigint): Generator<DatedFact, void, unknown>;
11
+ }
12
+ export {};
13
+ //# sourceMappingURL=stream.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stream.d.ts","sourceRoot":"","sources":["../../src/event-store/stream.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEzD,KAAK,SAAS,GAAG,MAAM,GAAG;IAAE,SAAS,EAAE,IAAI,CAAA;CAAE,CAAC;AAE9C,qBAAa,MAAM;IACjB,KAAK,EAAE,SAAS,EAAE,CAAM;IAExB,WAAW,aAAkB,SAAS,KAAK,IAAI,EAAI;IAEnD,MAAM,CAAC,MAAM,EAAE,OAAO;IAetB,SAAS,CAAC,UAAU,EAAE,CAAC,IAAI,EAAE,SAAS,KAAK,IAAI;IAO9C,OAAO,CAAC,IAAI,SAAK;CAMnB"}
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Stream = void 0;
4
+ class Stream {
5
+ facts = [];
6
+ subscribers = new Set();
7
+ append(change) {
8
+ const revision = BigInt(this.facts.length);
9
+ const occuredAt = new Date();
10
+ const datedFact = {
11
+ ...change,
12
+ revision,
13
+ occuredAt,
14
+ };
15
+ this.facts.push(datedFact);
16
+ for (const subscriber of this.subscribers) {
17
+ subscriber(datedFact);
18
+ }
19
+ }
20
+ subscribe(subscriber) {
21
+ this.subscribers.add(subscriber);
22
+ return () => {
23
+ this.subscribers.delete(subscriber);
24
+ };
25
+ }
26
+ *readRaw(from = 0n) {
27
+ const revision = Number(from);
28
+ for (let i = revision; i < this.facts.length; i++) {
29
+ yield this.facts[i];
30
+ }
31
+ }
32
+ }
33
+ exports.Stream = Stream;
34
+ //# sourceMappingURL=stream.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stream.js","sourceRoot":"","sources":["../../src/event-store/stream.ts"],"names":[],"mappings":";;;AAIA,MAAa,MAAM;IACjB,KAAK,GAAgB,EAAE,CAAC;IAExB,WAAW,GAAG,IAAI,GAAG,EAA6B,CAAC;IAEnD,MAAM,CAAC,MAAe;QACpB,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAC3C,MAAM,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC;QAC7B,MAAM,SAAS,GAAG;YAChB,GAAG,MAAM;YACT,QAAQ;YACR,SAAS;SACV,CAAC;QAEF,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC3B,KAAK,MAAM,UAAU,IAAI,IAAI,CAAC,WAAW,EAAE;YACzC,UAAU,CAAC,SAAS,CAAC,CAAC;SACvB;IACH,CAAC;IAED,SAAS,CAAC,UAAqC;QAC7C,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACjC,OAAO,GAAG,EAAE;YACV,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;QACtC,CAAC,CAAC;IACJ,CAAC;IAED,CAAC,OAAO,CAAC,IAAI,GAAG,EAAE;QAChB,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;QAC9B,KAAK,IAAI,CAAC,GAAG,QAAQ,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACjD,MAAM,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;SACrB;IACH,CAAC;CACF;AAjCD,wBAiCC"}
@@ -0,0 +1,11 @@
1
+ import { Checkpoint } from "@ddd-ts/event-sourcing/src/projection/checkpoint/checkpoint";
2
+ import { InMemoryDatabase, InMemoryTransaction } from "./store/in-memory.database";
3
+ export declare class InMemoryCheckpoint extends Checkpoint {
4
+ private readonly inMemoryDatabase;
5
+ projections: Map<string, bigint>;
6
+ constructor(inMemoryDatabase: InMemoryDatabase);
7
+ get(name: string, trx?: InMemoryTransaction): Promise<bigint>;
8
+ set(name: string, revision: bigint, trx?: InMemoryTransaction): Promise<void>;
9
+ clear(): Promise<void>;
10
+ }
11
+ //# sourceMappingURL=in-memory.checkpoint.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"in-memory.checkpoint.d.ts","sourceRoot":"","sources":["../src/in-memory.checkpoint.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,UAAU,EAEX,MAAM,6DAA6D,CAAC;AACrE,OAAO,EACL,gBAAgB,EAChB,mBAAmB,EACpB,MAAM,4BAA4B,CAAC;AAEpC,qBAAa,kBAAmB,SAAQ,UAAU;IAGpC,OAAO,CAAC,QAAQ,CAAC,gBAAgB;IAF7C,WAAW,sBAA6B;gBAEX,gBAAgB,EAAE,gBAAgB;IAIzD,GAAG,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,mBAAmB;IAQ3C,GAAG,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,mBAAmB;IAS7D,KAAK;CAGZ"}
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.InMemoryCheckpoint = void 0;
4
+ const checkpoint_1 = require("@ddd-ts/event-sourcing/src/projection/checkpoint/checkpoint");
5
+ class InMemoryCheckpoint extends checkpoint_1.Checkpoint {
6
+ inMemoryDatabase;
7
+ projections = new Map();
8
+ constructor(inMemoryDatabase) {
9
+ super();
10
+ this.inMemoryDatabase = inMemoryDatabase;
11
+ }
12
+ async get(name, trx) {
13
+ const checkpoint = this.inMemoryDatabase.load("checkpoint", name, trx);
14
+ if (typeof checkpoint === "bigint") {
15
+ return checkpoint;
16
+ }
17
+ return -1n;
18
+ }
19
+ async set(name, revision, trx) {
20
+ const current = await this.get(name);
21
+ if (revision < current) {
22
+ throw new checkpoint_1.CheckpointFurtherAway(name, revision, current);
23
+ }
24
+ this.inMemoryDatabase.save("checkpoint", name, revision, trx);
25
+ }
26
+ async clear() {
27
+ this.inMemoryDatabase.clear("checkpoint");
28
+ }
29
+ }
30
+ exports.InMemoryCheckpoint = InMemoryCheckpoint;
31
+ //# sourceMappingURL=in-memory.checkpoint.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"in-memory.checkpoint.js","sourceRoot":"","sources":["../src/in-memory.checkpoint.ts"],"names":[],"mappings":";;;AAAA,4FAGqE;AAMrE,MAAa,kBAAmB,SAAQ,uBAAU;IAGnB;IAF7B,WAAW,GAAG,IAAI,GAAG,EAAkB,CAAC;IAExC,YAA6B,gBAAkC;QAC7D,KAAK,EAAE,CAAC;QADmB,qBAAgB,GAAhB,gBAAgB,CAAkB;IAE/D,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,IAAY,EAAE,GAAyB;QAC/C,MAAM,UAAU,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,EAAE,GAAG,CAAC,CAAC;QACvE,IAAI,OAAO,UAAU,KAAK,QAAQ,EAAE;YAClC,OAAO,UAAU,CAAC;SACnB;QACD,OAAO,CAAC,EAAE,CAAC;IACb,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,IAAY,EAAE,QAAgB,EAAE,GAAyB;QACjE,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACrC,IAAI,QAAQ,GAAG,OAAO,EAAE;YACtB,MAAM,IAAI,kCAAqB,CAAC,IAAI,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;SAC1D;QAED,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,CAAC,CAAC;IAChE,CAAC;IAED,KAAK,CAAC,KAAK;QACT,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;IAC5C,CAAC;CACF;AA3BD,gDA2BC"}
@@ -0,0 +1,11 @@
1
+ import { Serializer } from "@ddd-ts/model";
2
+ import { Snapshotter, EsAggregate } from "@ddd-ts/event-sourcing";
3
+ import { InMemoryDatabase } from "./index";
4
+ export declare class InMemorySnapshotter<S extends Serializer<EsAggregate>> extends Snapshotter<S extends Serializer<infer A> ? A : never> {
5
+ private readonly db;
6
+ readonly serializer: S;
7
+ constructor(db: InMemoryDatabase, serializer: S);
8
+ load(id: ReturnType<S["getIdFromModel"]>): Promise<any>;
9
+ save(aggregate: S extends Serializer<infer A> ? A : never): Promise<void>;
10
+ }
11
+ //# sourceMappingURL=in-memory.snapshotter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"in-memory.snapshotter.d.ts","sourceRoot":"","sources":["../src/in-memory.snapshotter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAClE,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAE3C,qBAAa,mBAAmB,CAC9B,CAAC,SAAS,UAAU,CAAC,WAAW,CAAC,CACjC,SAAQ,WAAW,CAAC,CAAC,SAAS,UAAU,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;IAE5D,OAAO,CAAC,QAAQ,CAAC,EAAE;aACH,UAAU,EAAE,CAAC;gBADZ,EAAE,EAAE,gBAAgB,EACrB,UAAU,EAAE,CAAC;IAKzB,IAAI,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC;IAUvD,IAAI,CACR,SAAS,EAAE,CAAC,SAAS,UAAU,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,GAAG,KAAK,GACnD,OAAO,CAAC,IAAI,CAAC;CAQjB"}
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.InMemorySnapshotter = void 0;
4
+ const event_sourcing_1 = require("@ddd-ts/event-sourcing");
5
+ class InMemorySnapshotter extends event_sourcing_1.Snapshotter {
6
+ db;
7
+ serializer;
8
+ constructor(db, serializer) {
9
+ super();
10
+ this.db = db;
11
+ this.serializer = serializer;
12
+ }
13
+ async load(id) {
14
+ const snapshot = await this.db.loadLatestSnapshot(id.toString());
15
+ if (!snapshot) {
16
+ return undefined;
17
+ }
18
+ return this.serializer.deserialize(snapshot.serialized);
19
+ }
20
+ async save(aggregate) {
21
+ const id = this.serializer.getIdFromModel(aggregate);
22
+ this.db.save("snapshots", id.toString(), {
23
+ id: id.toString(),
24
+ revision: Number(aggregate.acknowledgedRevision),
25
+ serialized: this.serializer.serialize(aggregate),
26
+ });
27
+ }
28
+ }
29
+ exports.InMemorySnapshotter = InMemorySnapshotter;
30
+ //# sourceMappingURL=in-memory.snapshotter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"in-memory.snapshotter.js","sourceRoot":"","sources":["../src/in-memory.snapshotter.ts"],"names":[],"mappings":";;;AACA,2DAAkE;AAGlE,MAAa,mBAEX,SAAQ,4BAAsD;IAE3C;IACD;IAFlB,YACmB,EAAoB,EACrB,UAAa;QAE7B,KAAK,EAAE,CAAC;QAHS,OAAE,GAAF,EAAE,CAAkB;QACrB,eAAU,GAAV,UAAU,CAAG;IAG/B,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,EAAmC;QAC5C,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,EAAE,CAAC,kBAAkB,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC;QAEjE,IAAI,CAAC,QAAQ,EAAE;YACb,OAAO,SAAS,CAAC;SAClB;QAED,OAAO,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;IAC1D,CAAC;IAED,KAAK,CAAC,IAAI,CACR,SAAoD;QAEpD,MAAM,EAAE,GAAG,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;QACrD,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC,QAAQ,EAAE,EAAE;YACvC,EAAE,EAAE,EAAE,CAAC,QAAQ,EAAE;YACjB,QAAQ,EAAE,MAAM,CAAC,SAAS,CAAC,oBAAoB,CAAC;YAChD,UAAU,EAAE,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,SAAS,CAAC;SACjD,CAAC,CAAC;IACL,CAAC;CACF;AA9BD,kDA8BC"}
@@ -0,0 +1,6 @@
1
+ import { TransactionPerformer } from "@ddd-ts/model";
2
+ import { InMemoryDatabase } from "./store/in-memory.database";
3
+ export declare class InMemoryTransactionPerformer extends TransactionPerformer {
4
+ constructor(db: InMemoryDatabase);
5
+ }
6
+ //# sourceMappingURL=in-memory.transaction-performer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"in-memory.transaction-performer.d.ts","sourceRoot":"","sources":["../src/in-memory.transaction-performer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AACrD,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AAE9D,qBAAa,4BAA6B,SAAQ,oBAAoB;gBACxD,EAAE,EAAE,gBAAgB;CAGjC"}
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.InMemoryTransactionPerformer = void 0;
4
+ const model_1 = require("@ddd-ts/model");
5
+ class InMemoryTransactionPerformer extends model_1.TransactionPerformer {
6
+ constructor(db) {
7
+ super((effect) => db.transactionally(effect));
8
+ }
9
+ }
10
+ exports.InMemoryTransactionPerformer = InMemoryTransactionPerformer;
11
+ //# sourceMappingURL=in-memory.transaction-performer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"in-memory.transaction-performer.js","sourceRoot":"","sources":["../src/in-memory.transaction-performer.ts"],"names":[],"mappings":";;;AAAA,yCAAqD;AAGrD,MAAa,4BAA6B,SAAQ,4BAAoB;IACpE,YAAY,EAAoB;QAC9B,KAAK,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,CAAC;IAChD,CAAC;CACF;AAJD,oEAIC"}
@@ -0,0 +1,7 @@
1
+ export { InMemorySnapshotter } from "./in-memory.snapshotter";
2
+ export { InMemoryEventStore } from "./event-store/in-memory.event-store";
3
+ export { InMemoryCheckpoint } from "./in-memory.checkpoint";
4
+ export { InMemoryTransactionPerformer } from "./in-memory.transaction-performer";
5
+ export { InMemoryDatabase } from "./store/in-memory.database";
6
+ export { InMemoryStore } from "./store/in-memory.store";
7
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAE9D,OAAO,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AACzE,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAC5D,OAAO,EAAE,4BAA4B,EAAE,MAAM,mCAAmC,CAAC;AACjF,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC"}
package/dist/index.js ADDED
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.InMemoryStore = exports.InMemoryDatabase = exports.InMemoryTransactionPerformer = exports.InMemoryCheckpoint = exports.InMemoryEventStore = exports.InMemorySnapshotter = void 0;
4
+ var in_memory_snapshotter_1 = require("./in-memory.snapshotter");
5
+ Object.defineProperty(exports, "InMemorySnapshotter", { enumerable: true, get: function () { return in_memory_snapshotter_1.InMemorySnapshotter; } });
6
+ var in_memory_event_store_1 = require("./event-store/in-memory.event-store");
7
+ Object.defineProperty(exports, "InMemoryEventStore", { enumerable: true, get: function () { return in_memory_event_store_1.InMemoryEventStore; } });
8
+ var in_memory_checkpoint_1 = require("./in-memory.checkpoint");
9
+ Object.defineProperty(exports, "InMemoryCheckpoint", { enumerable: true, get: function () { return in_memory_checkpoint_1.InMemoryCheckpoint; } });
10
+ var in_memory_transaction_performer_1 = require("./in-memory.transaction-performer");
11
+ Object.defineProperty(exports, "InMemoryTransactionPerformer", { enumerable: true, get: function () { return in_memory_transaction_performer_1.InMemoryTransactionPerformer; } });
12
+ var in_memory_database_1 = require("./store/in-memory.database");
13
+ Object.defineProperty(exports, "InMemoryDatabase", { enumerable: true, get: function () { return in_memory_database_1.InMemoryDatabase; } });
14
+ var in_memory_store_1 = require("./store/in-memory.store");
15
+ Object.defineProperty(exports, "InMemoryStore", { enumerable: true, get: function () { return in_memory_store_1.InMemoryStore; } });
16
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AAAA,iEAA8D;AAArD,4HAAA,mBAAmB,OAAA;AAE5B,6EAAyE;AAAhE,2HAAA,kBAAkB,OAAA;AAC3B,+DAA4D;AAAnD,0HAAA,kBAAkB,OAAA;AAC3B,qFAAiF;AAAxE,+IAAA,4BAA4B,OAAA;AACrC,iEAA8D;AAArD,sHAAA,gBAAgB,OAAA;AACzB,2DAAwD;AAA/C,gHAAA,aAAa,OAAA"}
@@ -0,0 +1,17 @@
1
+ export declare class Collection {
2
+ private data;
3
+ constructor(data?: Map<string, {
4
+ savedAt: number;
5
+ data: any;
6
+ }>);
7
+ clear(): void;
8
+ getLatestSnapshot(id: string): any;
9
+ clone(): Collection;
10
+ merge(other: Collection): Collection;
11
+ delete(id: string): void;
12
+ get(id: string): any;
13
+ getAll(): any[];
14
+ save(id: string, data: any): void;
15
+ toPretty(): string;
16
+ }
17
+ //# sourceMappingURL=in-memory.collection.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"in-memory.collection.d.ts","sourceRoot":"","sources":["../../src/store/in-memory.collection.ts"],"names":[],"mappings":"AAAA,qBAAa,UAAU;IAEnB,OAAO,CAAC,IAAI;gBAAJ,IAAI,GAAE,GAAG,CAAC,MAAM,EAAE;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,GAAG,CAAA;KAAE,CAAa;IAGvE,KAAK;IAIL,iBAAiB,CAAC,EAAE,EAAE,MAAM;IAO5B,KAAK;IAQL,KAAK,CAAC,KAAK,EAAE,UAAU;IAWvB,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,IAAI;IAIxB,GAAG,CAAC,EAAE,EAAE,MAAM,GAAG,GAAG;IAIpB,MAAM,IAAI,GAAG,EAAE;IAIf,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,GAAG,IAAI;IAMjC,QAAQ;CAOT"}
@@ -0,0 +1,58 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Collection = void 0;
4
+ class Collection {
5
+ data;
6
+ constructor(data = new Map()) {
7
+ this.data = data;
8
+ }
9
+ clear() {
10
+ this.data.clear();
11
+ }
12
+ getLatestSnapshot(id) {
13
+ const data = [...this.data.values()];
14
+ const sameId = data.filter((d) => d.data.id === id);
15
+ const sorted = sameId.sort((a, b) => b.savedAt - a.savedAt);
16
+ return sorted[0].data;
17
+ }
18
+ clone() {
19
+ const clone = new Map();
20
+ for (const [key, value] of this.data) {
21
+ clone.set(key, value);
22
+ }
23
+ return new Collection(clone);
24
+ }
25
+ merge(other) {
26
+ const merge = new Map();
27
+ for (const [key, value] of this.data) {
28
+ merge.set(key, value);
29
+ }
30
+ for (const [key, value] of other.data) {
31
+ merge.set(key, value);
32
+ }
33
+ return new Collection(merge);
34
+ }
35
+ delete(id) {
36
+ this.data.delete(id);
37
+ }
38
+ get(id) {
39
+ return this.data.get(id)?.data;
40
+ }
41
+ getAll() {
42
+ return [...this.data.entries()].map(([id, data]) => data.data);
43
+ }
44
+ save(id, data) {
45
+ const now = process.hrtime();
46
+ const total = now[0] * 1e9 + now[1];
47
+ this.data.set(id, { savedAt: total, data });
48
+ }
49
+ toPretty() {
50
+ return [...this.data.entries()]
51
+ .map(function collectionStringifier([id, data]) {
52
+ return `\t\t"${id}": ${JSON.stringify(data.data)}`;
53
+ })
54
+ .join(",\n");
55
+ }
56
+ }
57
+ exports.Collection = Collection;
58
+ //# sourceMappingURL=in-memory.collection.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"in-memory.collection.js","sourceRoot":"","sources":["../../src/store/in-memory.collection.ts"],"names":[],"mappings":";;;AAAA,MAAa,UAAU;IAEX;IADV,YACU,OAAoD,IAAI,GAAG,EAAE;QAA7D,SAAI,GAAJ,IAAI,CAAyD;IACpE,CAAC;IAEJ,KAAK;QACH,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;IACpB,CAAC;IAED,iBAAiB,CAAC,EAAU;QAC1B,MAAM,IAAI,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QACrC,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;QACpD,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC;QAC5D,OAAO,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACxB,CAAC;IAED,KAAK;QACH,MAAM,KAAK,GAAG,IAAI,GAAG,EAAE,CAAC;QACxB,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,IAAI,CAAC,IAAI,EAAE;YACpC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;SACvB;QACD,OAAO,IAAI,UAAU,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;IAED,KAAK,CAAC,KAAiB;QACrB,MAAM,KAAK,GAAG,IAAI,GAAG,EAAE,CAAC;QACxB,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,IAAI,CAAC,IAAI,EAAE;YACpC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;SACvB;QACD,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,KAAK,CAAC,IAAI,EAAE;YACrC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;SACvB;QACD,OAAO,IAAI,UAAU,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;IAED,MAAM,CAAC,EAAU;QACf,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IACvB,CAAC;IAED,GAAG,CAAC,EAAU;QACZ,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC;IACjC,CAAC;IAED,MAAM;QACJ,OAAO,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACjE,CAAC;IAED,IAAI,CAAC,EAAU,EAAE,IAAS;QACxB,MAAM,GAAG,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;QAC7B,MAAM,KAAK,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;QACpC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IAC9C,CAAC;IAED,QAAQ;QACN,OAAO,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;aAC5B,GAAG,CAAC,SAAS,qBAAqB,CAAC,CAAC,EAAE,EAAE,IAAI,CAAC;YAC5C,OAAO,QAAQ,EAAE,MAAM,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QACrD,CAAC,CAAC;aACD,IAAI,CAAC,KAAK,CAAC,CAAC;IACjB,CAAC;CACF;AA5DD,gCA4DC"}
@@ -0,0 +1,17 @@
1
+ import { Storage } from "./in-memory.storage";
2
+ export type InMemoryTransaction = string;
3
+ export declare class InMemoryDatabase {
4
+ private storage;
5
+ private transactions;
6
+ getStorage(trx?: InMemoryTransaction): Storage;
7
+ clear(collectionName: string): void;
8
+ load(collectionName: string, id: string, trx?: InMemoryTransaction): any;
9
+ delete(collectionName: string, id: string): void;
10
+ loadAll(collectionName: string, trx?: InMemoryTransaction): any[];
11
+ loadLatestSnapshot(id: string): any;
12
+ save(collectionName: string, id: string, data: any, trx?: InMemoryTransaction): void;
13
+ transactionally(fn: (trx: InMemoryTransaction) => any): Promise<any>;
14
+ private commit;
15
+ print(): void;
16
+ }
17
+ //# sourceMappingURL=in-memory.database.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"in-memory.database.d.ts","sourceRoot":"","sources":["../../src/store/in-memory.database.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAE9C,MAAM,MAAM,mBAAmB,GAAG,MAAM,CAAC;AAEzC,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,OAAO,CAAiB;IAChC,OAAO,CAAC,YAAY,CAA2C;IAE/D,UAAU,CAAC,GAAG,CAAC,EAAE,mBAAmB;IAWpC,KAAK,CAAC,cAAc,EAAE,MAAM;IAI5B,IAAI,CAAC,cAAc,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,mBAAmB,GAAG,GAAG;IAIxE,MAAM,CAAC,cAAc,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,GAAG,IAAI;IAKhD,OAAO,CAAC,cAAc,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,mBAAmB,GAAG,GAAG,EAAE;IAIjE,kBAAkB,CAAC,EAAE,EAAE,MAAM;IAI7B,IAAI,CACF,cAAc,EAAE,MAAM,EACtB,EAAE,EAAE,MAAM,EACV,IAAI,EAAE,GAAG,EACT,GAAG,CAAC,EAAE,mBAAmB,GACxB,IAAI;IAcD,eAAe,CAAC,EAAE,EAAE,CAAC,GAAG,EAAE,mBAAmB,KAAK,GAAG;IA0B3D,OAAO,CAAC,MAAM;IAUd,KAAK;CAaN"}
@@ -0,0 +1,86 @@
1
+ "use strict";
2
+ // type Collection = Map<string, any>;
3
+ // type Storage = Map<string, Collection>;
4
+ Object.defineProperty(exports, "__esModule", { value: true });
5
+ exports.InMemoryDatabase = void 0;
6
+ const in_memory_storage_1 = require("./in-memory.storage");
7
+ class InMemoryDatabase {
8
+ storage = new in_memory_storage_1.Storage();
9
+ transactions = new Map();
10
+ getStorage(trx) {
11
+ if (trx) {
12
+ const storage = this.transactions.get(trx);
13
+ if (!storage) {
14
+ throw new Error(`Transaction "${trx}" not found`);
15
+ }
16
+ return storage;
17
+ }
18
+ return this.storage;
19
+ }
20
+ clear(collectionName) {
21
+ this.storage.getCollection(collectionName).clear();
22
+ }
23
+ load(collectionName, id, trx) {
24
+ return this.getStorage(trx).getCollection(collectionName).get(id);
25
+ }
26
+ delete(collectionName, id) {
27
+ // TODO: implement transactional delete
28
+ this.storage.getCollection(collectionName).delete(id);
29
+ }
30
+ loadAll(collectionName, trx) {
31
+ return this.getStorage(trx).getCollection(collectionName).getAll();
32
+ }
33
+ loadLatestSnapshot(id) {
34
+ return this.storage.getCollection("snapshots").getLatestSnapshot(id);
35
+ }
36
+ save(collectionName, id, data, trx) {
37
+ const globalStorage = this.storage;
38
+ const targetStorage = this.getStorage(trx);
39
+ if (globalStorage.getCollection(collectionName).get(id) !==
40
+ targetStorage.getCollection(collectionName).get(id)) {
41
+ throw new Error(`Write collision detected for key "${id}"`);
42
+ }
43
+ targetStorage.getCollection(collectionName).save(id, data);
44
+ }
45
+ async transactionally(fn) {
46
+ let trx = Math.random().toString().substring(2);
47
+ const snapshot = this.storage.clone();
48
+ this.transactions.set(trx, snapshot);
49
+ let retry = 5;
50
+ let latestReturnValue = undefined;
51
+ while (retry--) {
52
+ try {
53
+ latestReturnValue = await fn(trx);
54
+ this.commit(trx);
55
+ break;
56
+ }
57
+ catch (error) {
58
+ console.error(error);
59
+ this.transactions.set(trx, this.storage.clone());
60
+ }
61
+ }
62
+ if (retry === -1) {
63
+ throw new Error("failed to execute transaction after 5 retries");
64
+ }
65
+ return latestReturnValue;
66
+ }
67
+ commit(trx) {
68
+ const snapshot = this.transactions.get(trx);
69
+ if (!snapshot) {
70
+ throw new Error(`Transaction "${trx}" not found`);
71
+ }
72
+ this.storage = this.storage.clone().merge(snapshot);
73
+ this.transactions.delete(trx);
74
+ }
75
+ print() {
76
+ console.log([
77
+ "Database:",
78
+ this.storage.toPretty(),
79
+ "",
80
+ "Transactions:",
81
+ ...[...this.transactions.entries()].map(([trx, storage]) => `\t${trx}: ${storage.toPretty()}`),
82
+ ].join("\n"));
83
+ }
84
+ }
85
+ exports.InMemoryDatabase = InMemoryDatabase;
86
+ //# sourceMappingURL=in-memory.database.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"in-memory.database.js","sourceRoot":"","sources":["../../src/store/in-memory.database.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ import { Collection } from "./in-memory.collection";
2
+ export declare class Storage {
3
+ private collections;
4
+ constructor(collections?: Map<string, Collection>);
5
+ clone(): Storage;
6
+ merge(other: Storage): Storage;
7
+ getCollection(collectionName: string): Collection;
8
+ toPretty(): string;
9
+ }
10
+ //# sourceMappingURL=in-memory.storage.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"in-memory.storage.d.ts","sourceRoot":"","sources":["../../src/store/in-memory.storage.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAEpD,qBAAa,OAAO;IACN,OAAO,CAAC,WAAW;gBAAX,WAAW,GAAE,GAAG,CAAC,MAAM,EAAE,UAAU,CAAa;IAEpE,KAAK;IASL,KAAK,CAAC,KAAK,EAAE,OAAO;IAWpB,aAAa,CAAC,cAAc,EAAE,MAAM,GAAG,UAAU;IAMjD,QAAQ;CAUT"}
@@ -0,0 +1,41 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Storage = void 0;
4
+ const in_memory_collection_1 = require("./in-memory.collection");
5
+ class Storage {
6
+ collections;
7
+ constructor(collections = new Map()) {
8
+ this.collections = collections;
9
+ }
10
+ clone() {
11
+ const clone = new Map();
12
+ for (const [collectionName, collection] of this.collections) {
13
+ clone.set(collectionName, collection.clone());
14
+ }
15
+ return new Storage(clone);
16
+ }
17
+ merge(other) {
18
+ const collections = new Map();
19
+ for (const [collectionName, collection] of other.collections) {
20
+ collections.set(collectionName, this.getCollection(collectionName).merge(collection));
21
+ }
22
+ return new Storage(collections);
23
+ }
24
+ getCollection(collectionName) {
25
+ const collection = this.collections.get(collectionName) || new in_memory_collection_1.Collection();
26
+ this.collections.set(collectionName, collection);
27
+ return collection;
28
+ }
29
+ toPretty() {
30
+ return [...this.collections.entries()]
31
+ .map(([collectionName, collection]) => {
32
+ return [
33
+ 'Collection: "' + collectionName + '"',
34
+ collection.toPretty(),
35
+ ].join("\n");
36
+ })
37
+ .join("\n");
38
+ }
39
+ }
40
+ exports.Storage = Storage;
41
+ //# sourceMappingURL=in-memory.storage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"in-memory.storage.js","sourceRoot":"","sources":["../../src/store/in-memory.storage.ts"],"names":[],"mappings":";;;AAAA,iEAAoD;AAEpD,MAAa,OAAO;IACE;IAApB,YAAoB,cAAuC,IAAI,GAAG,EAAE;QAAhD,gBAAW,GAAX,WAAW,CAAqC;IAAG,CAAC;IAExE,KAAK;QACH,MAAM,KAAK,GAAG,IAAI,GAAG,EAAsB,CAAC;QAC5C,KAAK,MAAM,CAAC,cAAc,EAAE,UAAU,CAAC,IAAI,IAAI,CAAC,WAAW,EAAE;YAC3D,KAAK,CAAC,GAAG,CAAC,cAAc,EAAE,UAAU,CAAC,KAAK,EAAE,CAAC,CAAC;SAC/C;QAED,OAAO,IAAI,OAAO,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAED,KAAK,CAAC,KAAc;QAClB,MAAM,WAAW,GAAG,IAAI,GAAG,EAAsB,CAAC;QAClD,KAAK,MAAM,CAAC,cAAc,EAAE,UAAU,CAAC,IAAI,KAAK,CAAC,WAAW,EAAE;YAC5D,WAAW,CAAC,GAAG,CACb,cAAc,EACd,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,CACrD,CAAC;SACH;QACD,OAAO,IAAI,OAAO,CAAC,WAAW,CAAC,CAAC;IAClC,CAAC;IAED,aAAa,CAAC,cAAsB;QAClC,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,cAAc,CAAC,IAAI,IAAI,iCAAU,EAAE,CAAC;QAC5E,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,cAAc,EAAE,UAAU,CAAC,CAAC;QACjD,OAAO,UAAU,CAAC;IACpB,CAAC;IAED,QAAQ;QACN,OAAO,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;aACnC,GAAG,CAAC,CAAC,CAAC,cAAc,EAAE,UAAU,CAAC,EAAE,EAAE;YACpC,OAAO;gBACL,eAAe,GAAG,cAAc,GAAG,GAAG;gBACtC,UAAU,CAAC,QAAQ,EAAE;aACtB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACf,CAAC,CAAC;aACD,IAAI,CAAC,IAAI,CAAC,CAAC;IAChB,CAAC;CACF;AAvCD,0BAuCC"}
@@ -0,0 +1,14 @@
1
+ import { AbstractConstructor } from "@ddd-ts/event-sourcing";
2
+ import { Serializer, Store } from "@ddd-ts/model";
3
+ import { InMemoryDatabase } from "./in-memory.database";
4
+ /**
5
+ * This in memory store is a copy store. It stores a copy of the actual model.
6
+ * It is the recommended inmemory store to use, as it reflects more closely the behaviour of a real store.
7
+ */
8
+ export declare function InMemoryStore<Model, Id extends {
9
+ toString(): string;
10
+ }>(collection: string): AbstractConstructor<Store<Model, Id>, [
11
+ InMemoryDatabase,
12
+ Serializer<Model>
13
+ ]>;
14
+ //# sourceMappingURL=in-memory.store.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"in-memory.store.d.ts","sourceRoot":"","sources":["../../src/store/in-memory.store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAC7D,OAAO,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAClD,OAAO,EAAE,gBAAgB,EAAuB,MAAM,sBAAsB,CAAC;AAE7E;;;GAGG;AACH,wBAAgB,aAAa,CAAC,KAAK,EAAE,EAAE,SAAS;IAAE,QAAQ,IAAI,MAAM,CAAA;CAAE,EACpE,UAAU,EAAE,MAAM,GACjB,mBAAmB,CACpB,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,EAChB;IAAC,gBAAgB;IAAE,UAAU,CAAC,KAAK,CAAC;CAAC,CACtC,CAiDA"}
@@ -0,0 +1,41 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.InMemoryStore = void 0;
4
+ /**
5
+ * This in memory store is a copy store. It stores a copy of the actual model.
6
+ * It is the recommended inmemory store to use, as it reflects more closely the behaviour of a real store.
7
+ */
8
+ function InMemoryStore(collection) {
9
+ class InMemoryStore {
10
+ database;
11
+ serializer;
12
+ constructor(database, serializer) {
13
+ this.database = database;
14
+ this.serializer = serializer;
15
+ }
16
+ clear() {
17
+ this.database.clear(collection);
18
+ }
19
+ async save(model, trx) {
20
+ const serialized = this.serializer.serialize(model);
21
+ await this.database.save(collection, serialized.id, this.serializer.serialize(model), trx);
22
+ }
23
+ async load(id, trx) {
24
+ const serialized = await this.database.load(collection, id.toString(), trx);
25
+ if (!serialized) {
26
+ return undefined;
27
+ }
28
+ return this.serializer.deserialize(serialized);
29
+ }
30
+ loadAll() {
31
+ const serialized = this.database.loadAll(collection);
32
+ return Promise.resolve(serialized.map((s) => this.serializer.deserialize(s)));
33
+ }
34
+ async delete(id) {
35
+ this.database.delete(collection, id.toString());
36
+ }
37
+ }
38
+ return InMemoryStore;
39
+ }
40
+ exports.InMemoryStore = InMemoryStore;
41
+ //# sourceMappingURL=in-memory.store.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"in-memory.store.js","sourceRoot":"","sources":["../../src/store/in-memory.store.ts"],"names":[],"mappings":";;;AAIA;;;GAGG;AACH,SAAgB,aAAa,CAC3B,UAAkB;IAKlB,MAAe,aAAa;QAER;QACC;QAFnB,YACkB,QAA0B,EACzB,UAA6B;YAD9B,aAAQ,GAAR,QAAQ,CAAkB;YACzB,eAAU,GAAV,UAAU,CAAmB;QAC7C,CAAC;QAEJ,KAAK;YACH,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QAClC,CAAC;QAED,KAAK,CAAC,IAAI,CAAC,KAAY,EAAE,GAAyB;YAChD,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;YACpD,MAAM,IAAI,CAAC,QAAQ,CAAC,IAAI,CACtB,UAAU,EACV,UAAU,CAAC,EAAE,EACb,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,KAAK,CAAC,EAChC,GAAG,CACJ,CAAC;QACJ,CAAC;QAED,KAAK,CAAC,IAAI,CAAC,EAAM,EAAE,GAAyB;YAC1C,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,IAAI,CACzC,UAAU,EACV,EAAE,CAAC,QAAQ,EAAE,EACb,GAAG,CACJ,CAAC;YAEF,IAAI,CAAC,UAAU,EAAE;gBACf,OAAO,SAAS,CAAC;aAClB;YAED,OAAO,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;QACjD,CAAC;QAED,OAAO;YACL,MAAM,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;YAErD,OAAO,OAAO,CAAC,OAAO,CACpB,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CACtD,CAAC;QACJ,CAAC;QAED,KAAK,CAAC,MAAM,CAAC,EAAM;YACjB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,UAAU,EAAE,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC;QAClD,CAAC;KACF;IAED,OAAO,aAAa,CAAC;AACvB,CAAC;AAtDD,sCAsDC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=bank.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bank.spec.d.ts","sourceRoot":"","sources":["../../src/test/bank.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const event_sourcing_1 = require("@ddd-ts/event-sourcing");
4
+ const tests_1 = require("@ddd-ts/tests");
5
+ const __1 = require("..");
6
+ const in_memory_snapshotter_1 = require("../in-memory.snapshotter");
7
+ describe("EventSourcingInMemory", () => {
8
+ const es = new __1.InMemoryEventStore();
9
+ const database = new __1.InMemoryDatabase();
10
+ const checkpoint = new __1.InMemoryCheckpoint(database);
11
+ const transaction = new __1.InMemoryTransactionPerformer(database);
12
+ (0, tests_1.BankSuite)(es, checkpoint, transaction, (serializer, name) => {
13
+ const Store = class extends (0, __1.InMemoryStore)(name) {
14
+ };
15
+ const store = new Store(database, serializer);
16
+ return store;
17
+ }, (AGGREGATE, serializer) => {
18
+ const persistor = class extends (0, event_sourcing_1.EsAggregatePersistorWithSnapshots)(AGGREGATE) {
19
+ };
20
+ const snapshotter = new in_memory_snapshotter_1.InMemorySnapshotter(database, serializer);
21
+ return new persistor(es, snapshotter);
22
+ });
23
+ });
24
+ //# sourceMappingURL=bank.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bank.spec.js","sourceRoot":"","sources":["../../src/test/bank.spec.ts"],"names":[],"mappings":";;AAAA,2DAA2E;AAC3E,yCAA0C;AAC1C,0BAMY;AACZ,oEAA+D;AAE/D,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,MAAM,EAAE,GAAG,IAAI,sBAAkB,EAAE,CAAC;IACpC,MAAM,QAAQ,GAAG,IAAI,oBAAgB,EAAE,CAAC;IACxC,MAAM,UAAU,GAAG,IAAI,sBAAkB,CAAC,QAAQ,CAAC,CAAC;IACpD,MAAM,WAAW,GAAG,IAAI,gCAA4B,CAAC,QAAQ,CAAC,CAAC;IAE/D,IAAA,iBAAS,EACP,EAAE,EACF,UAAU,EACV,WAAW,EACX,CAAC,UAAU,EAAE,IAAI,EAAE,EAAE;QACnB,MAAM,KAAK,GAAG,KAAM,SAAQ,IAAA,iBAAa,EAAC,IAAI,CAAC;SAAG,CAAC;QACnD,MAAM,KAAK,GAAG,IAAI,KAAK,CAAC,QAAQ,EAAE,UAAU,CAAQ,CAAC;QACrD,OAAO,KAAK,CAAC;IACf,CAAC,EACD,CAAC,SAAS,EAAE,UAAU,EAAE,EAAE;QACxB,MAAM,SAAS,GAAG,KAAM,SAAQ,IAAA,kDAAiC,EAC/D,SAAS,CACV;SAAG,CAAC;QACL,MAAM,WAAW,GAAG,IAAI,2CAAmB,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;QAClE,OAAO,IAAI,SAAS,CAAC,EAAE,EAAE,WAAW,CAAC,CAAC;IACxC,CAAC,CACF,CAAC;AACJ,CAAC,CAAC,CAAC"}
package/package.json ADDED
@@ -0,0 +1,19 @@
1
+ {
2
+ "name": "@ddd-ts/event-sourcing-inmemory",
3
+ "version": "0.0.0-feat.alpha.045d9c5",
4
+ "main": "dist/index.js",
5
+ "types": "dist/index.d.ts",
6
+ "license": "MIT",
7
+ "scripts": {
8
+ "test": "test-runner",
9
+ "build": "builder"
10
+ },
11
+ "dependencies": {
12
+ "@ddd-ts/event-sourcing": "*",
13
+ "@ddd-ts/model": "*"
14
+ },
15
+ "devDependencies": {
16
+ "@ddd-ts/dev": "*",
17
+ "@ddd-ts/tests": "*"
18
+ }
19
+ }