@rkrkdldkd/example-event-sourcing 0.0.4 → 0.0.6
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/app.module.js +12 -3
- package/dist/app.module.js.map +1 -1
- package/dist/common/constants.d.ts +1 -0
- package/dist/common/constants.js +2 -1
- package/dist/common/constants.js.map +1 -1
- package/dist/decorator/aggregate-event-repository.decorator.d.ts +1 -0
- package/dist/decorator/aggregate-event-repository.decorator.js +13 -0
- package/dist/decorator/aggregate-event-repository.decorator.js.map +1 -0
- package/dist/decorator/aggregate.decorator.js +1 -1
- package/dist/decorator/aggregate.decorator.js.map +1 -1
- package/dist/decorator/event-handler.decorator.js +2 -2
- package/dist/decorator/event-handler.decorator.js.map +1 -1
- package/dist/decorator/event.decorator.js +1 -1
- package/dist/decorator/event.decorator.js.map +1 -1
- package/dist/decorator/index.d.ts +4 -1
- package/dist/decorator/index.js +18 -0
- package/dist/decorator/index.js.map +1 -1
- package/dist/event-sourcing.module.d.ts +8 -3
- package/dist/event-sourcing.module.js +50 -5
- package/dist/event-sourcing.module.js.map +1 -1
- package/dist/helper/metadata/get-aggregate-metadata.js +2 -2
- package/dist/helper/metadata/get-aggregate-metadata.js.map +1 -1
- package/dist/helper/metadata/get-event-handler-metadata.js +3 -3
- package/dist/helper/metadata/get-event-handler-metadata.js.map +1 -1
- package/dist/helper/metadata/get-event-metadata.js +1 -1
- package/dist/helper/metadata/get-event-metadata.js.map +1 -1
- package/dist/index.d.ts +7 -10
- package/dist/index.js +7 -10
- package/dist/index.js.map +1 -1
- package/dist/interface/event/event-envelope-metadata.interface.d.ts +2 -1
- package/dist/interface/postgres-event.entity.d.ts +11 -0
- package/dist/interface/postgres-event.entity.js +3 -0
- package/dist/interface/postgres-event.entity.js.map +1 -0
- package/dist/main.js +3 -0
- package/dist/main.js.map +1 -1
- package/dist/model/abstract.repository.d.ts +13 -0
- package/dist/model/abstract.repository.js +108 -0
- package/dist/model/abstract.repository.js.map +1 -0
- package/dist/model/aggregate.root.js +1 -1
- package/dist/model/aggregate.root.js.map +1 -1
- package/dist/model/db/db.client.d.ts +9 -0
- package/dist/model/db/db.client.js +37 -0
- package/dist/model/db/db.client.js.map +1 -0
- package/dist/model/event-envelope.d.ts +1 -3
- package/dist/model/event-envelope.js +0 -5
- package/dist/model/event-envelope.js.map +1 -1
- package/dist/model/index.d.ts +4 -0
- package/dist/model/index.js +21 -0
- package/dist/model/index.js.map +1 -0
- package/dist/model/temp.repository.d.ts +3 -0
- package/dist/model/temp.repository.js +18 -0
- package/dist/model/temp.repository.js.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/package.json +27 -24
package/dist/app.module.js
CHANGED
|
@@ -8,17 +8,26 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
8
8
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
9
|
exports.AppModule = void 0;
|
|
10
10
|
const common_1 = require("@nestjs/common");
|
|
11
|
+
const event_sourcing_module_1 = require("src/event-sourcing.module");
|
|
12
|
+
const temp_repository_1 = require("src/model/temp.repository");
|
|
11
13
|
const app_controller_1 = require("./app.controller");
|
|
12
14
|
const app_service_1 = require("./app.service");
|
|
13
|
-
const event_sourcing_module_1 = require("src/event-sourcing.module");
|
|
14
15
|
let AppModule = class AppModule {
|
|
15
16
|
};
|
|
16
17
|
exports.AppModule = AppModule;
|
|
17
18
|
exports.AppModule = AppModule = __decorate([
|
|
18
19
|
(0, common_1.Module)({
|
|
19
|
-
imports: [
|
|
20
|
+
imports: [
|
|
21
|
+
event_sourcing_module_1.EventSourcingModule.forRootAsync({
|
|
22
|
+
host: '127.0.0.1',
|
|
23
|
+
port: 5432,
|
|
24
|
+
user: 'postgres',
|
|
25
|
+
password: 'postgres',
|
|
26
|
+
database: 'postgres',
|
|
27
|
+
}),
|
|
28
|
+
],
|
|
20
29
|
controllers: [app_controller_1.AppController],
|
|
21
|
-
providers: [app_service_1.AppService],
|
|
30
|
+
providers: [app_service_1.AppService, temp_repository_1.ARepository],
|
|
22
31
|
})
|
|
23
32
|
], AppModule);
|
|
24
33
|
//# sourceMappingURL=app.module.js.map
|
package/dist/app.module.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"app.module.js","sourceRoot":"","sources":["../src/app.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,qDAAiD;AACjD,+CAA2C;
|
|
1
|
+
{"version":3,"file":"app.module.js","sourceRoot":"","sources":["../src/app.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,qEAAgE;AAChE,+DAAwD;AACxD,qDAAiD;AACjD,+CAA2C;AAepC,IAAM,SAAS,GAAf,MAAM,SAAS;CAAG,CAAA;AAAZ,8BAAS;oBAAT,SAAS;IAbrB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,2CAAmB,CAAC,YAAY,CAAC;gBAC/B,IAAI,EAAE,WAAW;gBACjB,IAAI,EAAE,IAAI;gBACV,IAAI,EAAE,UAAU;gBAChB,QAAQ,EAAE,UAAU;gBACpB,QAAQ,EAAE,UAAU;aACrB,CAAC;SACH;QACD,WAAW,EAAE,CAAC,8BAAa,CAAC;QAC5B,SAAS,EAAE,CAAC,wBAAU,EAAE,6BAAW,CAAC;KACrC,CAAC;GACW,SAAS,CAAG"}
|
|
@@ -10,3 +10,4 @@ export declare const EVENT_SUBSCRIBER_METADATA = "EVENT_SUBSCRIBER_METADATA";
|
|
|
10
10
|
export declare const QUERY_HANDLER_METADATA = "QUERY_HANDLER_METADATA";
|
|
11
11
|
export declare const QUERY_METADATA = "QUERY_METADATA";
|
|
12
12
|
export declare const SNAPSHOT_METADATA = "SNAPSHOT_METADATA";
|
|
13
|
+
export declare const AGGREGATE_EVENT_REPOSITORY_METADATA = "AGGREGATE_EVENT_REPOSITORY_METADATA";
|
package/dist/common/constants.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.SNAPSHOT_METADATA = exports.QUERY_METADATA = exports.QUERY_HANDLER_METADATA = exports.EVENT_SUBSCRIBER_METADATA = exports.EVENT_SERIALIZER_METADATA = exports.EVENT_PUBLISHER_METADATA = exports.EVENT_HANDLER_METADATA = exports.EVENT_METADATA = exports.COMMAND_METADATA = exports.COMMAND_HANDLER_METADATA = exports.AGGREGATE_METADATA = exports.EVENT_SOURCING_OPTIONS = void 0;
|
|
3
|
+
exports.AGGREGATE_EVENT_REPOSITORY_METADATA = exports.SNAPSHOT_METADATA = exports.QUERY_METADATA = exports.QUERY_HANDLER_METADATA = exports.EVENT_SUBSCRIBER_METADATA = exports.EVENT_SERIALIZER_METADATA = exports.EVENT_PUBLISHER_METADATA = exports.EVENT_HANDLER_METADATA = exports.EVENT_METADATA = exports.COMMAND_METADATA = exports.COMMAND_HANDLER_METADATA = exports.AGGREGATE_METADATA = exports.EVENT_SOURCING_OPTIONS = void 0;
|
|
4
4
|
exports.EVENT_SOURCING_OPTIONS = Symbol();
|
|
5
5
|
exports.AGGREGATE_METADATA = 'AGGREGATE_METADATA';
|
|
6
6
|
exports.COMMAND_HANDLER_METADATA = 'COMMAND_HANDLER_METADATA';
|
|
@@ -13,4 +13,5 @@ exports.EVENT_SUBSCRIBER_METADATA = 'EVENT_SUBSCRIBER_METADATA';
|
|
|
13
13
|
exports.QUERY_HANDLER_METADATA = 'QUERY_HANDLER_METADATA';
|
|
14
14
|
exports.QUERY_METADATA = 'QUERY_METADATA';
|
|
15
15
|
exports.SNAPSHOT_METADATA = 'SNAPSHOT_METADATA';
|
|
16
|
+
exports.AGGREGATE_EVENT_REPOSITORY_METADATA = 'AGGREGATE_EVENT_REPOSITORY_METADATA';
|
|
16
17
|
//# sourceMappingURL=constants.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../src/common/constants.ts"],"names":[],"mappings":";;;AAAa,QAAA,sBAAsB,GAAG,MAAM,EAAE,CAAC;AAElC,QAAA,kBAAkB,GAAG,oBAAoB,CAAC;AAC1C,QAAA,wBAAwB,GAAG,0BAA0B,CAAC;AACtD,QAAA,gBAAgB,GAAG,kBAAkB,CAAC;AACtC,QAAA,cAAc,GAAG,gBAAgB,CAAC;AAClC,QAAA,sBAAsB,GAAG,wBAAwB,CAAC;AAClD,QAAA,wBAAwB,GAAG,0BAA0B,CAAC;AACtD,QAAA,yBAAyB,GAAG,2BAA2B,CAAC;AACxD,QAAA,yBAAyB,GAAG,2BAA2B,CAAC;AACxD,QAAA,sBAAsB,GAAG,wBAAwB,CAAC;AAClD,QAAA,cAAc,GAAG,gBAAgB,CAAC;AAClC,QAAA,iBAAiB,GAAG,mBAAmB,CAAC"}
|
|
1
|
+
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../src/common/constants.ts"],"names":[],"mappings":";;;AAAa,QAAA,sBAAsB,GAAG,MAAM,EAAE,CAAC;AAElC,QAAA,kBAAkB,GAAG,oBAAoB,CAAC;AAC1C,QAAA,wBAAwB,GAAG,0BAA0B,CAAC;AACtD,QAAA,gBAAgB,GAAG,kBAAkB,CAAC;AACtC,QAAA,cAAc,GAAG,gBAAgB,CAAC;AAClC,QAAA,sBAAsB,GAAG,wBAAwB,CAAC;AAClD,QAAA,wBAAwB,GAAG,0BAA0B,CAAC;AACtD,QAAA,yBAAyB,GAAG,2BAA2B,CAAC;AACxD,QAAA,yBAAyB,GAAG,2BAA2B,CAAC;AACxD,QAAA,sBAAsB,GAAG,wBAAwB,CAAC;AAClD,QAAA,cAAc,GAAG,gBAAgB,CAAC;AAClC,QAAA,iBAAiB,GAAG,mBAAmB,CAAC;AAExC,QAAA,mCAAmC,GAC9C,qCAAqC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const AggregateEventRepository: (name2: string) => ClassDecorator;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AggregateEventRepository = void 0;
|
|
4
|
+
const constants_1 = require("../common/constants");
|
|
5
|
+
const AggregateEventRepository = (name2) => {
|
|
6
|
+
return (target) => {
|
|
7
|
+
console.log(name2);
|
|
8
|
+
const { name } = target;
|
|
9
|
+
Reflect.defineMetadata(constants_1.AGGREGATE_EVENT_REPOSITORY_METADATA, name, target);
|
|
10
|
+
};
|
|
11
|
+
};
|
|
12
|
+
exports.AggregateEventRepository = AggregateEventRepository;
|
|
13
|
+
//# sourceMappingURL=aggregate-event-repository.decorator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aggregate-event-repository.decorator.js","sourceRoot":"","sources":["../../src/decorator/aggregate-event-repository.decorator.ts"],"names":[],"mappings":";;;AAAA,mDAA2E;AAIpE,MAAM,wBAAwB,GAAG,CAAC,KAAa,EAAkB,EAAE;IACxE,OAAO,CAAC,MAAc,EAAE,EAAE;QACxB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACnB,MAAM,EAAE,IAAI,EAAE,GAAG,MAAyC,CAAC;QAE3D,OAAO,CAAC,cAAc,CAAC,+CAAmC,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;IAC5E,CAAC,CAAC;AACJ,CAAC,CAAC;AAPW,QAAA,wBAAwB,4BAOnC"}
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.Aggregate = void 0;
|
|
4
4
|
require("reflect-metadata");
|
|
5
|
-
const constants_1 = require("
|
|
5
|
+
const constants_1 = require("../common/constants");
|
|
6
6
|
const Aggregate = (options) => {
|
|
7
7
|
return (target) => {
|
|
8
8
|
const { name } = target;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"aggregate.decorator.js","sourceRoot":"","sources":["../../src/decorator/aggregate.decorator.ts"],"names":[],"mappings":";;;AAAA,4BAA0B;AAC1B,
|
|
1
|
+
{"version":3,"file":"aggregate.decorator.js","sourceRoot":"","sources":["../../src/decorator/aggregate.decorator.ts"],"names":[],"mappings":";;;AAAA,4BAA0B;AAC1B,mDAA0D;AAanD,MAAM,SAAS,GAAG,CAAC,OAA2B,EAAkB,EAAE;IACvE,OAAO,CAAC,MAAc,EAAE,EAAE;QACxB,MAAM,EAAE,IAAI,EAAE,GAAG,MAAyC,CAAC;QAC3D,MAAM,QAAQ,GAAsB;YAClC,UAAU,EAAE,IAAI,CAAC,WAAW,EAAE;YAC9B,GAAG,OAAO;SACX,CAAC;QAEF,IAAI,CAAC,QAAQ,CAAC,UAAU,EAAE,MAAM,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC;YAC5C,MAAM,IAAI,KAAK,CACb,0BAA0B,QAAQ,CAAC,UAAU,gDAAgD,CAC9F,CAAC;QACJ,CAAC;QAED,OAAO,CAAC,cAAc,CAAC,8BAAkB,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;IAC/D,CAAC,CAAC;AACJ,CAAC,CAAC;AAhBW,QAAA,SAAS,aAgBpB"}
|
|
@@ -2,8 +2,8 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.EventHandler = void 0;
|
|
4
4
|
require("reflect-metadata");
|
|
5
|
-
const constants_1 = require("
|
|
6
|
-
const get_event_metadata_1 = require("
|
|
5
|
+
const constants_1 = require("../common/constants");
|
|
6
|
+
const get_event_metadata_1 = require("../helper/metadata/get-event-metadata");
|
|
7
7
|
const EventHandler = (event) => {
|
|
8
8
|
const { name } = (0, get_event_metadata_1.getEventMetadata)(event);
|
|
9
9
|
if (!name) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"event-handler.decorator.js","sourceRoot":"","sources":["../../src/decorator/event-handler.decorator.ts"],"names":[],"mappings":";;;AAAA,4BAA0B;AAC1B,
|
|
1
|
+
{"version":3,"file":"event-handler.decorator.js","sourceRoot":"","sources":["../../src/decorator/event-handler.decorator.ts"],"names":[],"mappings":";;;AAAA,4BAA0B;AAC1B,mDAA8D;AAC9D,8EAA0E;AAUnE,MAAM,YAAY,GAAG,CAC1B,KAA+B,EACZ,EAAE;IACrB,MAAM,EAAE,IAAI,EAAE,GAAG,IAAA,qCAAgB,EAAC,KAAK,CAAC,CAAC;IAEzC,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,MAAM,IAAI,KAAK,CACb,8DAA8D,KAAK,CAAC,WAAW,CAAC,IAAI,IAAI,CACzF,CAAC;IACJ,CAAC;IAED,OAAO,CAAC,cAAc,EAAE,WAAW,EAAE,EAAE;QACrC,OAAO,CAAC,cAAc,CACpB,GAAG,kCAAsB,IAAI,IAAI,EAAE,EACnC,EAAE,MAAM,EAAE,WAAW,EAAE,EACvB,cAAc,CACf,CAAC;IACJ,CAAC,CAAC;AACJ,CAAC,CAAC;AAlBW,QAAA,YAAY,gBAkBvB"}
|
|
@@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.Event = void 0;
|
|
4
4
|
const node_crypto_1 = require("node:crypto");
|
|
5
5
|
require("reflect-metadata");
|
|
6
|
-
const constants_1 = require("
|
|
6
|
+
const constants_1 = require("../common/constants");
|
|
7
7
|
const Event = (name) => {
|
|
8
8
|
return (target) => {
|
|
9
9
|
const metadata = {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"event.decorator.js","sourceRoot":"","sources":["../../src/decorator/event.decorator.ts"],"names":[],"mappings":";;;AAAA,6CAAyC;AACzC,4BAA0B;AAC1B,
|
|
1
|
+
{"version":3,"file":"event.decorator.js","sourceRoot":"","sources":["../../src/decorator/event.decorator.ts"],"names":[],"mappings":";;;AAAA,6CAAyC;AACzC,4BAA0B;AAC1B,mDAAsD;AAe/C,MAAM,KAAK,GAAG,CAAC,IAAa,EAAkB,EAAE;IACrD,OAAO,CAAC,MAAW,EAAE,EAAE;QACrB,MAAM,QAAQ,GAAkB;YAC9B,EAAE,EAAE,IAAA,wBAAU,GAAE;YAChB,IAAI,EAAE,IAAI,IAAI,MAAM,CAAC,IAAI;SAC1B,CAAC;QAEF,IAAI,QAAQ,CAAC,IAAI,CAAC,MAAM,GAAG,EAAE,EAAE,CAAC;YAC9B,MAAM,IAAI,KAAK,CACb,eAAe,QAAQ,CAAC,IAAI,gDAAgD,CAC7E,CAAC;QACJ,CAAC;QAED,OAAO,CAAC,cAAc,CAAC,0BAAc,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;IAC3D,CAAC,CAAC;AACJ,CAAC,CAAC;AAfW,QAAA,KAAK,SAehB"}
|
package/dist/decorator/index.js
CHANGED
|
@@ -1,3 +1,21 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
2
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./aggregate-event-repository.decorator"), exports);
|
|
18
|
+
__exportStar(require("./aggregate.decorator"), exports);
|
|
19
|
+
__exportStar(require("./event-handler.decorator"), exports);
|
|
20
|
+
__exportStar(require("./event.decorator"), exports);
|
|
3
21
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/decorator/index.ts"],"names":[],"mappings":""}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/decorator/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,yEAAuD;AACvD,wDAAsC;AACtC,4DAA0C;AAC1C,oDAAkC"}
|
|
@@ -1,4 +1,9 @@
|
|
|
1
|
-
import { DynamicModule } from '@nestjs/common';
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
import { DynamicModule, OnModuleInit } from '@nestjs/common';
|
|
2
|
+
import { PoolConfig } from 'pg';
|
|
3
|
+
import { DbClient } from './model/db/db.client';
|
|
4
|
+
export declare class EventSourcingModule implements OnModuleInit {
|
|
5
|
+
private readonly dbClient;
|
|
6
|
+
static forRootAsync(config: PoolConfig): DynamicModule;
|
|
7
|
+
constructor(dbClient: DbClient);
|
|
8
|
+
onModuleInit(): Promise<void>;
|
|
4
9
|
}
|
|
@@ -5,30 +5,75 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
5
5
|
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
6
|
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
7
|
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
8
11
|
var EventSourcingModule_1;
|
|
9
12
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
13
|
exports.EventSourcingModule = void 0;
|
|
11
14
|
const common_1 = require("@nestjs/common");
|
|
12
|
-
const
|
|
15
|
+
const core_1 = require("@nestjs/core");
|
|
16
|
+
const constants_1 = require("./common/constants");
|
|
17
|
+
const db_client_1 = require("./model/db/db.client");
|
|
13
18
|
let EventSourcingModule = EventSourcingModule_1 = class EventSourcingModule {
|
|
14
|
-
|
|
19
|
+
dbClient;
|
|
20
|
+
static forRootAsync(config) {
|
|
15
21
|
const providers = [
|
|
16
22
|
{
|
|
17
23
|
provide: constants_1.EVENT_SOURCING_OPTIONS,
|
|
18
|
-
|
|
19
|
-
|
|
24
|
+
useValue: config,
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
provide: db_client_1.DbClient,
|
|
28
|
+
useFactory: (options) => {
|
|
29
|
+
const client = new db_client_1.DbClient(options);
|
|
30
|
+
return client;
|
|
31
|
+
},
|
|
32
|
+
inject: [constants_1.EVENT_SOURCING_OPTIONS],
|
|
20
33
|
},
|
|
21
34
|
];
|
|
22
35
|
return {
|
|
23
36
|
module: EventSourcingModule_1,
|
|
37
|
+
imports: [core_1.DiscoveryModule],
|
|
24
38
|
providers,
|
|
39
|
+
exports: providers,
|
|
25
40
|
};
|
|
26
41
|
}
|
|
42
|
+
constructor(dbClient) {
|
|
43
|
+
this.dbClient = dbClient;
|
|
44
|
+
}
|
|
45
|
+
async onModuleInit() {
|
|
46
|
+
const connection = await this.dbClient.getConnection();
|
|
47
|
+
try {
|
|
48
|
+
await connection.query('BEGIN');
|
|
49
|
+
await this.dbClient.query(`CREATE TABLE IF NOT EXISTS "test_event" (
|
|
50
|
+
stream_id VARCHAR(120) NOT NULL,
|
|
51
|
+
version INT NOT NULL,
|
|
52
|
+
event VARCHAR(80) NOT NULL,
|
|
53
|
+
payload JSONB NOT NULL,
|
|
54
|
+
event_date VARCHAR(7) NOT NULL,
|
|
55
|
+
event_id VARCHAR(40) NOT NULL,
|
|
56
|
+
aggregate_id VARCHAR(40) NOT NULL,
|
|
57
|
+
occurred_on TIMESTAMPTZ NOT NULL,
|
|
58
|
+
correlation_id VARCHAR(255),
|
|
59
|
+
causation_id VARCHAR(255),
|
|
60
|
+
PRIMARY KEY (stream_id, version)
|
|
61
|
+
)`);
|
|
62
|
+
}
|
|
63
|
+
catch (error) {
|
|
64
|
+
await connection.query('ROLLBACK');
|
|
65
|
+
throw error;
|
|
66
|
+
}
|
|
67
|
+
finally {
|
|
68
|
+
connection.release();
|
|
69
|
+
}
|
|
70
|
+
}
|
|
27
71
|
};
|
|
28
72
|
exports.EventSourcingModule = EventSourcingModule;
|
|
29
73
|
exports.EventSourcingModule = EventSourcingModule = EventSourcingModule_1 = __decorate([
|
|
30
74
|
(0, common_1.Module)({
|
|
31
75
|
imports: [],
|
|
32
|
-
})
|
|
76
|
+
}),
|
|
77
|
+
__metadata("design:paramtypes", [db_client_1.DbClient])
|
|
33
78
|
], EventSourcingModule);
|
|
34
79
|
//# sourceMappingURL=event-sourcing.module.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"event-sourcing.module.js","sourceRoot":"","sources":["../src/event-sourcing.module.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"event-sourcing.module.js","sourceRoot":"","sources":["../src/event-sourcing.module.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,2CAA+E;AAC/E,uCAA+C;AAE/C,kDAA8D;AAC9D,oDAAgD;AAKzC,IAAM,mBAAmB,2BAAzB,MAAM,mBAAmB;IAyBD;IAxB7B,MAAM,CAAC,YAAY,CAAC,MAAkB;QACpC,MAAM,SAAS,GAAe;YAC5B;gBACE,OAAO,EAAE,kCAAsB;gBAC/B,QAAQ,EAAE,MAAM;aACjB;YACD;gBACE,OAAO,EAAE,oBAAQ;gBACjB,UAAU,EAAE,CAAC,OAAmB,EAAE,EAAE;oBAClC,MAAM,MAAM,GAAG,IAAI,oBAAQ,CAAC,OAAO,CAAC,CAAC;oBACrC,OAAO,MAAM,CAAC;gBAChB,CAAC;gBACD,MAAM,EAAE,CAAC,kCAAsB,CAAC;aACjC;SACF,CAAC;QAEF,OAAO;YACL,MAAM,EAAE,qBAAmB;YAC3B,OAAO,EAAE,CAAC,sBAAe,CAAC;YAC1B,SAAS;YACT,OAAO,EAAE,SAAS;SACnB,CAAC;IACJ,CAAC;IAED,YAA6B,QAAkB;QAAlB,aAAQ,GAAR,QAAQ,CAAU;IAAG,CAAC;IAEnD,KAAK,CAAC,YAAY;QAChB,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE,CAAC;QAEvD,IAAI,CAAC;YACH,MAAM,UAAU,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YAChC,MAAM,IAAI,CAAC,QAAQ,CAAC,KAAK,CACvB;;;;;;;;;;;;kBAYU,CACX,CAAC;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,UAAU,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;YACnC,MAAM,KAAK,CAAC;QACd,CAAC;gBAAS,CAAC;YACT,UAAU,CAAC,OAAO,EAAE,CAAC;QACvB,CAAC;IACH,CAAC;CACF,CAAA;AAtDY,kDAAmB;8BAAnB,mBAAmB;IAH/B,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,EAAE;KACZ,CAAC;qCA0BuC,oBAAQ;GAzBpC,mBAAmB,CAsD/B"}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.getAggregateMetadata = void 0;
|
|
4
|
-
const constants_1 = require("
|
|
5
|
-
const assume_metadata_type_1 = require("
|
|
4
|
+
const constants_1 = require("../../common/constants");
|
|
5
|
+
const assume_metadata_type_1 = require("./assume-metadata-type");
|
|
6
6
|
const getAggregateMetadata = (cls) => {
|
|
7
7
|
return (0, assume_metadata_type_1.ensureMetadata)(Reflect.getMetadata(constants_1.AGGREGATE_METADATA, cls));
|
|
8
8
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-aggregate-metadata.js","sourceRoot":"","sources":["../../../src/helper/metadata/get-aggregate-metadata.ts"],"names":[],"mappings":";;;AACA,
|
|
1
|
+
{"version":3,"file":"get-aggregate-metadata.js","sourceRoot":"","sources":["../../../src/helper/metadata/get-aggregate-metadata.ts"],"names":[],"mappings":";;;AACA,sDAA0D;AAC1D,iEAA0E;AAInE,MAAM,oBAAoB,GAAG,CAClC,GAAwB,EACO,EAAE;IACjC,OAAO,IAAA,qCAAc,EAAC,OAAO,CAAC,WAAW,CAAC,8BAAkB,EAAE,GAAG,CAAC,CAAC,CAAC;AACtE,CAAC,CAAC;AAJW,QAAA,oBAAoB,wBAI/B"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.getEventHandlerMetadata = void 0;
|
|
4
|
-
const constants_1 = require("
|
|
5
|
-
const assume_metadata_type_1 = require("
|
|
6
|
-
const get_event_metadata_1 = require("
|
|
4
|
+
const constants_1 = require("../../common/constants");
|
|
5
|
+
const assume_metadata_type_1 = require("./assume-metadata-type");
|
|
6
|
+
const get_event_metadata_1 = require("./get-event-metadata");
|
|
7
7
|
const getEventHandlerMetadata = (aggregate, eventClass) => {
|
|
8
8
|
const { name } = (0, get_event_metadata_1.getEventMetadata)(eventClass);
|
|
9
9
|
return (0, assume_metadata_type_1.ensureMetadata)(Reflect.getMetadata(`${constants_1.EVENT_HANDLER_METADATA}-${name}`, aggregate));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-event-handler-metadata.js","sourceRoot":"","sources":["../../../src/helper/metadata/get-event-handler-metadata.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"get-event-handler-metadata.js","sourceRoot":"","sources":["../../../src/helper/metadata/get-event-handler-metadata.ts"],"names":[],"mappings":";;;AAAA,sDAA8D;AAC9D,iEAA0E;AAC1E,6DAA0E;AAMnE,MAAM,uBAAuB,GAAG,CACrC,SAAwB,EACxB,UAAoC,EACF,EAAE;IACpC,MAAM,EAAE,IAAI,EAAE,GAAG,IAAA,qCAAgB,EAAC,UAAU,CAAC,CAAC;IAE9C,OAAO,IAAA,qCAAc,EACnB,OAAO,CAAC,WAAW,CAAC,GAAG,kCAAsB,IAAI,IAAI,EAAE,EAAE,SAAS,CAAC,CACpE,CAAC;AACJ,CAAC,CAAC;AATW,QAAA,uBAAuB,2BASlC"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.getEventMetadata = void 0;
|
|
4
|
-
const constants_1 = require("
|
|
4
|
+
const constants_1 = require("../../common/constants");
|
|
5
5
|
const getEventMetadata = (event) => {
|
|
6
6
|
return Reflect.getMetadata(constants_1.EVENT_METADATA, event);
|
|
7
7
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-event-metadata.js","sourceRoot":"","sources":["../../../src/helper/metadata/get-event-metadata.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"get-event-metadata.js","sourceRoot":"","sources":["../../../src/helper/metadata/get-event-metadata.ts"],"names":[],"mappings":";;;AAAA,sDAAsD;AAK/C,MAAM,gBAAgB,GAAG,CAC9B,KAA+B,EAChB,EAAE;IACjB,OAAO,OAAO,CAAC,WAAW,CAAC,0BAAc,EAAE,KAAK,CAAkB,CAAC;AACrE,CAAC,CAAC;AAJW,QAAA,gBAAgB,oBAI3B"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,17 +1,14 @@
|
|
|
1
|
+
export * from './common/constants';
|
|
2
|
+
export * from './decorator/index';
|
|
1
3
|
export * from './event-sourcing.module';
|
|
2
|
-
export * from './decorator/aggregate.decorator';
|
|
3
|
-
export * from './decorator/event.decorator';
|
|
4
|
-
export * from './decorator/event-handler.decorator';
|
|
5
|
-
export * from './model/aggregate.root';
|
|
6
|
-
export * from './model/event-envelope';
|
|
7
|
-
export * from './interface/class-constructor.type';
|
|
8
|
-
export * from './interface/postgres-event-store-config';
|
|
9
|
-
export * from './interface/postgres-snapshot-store-config';
|
|
10
4
|
export * from './interface/aggregate/aggregate-metadata.interface';
|
|
11
5
|
export * from './interface/aggregate/event-handler-method.type';
|
|
12
|
-
export * from './interface/
|
|
6
|
+
export * from './interface/class-constructor.type';
|
|
13
7
|
export * from './interface/event/event-envelope-metadata.interface';
|
|
14
8
|
export * from './interface/event/event-handler-metadata.interface';
|
|
15
9
|
export * from './interface/event/event-metadata.interface';
|
|
16
10
|
export * from './interface/event/event-publisher.interface';
|
|
17
|
-
export * from './
|
|
11
|
+
export * from './interface/event/event.interface';
|
|
12
|
+
export * from './interface/postgres-event-store-config';
|
|
13
|
+
export * from './interface/postgres-snapshot-store-config';
|
|
14
|
+
export * from './model/index';
|
package/dist/index.js
CHANGED
|
@@ -14,21 +14,18 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./common/constants"), exports);
|
|
18
|
+
__exportStar(require("./decorator/index"), exports);
|
|
17
19
|
__exportStar(require("./event-sourcing.module"), exports);
|
|
18
|
-
__exportStar(require("./decorator/aggregate.decorator"), exports);
|
|
19
|
-
__exportStar(require("./decorator/event.decorator"), exports);
|
|
20
|
-
__exportStar(require("./decorator/event-handler.decorator"), exports);
|
|
21
|
-
__exportStar(require("./model/aggregate.root"), exports);
|
|
22
|
-
__exportStar(require("./model/event-envelope"), exports);
|
|
23
|
-
__exportStar(require("./interface/class-constructor.type"), exports);
|
|
24
|
-
__exportStar(require("./interface/postgres-event-store-config"), exports);
|
|
25
|
-
__exportStar(require("./interface/postgres-snapshot-store-config"), exports);
|
|
26
20
|
__exportStar(require("./interface/aggregate/aggregate-metadata.interface"), exports);
|
|
27
21
|
__exportStar(require("./interface/aggregate/event-handler-method.type"), exports);
|
|
28
|
-
__exportStar(require("./interface/
|
|
22
|
+
__exportStar(require("./interface/class-constructor.type"), exports);
|
|
29
23
|
__exportStar(require("./interface/event/event-envelope-metadata.interface"), exports);
|
|
30
24
|
__exportStar(require("./interface/event/event-handler-metadata.interface"), exports);
|
|
31
25
|
__exportStar(require("./interface/event/event-metadata.interface"), exports);
|
|
32
26
|
__exportStar(require("./interface/event/event-publisher.interface"), exports);
|
|
33
|
-
__exportStar(require("./
|
|
27
|
+
__exportStar(require("./interface/event/event.interface"), exports);
|
|
28
|
+
__exportStar(require("./interface/postgres-event-store-config"), exports);
|
|
29
|
+
__exportStar(require("./interface/postgres-snapshot-store-config"), exports);
|
|
30
|
+
__exportStar(require("./model/index"), exports);
|
|
34
31
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,qDAAmC;AACnC,oDAAkC;AAClC,0DAAwC;AACxC,qFAAmE;AACnE,kFAAgE;AAChE,qEAAmD;AACnD,sFAAoE;AACpE,qFAAmE;AACnE,6EAA2D;AAC3D,8EAA4D;AAC5D,oEAAkD;AAClD,0EAAwD;AACxD,6EAA2D;AAC3D,gDAA8B"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { IEvent, IEventPayload } from './event/event.interface';
|
|
2
|
+
export type PostgresEventEntity = {
|
|
3
|
+
event_id: string;
|
|
4
|
+
event: string;
|
|
5
|
+
version: number;
|
|
6
|
+
payload: IEventPayload<IEvent>;
|
|
7
|
+
aggregate_id: string;
|
|
8
|
+
occurred_on: Date;
|
|
9
|
+
correlation_id: string | null;
|
|
10
|
+
causation_id: string | null;
|
|
11
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"postgres-event.entity.js","sourceRoot":"","sources":["../../src/interface/postgres-event.entity.ts"],"names":[],"mappings":""}
|
package/dist/main.js
CHANGED
|
@@ -2,9 +2,12 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const core_1 = require("@nestjs/core");
|
|
4
4
|
const app_module_1 = require("./app.module");
|
|
5
|
+
const temp_repository_1 = require("./model/temp.repository");
|
|
5
6
|
async function bootstrap() {
|
|
6
7
|
const app = await core_1.NestFactory.create(app_module_1.AppModule);
|
|
7
8
|
await app.listen(process.env.PORT ?? 3000);
|
|
9
|
+
const a = app.get(temp_repository_1.ARepository);
|
|
10
|
+
console.log(await a.getById());
|
|
8
11
|
}
|
|
9
12
|
bootstrap();
|
|
10
13
|
//# sourceMappingURL=main.js.map
|
package/dist/main.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"main.js","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":";;AAAA,uCAA2C;AAC3C,6CAAyC;
|
|
1
|
+
{"version":3,"file":"main.js","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":";;AAAA,uCAA2C;AAC3C,6CAAyC;AACzC,6DAAsD;AAEtD,KAAK,UAAU,SAAS;IACtB,MAAM,GAAG,GAAG,MAAM,kBAAW,CAAC,MAAM,CAAC,sBAAS,CAAC,CAAC;IAChD,MAAM,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC;IAE3C,MAAM,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,6BAAW,CAAC,CAAC;IAE/B,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;AACjC,CAAC;AAED,SAAS,EAAE,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { EventMap, EventStream } from '@ocoda/event-sourcing';
|
|
2
|
+
import { IEvent } from 'src/interface/event/event.interface';
|
|
3
|
+
import { DbClient } from './db/db.client';
|
|
4
|
+
import { EventEnvelope } from './event-envelope';
|
|
5
|
+
export declare class AbstractRepository {
|
|
6
|
+
private readonly dbClient;
|
|
7
|
+
private readonly eventMap;
|
|
8
|
+
constructor(dbClient: DbClient, eventMap: EventMap);
|
|
9
|
+
private readonly columns;
|
|
10
|
+
getById(): Promise<import("pg").QueryResult<any>>;
|
|
11
|
+
getEnvelope(aggregate: string, version: number): Promise<EventEnvelope>;
|
|
12
|
+
appendEvents(aggregate: string, stream: EventStream, aggregateVersion: number, events: IEvent[] | EventEnvelope[]): Promise<EventEnvelope[]>;
|
|
13
|
+
}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.AbstractRepository = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const event_sourcing_1 = require("@ocoda/event-sourcing");
|
|
18
|
+
const time_uuid_1 = require("@smiledragon-corp/time-uuid");
|
|
19
|
+
const db_client_1 = require("./db/db.client");
|
|
20
|
+
const event_envelope_1 = require("./event-envelope");
|
|
21
|
+
let AbstractRepository = class AbstractRepository {
|
|
22
|
+
dbClient;
|
|
23
|
+
eventMap;
|
|
24
|
+
constructor(dbClient, eventMap) {
|
|
25
|
+
this.dbClient = dbClient;
|
|
26
|
+
this.eventMap = eventMap;
|
|
27
|
+
}
|
|
28
|
+
columns = [
|
|
29
|
+
'stream_id',
|
|
30
|
+
'version',
|
|
31
|
+
'event',
|
|
32
|
+
'payload',
|
|
33
|
+
'event_date',
|
|
34
|
+
'event_id',
|
|
35
|
+
'aggregate_id',
|
|
36
|
+
'occurred_on',
|
|
37
|
+
'correlation_id',
|
|
38
|
+
'causation_id',
|
|
39
|
+
];
|
|
40
|
+
async getById() {
|
|
41
|
+
const result = await this.dbClient.query('SELECT NOW()');
|
|
42
|
+
return result;
|
|
43
|
+
}
|
|
44
|
+
async getEnvelope(aggregate, version) {
|
|
45
|
+
const { rows: entities } = await this.dbClient.query(`SELECT event, payload, event_id, aggregate_id, version, occurred_on, correlation_id, causation_id FROM "${aggregate}" WHERE version = $1`, [version]);
|
|
46
|
+
const entity = entities[0];
|
|
47
|
+
if (!entity) {
|
|
48
|
+
throw new Error(`Event with version ${version} not found`);
|
|
49
|
+
}
|
|
50
|
+
return event_envelope_1.EventEnvelope.from(entity.event, entity.payload, {
|
|
51
|
+
eventId: time_uuid_1.TimeUUID.parse(entity.event_id),
|
|
52
|
+
aggregateId: entity.aggregate_id,
|
|
53
|
+
version: entity.version,
|
|
54
|
+
occurredOn: entity.occurred_on,
|
|
55
|
+
correlationId: entity.correlation_id ?? undefined,
|
|
56
|
+
causationId: entity.causation_id ?? undefined,
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
async appendEvents(aggregate, stream, aggregateVersion, events) {
|
|
60
|
+
try {
|
|
61
|
+
const { rows: currentVersionRows } = await this.dbClient.query(`SELECT MAX(version) as version FROM "${aggregate}" WHERE stream_id = $1`, [stream.streamId]);
|
|
62
|
+
const currentVersion = currentVersionRows[0]?.version || 0;
|
|
63
|
+
if (aggregateVersion <= currentVersion) {
|
|
64
|
+
throw new event_sourcing_1.EventStoreVersionConflictException(stream, aggregateVersion, currentVersion);
|
|
65
|
+
}
|
|
66
|
+
let version = aggregateVersion - events.length + 1;
|
|
67
|
+
const envelopes = [];
|
|
68
|
+
for (const event of events) {
|
|
69
|
+
if (event instanceof event_envelope_1.EventEnvelope) {
|
|
70
|
+
envelopes.push(event);
|
|
71
|
+
continue;
|
|
72
|
+
}
|
|
73
|
+
const name = this.eventMap.getName(event);
|
|
74
|
+
const payload = this.eventMap.serializeEvent(event);
|
|
75
|
+
const envelope = event_envelope_1.EventEnvelope.create(name, payload, {
|
|
76
|
+
aggregateId: stream.aggregateId,
|
|
77
|
+
eventId: new time_uuid_1.TimeUUID(),
|
|
78
|
+
version: version++,
|
|
79
|
+
});
|
|
80
|
+
envelopes.push(envelope);
|
|
81
|
+
}
|
|
82
|
+
const values = [];
|
|
83
|
+
const params = [];
|
|
84
|
+
let paramIndex = 1;
|
|
85
|
+
for (const envelope of envelopes) {
|
|
86
|
+
values.push(`(${this.columns.map(() => `$${paramIndex++}`).join(', ')})`);
|
|
87
|
+
params.push(stream.streamId, envelope.metadata.version, envelope.event, envelope.payload, envelope.metadata.eventId.timestamp, envelope.metadata.eventId.toString(), envelope.metadata.aggregateId, envelope.metadata.occurredOn.toISOString(), envelope.metadata.correlationId ?? null, envelope.metadata.causationId ?? null);
|
|
88
|
+
}
|
|
89
|
+
await this.dbClient.query(`INSERT INTO "${aggregate}" (${this.columns.join(', ')}) VALUES ${values.join(',')}`, params);
|
|
90
|
+
return envelopes;
|
|
91
|
+
}
|
|
92
|
+
catch (error) {
|
|
93
|
+
switch (error.constructor) {
|
|
94
|
+
case event_sourcing_1.EventStoreVersionConflictException:
|
|
95
|
+
throw error;
|
|
96
|
+
default:
|
|
97
|
+
throw new event_sourcing_1.EventStorePersistenceException(aggregate, error);
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
};
|
|
102
|
+
exports.AbstractRepository = AbstractRepository;
|
|
103
|
+
exports.AbstractRepository = AbstractRepository = __decorate([
|
|
104
|
+
__param(0, (0, common_1.Inject)(db_client_1.DbClient)),
|
|
105
|
+
__metadata("design:paramtypes", [db_client_1.DbClient,
|
|
106
|
+
event_sourcing_1.EventMap])
|
|
107
|
+
], AbstractRepository);
|
|
108
|
+
//# sourceMappingURL=abstract.repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"abstract.repository.js","sourceRoot":"","sources":["../../src/model/abstract.repository.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.AggregateRoot = void 0;
|
|
4
|
-
const get_event_handler_metadata_1 = require("
|
|
4
|
+
const get_event_handler_metadata_1 = require("../helper/metadata/get-event-handler-metadata");
|
|
5
5
|
const VERSION = Symbol();
|
|
6
6
|
const EVENTS = Symbol();
|
|
7
7
|
class AggregateRoot {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"aggregate.root.js","sourceRoot":"","sources":["../../src/model/aggregate.root.ts"],"names":[],"mappings":";;;AAAA
|
|
1
|
+
{"version":3,"file":"aggregate.root.js","sourceRoot":"","sources":["../../src/model/aggregate.root.ts"],"names":[],"mappings":";;;AAAA,8FAAyF;AAKzF,MAAM,OAAO,GAAG,MAAM,EAAE,CAAC;AACzB,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC;AAExB,MAAsB,aAAa;IACzB,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IACL,CAAC,MAAM,CAAC,GAAa,EAAE,CAAC;IAEzC,IAAI,OAAO,CAAC,OAAe;QACzB,IAAI,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;IAC1B,CAAC;IAED,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC;IACvB,CAAC;IAED,UAAU,CAA4B,KAAQ,EAAE,WAAW,GAAG,KAAK;QACjE,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;QAIhB,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC3B,CAAC;QAED,MAAM,OAAO,GAAG,IAAI,CAAC,eAAe,CAClC,KAAK,CAAC,WAAkC,CACzC,CAAC;QAEF,OAAO,EAAE,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IAC7B,CAAC;IAEO,eAAe,CACrB,UAA+B;QAE/B,MAAM,oBAAoB,GAAG,IAAA,oDAAuB,EAAC,IAAI,EAAE,UAAU,CAAC,CAAC;QAEvE,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC1B,MAAM,IAAI,KAAK,CACb,qCAAqC,UAAU,CAAC,IAAI,mBAAmB,IAAI,CAAC,WAAW,CAAC,IAAI,IAAI,CACjG,CAAC;QACJ,CAAC;QAED,OAAO,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC;IAC3C,CAAC;IAED,MAAM;QACJ,MAAM,MAAM,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;QACjC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;QAExB,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,WAAqC;QACzD,IAAI,KAAK,EAAE,MAAM,MAAM,IAAI,WAAW,EAAE,CAAC;YACvC,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;gBAC3B,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;YAC/B,CAAC;QACH,CAAC;IACH,CAAC;CACF;AAxDD,sCAwDC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { PoolClient, PoolConfig, QueryConfig, QueryConfigValues, QueryResult, QueryResultRow } from 'pg';
|
|
2
|
+
export declare class DbClient {
|
|
3
|
+
private readonly options;
|
|
4
|
+
private pool;
|
|
5
|
+
constructor(options: PoolConfig);
|
|
6
|
+
getConnection(): Promise<PoolClient>;
|
|
7
|
+
query<R extends QueryResultRow = any, I = any[]>(queryTextOrConfig: string | QueryConfig<I>, values?: QueryConfigValues<I>): Promise<QueryResult<R>>;
|
|
8
|
+
releaseConnection(connection: PoolClient): void;
|
|
9
|
+
}
|