Comments (2)
I mean when publishing events with eventBus.publish(new Event())
there is no option to await
for all events to finish.
So, imagine that you have a situation like this:
const user = new User();
this.eventBus.publish(new UserCreatedEvent()); // <- this will not wait for events to finish
await this.repository.save(user);
return user; // <- consumer of your api will get a user before published events are executed
Now lets say that you have event handlers somewhere listening for a UserCreatedEvent
, for example you need to create a wallet for a user when a user is created, and save it to the db.
If you don't await
for the publisher to finish executing all the events your function will return right after user is saved to the database, without waiting for a wallet creation.
It is reactive sure, but what if after saving a user your api/database crashes? Your wallet will never be created. Reactive events are good when you have a mechanism to retry sending an event in case of a failure (for example if you use message brokers like RabbitMQ), but NestJS CQRS event bus is in-memory, so in case of a crash/restart it will just lose all the events. Some events will be executed, some not. This means you will have inconsistent data everywhere.
On the other hand, when a publisher lets you await
for all domain events to finish (which NestJS CQRS doesn't) you can include all those events in a single transaction and if one event fails none of the data gets persisted. Its all or nothing.
I hope this answers your question
from domain-driven-hexagon.
wouldn't it be good to add this kind of feature to the official NestJS CQRS package? What do you think @Sairyss
from domain-driven-hexagon.
Related Issues (20)
- `StructuredClone()` function converts entity object into plain object, causing `undefined` properties when calling getters HOT 2
- @slonik/migrator is not compatible with slonik 30+ HOT 9
- InternalServerErrorException has incorrect documentation HOT 1
- FindUsersQuery should map data to response in order to avoid leaks HOT 1
- Why are ports defined in infrastructure layer? HOT 2
- Intermittent test failure for create-user HOT 7
- Clarification on the Practical Usage of Domain Services in DDD
- typeof id is undefined HOT 4
- execute start:dev throws error HOT 6
- Implement and add examples for Adapters and Providers from Infrastructure folder? HOT 6
- Enable GitHub discussions ? HOT 1
- Correct approach for different types of concept? HOT 1
- UnitOfWork creating many QueryRunners and not release them HOT 4
- Types are incorrect for value object's unpack method
- Dependency Inversion in new version HOT 1
- Queries using repositories HOT 1
- Query handler breaking the dependency rule? HOT 4
- Authentication module HOT 1
- Resolver returning type HOT 1
- resolver return HOT 2
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from domain-driven-hexagon.