ddd-node 3.0.0 → 4.0.0

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.
@@ -2,7 +2,7 @@ import { Class } from "../types/class";
2
2
  import { ClassStatic } from "../types/class-static";
3
3
  import { AnyCommand } from "./command";
4
4
  import { Entity, IEntityMetadata } from "./entity";
5
- import { AnyEvent, EventClass, IEventAggregate, NewEventMetadataOptions } from "./event";
5
+ import { AnyEvent, EventClass, NewEventMetadataOptions } from "./event";
6
6
  import { Id } from "./id";
7
7
  import { PropsOf } from "./props-envelope";
8
8
  export interface IAggregateMetadata extends IEntityMetadata {
@@ -21,7 +21,6 @@ export declare class Aggregate<P extends object> extends Entity<P> implements IA
21
21
  getEvents(): AnyEvent[];
22
22
  hasEvents(): boolean;
23
23
  nextVersion(): number;
24
- nextEventAggregate(): IEventAggregate;
25
24
  protected newEvent<E extends AnyEvent>(eventClass: EventClass<E>, props: PropsOf<E>, metadata?: NewEventMetadataOptions): E;
26
25
  protected addEvent<E extends AnyEvent>(event: E): void;
27
26
  }
@@ -32,9 +31,8 @@ export declare class AggregateES<P extends object> extends Aggregate<P> {
32
31
  getHandledCommands(): AnyCommand[];
33
32
  getPastEvents(): AnyEvent[];
34
33
  lastEvent(): AnyEvent | undefined;
35
- lastEventVersion(): number;
36
- nextEventVersion(): number;
37
- nextEventAggregate(): IEventAggregate;
34
+ currentVersion(): number;
35
+ nextVersion(): number;
38
36
  private addPastEvent;
39
37
  private validateEventBeforeApply;
40
38
  getEventApplier(eventType: string): AggregateEventApplier<AnyEvent> | null;
@@ -53,4 +51,5 @@ export type AggregateESClassWithProps<P extends object> = Class<AggregateES<P>,
53
51
  export type AggregateConstructorParams<T extends AnyAggregate> = AggregateConstructorParamsWithProps<PropsOf<T>>;
54
52
  export type AggregateClass<T extends AnyAggregate> = Class<T, AggregateConstructorParams<T>> & ClassStatic<typeof Aggregate<PropsOf<T>>>;
55
53
  export type AggregateESClass<T extends AnyAggregateES> = Class<T, AggregateConstructorParams<T>> & ClassStatic<typeof AggregateES<PropsOf<T>>>;
54
+ export type InferAggregateClass<T extends AnyAggregate> = T extends AnyAggregateES ? AggregateESClass<T> : AggregateClass<T>;
56
55
  export type AnyAggregateClass = AggregateClass<AnyAggregate>;
@@ -38,15 +38,12 @@ class Aggregate extends entity_1.Entity {
38
38
  nextVersion() {
39
39
  return this.version + 1;
40
40
  }
41
- nextEventAggregate() {
42
- return {
43
- type: this.aggregateType(),
41
+ newEvent(eventClass, props, metadata) {
42
+ return eventClass.newEvent({
44
43
  id: this.id,
44
+ type: this.aggregateType(),
45
45
  version: this.nextVersion(),
46
- };
47
- }
48
- newEvent(eventClass, props, metadata) {
49
- return eventClass.newEvent(this.nextEventAggregate(), props, metadata);
46
+ }, props, metadata);
50
47
  }
51
48
  addEvent(event) {
52
49
  this.events.push(event);
@@ -74,21 +71,14 @@ class AggregateES extends Aggregate {
74
71
  lastEvent() {
75
72
  return this.hasEvents() ? this.events.at(-1) : this.pastEvents.at(-1);
76
73
  }
77
- lastEventVersion() {
74
+ currentVersion() {
78
75
  const lastEvent = this.lastEvent();
79
76
  if (lastEvent)
80
77
  return lastEvent.aggregate.version;
81
78
  return this.version;
82
79
  }
83
- nextEventVersion() {
84
- return this.lastEventVersion() + 1;
85
- }
86
- nextEventAggregate() {
87
- return {
88
- type: this.aggregateType(),
89
- id: this.id,
90
- version: this.nextEventVersion(),
91
- };
80
+ nextVersion() {
81
+ return this.currentVersion() + 1;
92
82
  }
93
83
  addPastEvent(event) {
94
84
  if (this.hasEvents())
@@ -101,7 +91,7 @@ class AggregateES extends Aggregate {
101
91
  throw new aggregate_error_1.InvalidEventAggregateTypeError();
102
92
  if (id !== this.id)
103
93
  throw new aggregate_error_1.InvalidEventAggregateIdError();
104
- if (version !== this.nextEventVersion())
94
+ if (version !== this.nextVersion())
105
95
  throw new aggregate_error_1.InvalidEventAggregateVersionError();
106
96
  }
107
97
  getEventApplier(eventType) {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "ddd-node",
3
- "version": "3.0.0",
3
+ "version": "4.0.0",
4
4
  "description": "Domain Driven Design base for NodeJs",
5
5
  "main": "dist/index.js",
6
6
  "scripts": {