@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.
- package/dist/event-store/in-memory.event-store.d.ts +33 -0
- package/dist/event-store/in-memory.event-store.d.ts.map +1 -0
- package/dist/event-store/in-memory.event-store.js +99 -0
- package/dist/event-store/in-memory.event-store.js.map +1 -0
- package/dist/event-store/in-memory.event-store.spec.d.ts +2 -0
- package/dist/event-store/in-memory.event-store.spec.d.ts.map +1 -0
- package/dist/event-store/in-memory.event-store.spec.js +8 -0
- package/dist/event-store/in-memory.event-store.spec.js.map +1 -0
- package/dist/event-store/projected-stream.d.ts +26 -0
- package/dist/event-store/projected-stream.d.ts.map +1 -0
- package/dist/event-store/projected-stream.js +61 -0
- package/dist/event-store/projected-stream.js.map +1 -0
- package/dist/event-store/stream.d.ts +13 -0
- package/dist/event-store/stream.d.ts.map +1 -0
- package/dist/event-store/stream.js +34 -0
- package/dist/event-store/stream.js.map +1 -0
- package/dist/in-memory.checkpoint.d.ts +11 -0
- package/dist/in-memory.checkpoint.d.ts.map +1 -0
- package/dist/in-memory.checkpoint.js +31 -0
- package/dist/in-memory.checkpoint.js.map +1 -0
- package/dist/in-memory.snapshotter.d.ts +11 -0
- package/dist/in-memory.snapshotter.d.ts.map +1 -0
- package/dist/in-memory.snapshotter.js +30 -0
- package/dist/in-memory.snapshotter.js.map +1 -0
- package/dist/in-memory.transaction-performer.d.ts +6 -0
- package/dist/in-memory.transaction-performer.d.ts.map +1 -0
- package/dist/in-memory.transaction-performer.js +11 -0
- package/dist/in-memory.transaction-performer.js.map +1 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +16 -0
- package/dist/index.js.map +1 -0
- package/dist/store/in-memory.collection.d.ts +17 -0
- package/dist/store/in-memory.collection.d.ts.map +1 -0
- package/dist/store/in-memory.collection.js +58 -0
- package/dist/store/in-memory.collection.js.map +1 -0
- package/dist/store/in-memory.database.d.ts +17 -0
- package/dist/store/in-memory.database.d.ts.map +1 -0
- package/dist/store/in-memory.database.js +86 -0
- package/dist/store/in-memory.database.js.map +1 -0
- package/dist/store/in-memory.storage.d.ts +10 -0
- package/dist/store/in-memory.storage.d.ts.map +1 -0
- package/dist/store/in-memory.storage.js +41 -0
- package/dist/store/in-memory.storage.js.map +1 -0
- package/dist/store/in-memory.store.d.ts +14 -0
- package/dist/store/in-memory.store.d.ts.map +1 -0
- package/dist/store/in-memory.store.js +41 -0
- package/dist/store/in-memory.store.js.map +1 -0
- package/dist/test/bank.spec.d.ts +2 -0
- package/dist/test/bank.spec.d.ts.map +1 -0
- package/dist/test/bank.spec.js +24 -0
- package/dist/test/bank.spec.js.map +1 -0
- 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 @@
|
|
|
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"}
|
package/dist/index.d.ts
ADDED
|
@@ -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 @@
|
|
|
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
|
+
}
|