Event Sourcing and Read Model generation

前端 未结 3 1694
时光说笑
时光说笑 2021-01-30 14:08

Assuming Stack Overflow domain problem and the following definition of events:

UserRegistered(UserId, Name, Email)
UserNameChanged(UserId, Name)
QuestionAsked(Us         


        
3条回答
  •  旧时难觅i
    2021-01-30 14:27

    Personally I think there's nothing wrong with looking up the user's name from within the event handler. But if you're in a position where you can't query the name from the User's read model then I'd introduce an additional event handler to QuestionEventsHandler, to handle the UserRegistered event.

    That way the QuestionEventsHandler could maintain its own repository of user names (you wouldn't need to store the users email). The QuestionAsked handler can then query the user's name direct from it's own repository (as Rinat Abdullin said storage is cheap!).

    Besides since your QuestionItem read model holds the user's name, you would need to handle the UserNameChanged event within the QuestionEventsHandler as well to ensure the name field within the QuestionItem is up-to-date.

    To me this seems less effort than 'enriching the events' and has the benefit of not building dependencies on other parts of the system and their read models.

提交回复
热议问题