Published on 09 June 2013 by @mathiasverraes
Data Mappers (like Doctrine2) help us a lot to persist data. Yet many projects are still struggling with tough questions: - Where to put business logic? - How to protect our code from abuse? - Where to put queries, and how test them?
Let’s look beyond the old Gang of Four design patterns, and take some clues from tactical Domain Driven Design. At the heart of our models, we can use Value Objects and Entities, with tightly defined consistency boundaries. Repositories abstract away the persistence. Encapsulated Operations helps us to protect invariants. And if we need to manage a lot of complexity, the Specification pattern helps us express business rules in the language of the business.
These patterns help us evolve from structural data models, to rich behavioral models. They capture not just state and relationships, but true meaning.
The presentation is a fast paced introduction to some patterns and ideas that will make your Domain Model expressive, unbreakable, and beautiful.
Check out Elephant in the Room #002: The Heart and Soul of OOP for more info about Value Objects.Follow @mathiasverraes on Twitter.
|Towards Modelling Processes||PHP Barcelona||Talk||Barcelona, ES||Oct 30-31|
|Towards Modelling Processes||PHPCon Poland||Talk||Poland||Nov 13-15|
|DDD in PHP||1 day workshop||Workshop||Poland||Nov 13-15|
|Towards Modelling Processes||Forum PHP Paris||Talk||Paris, FR||Nov 23-24|
|DDD in PHP||1 day workshop||Workshop||Amsterdam, NL||TBD|
|Temporal Modelling||1 day workshop||Workshop||Brussels, BE||Jan 26|
|Domain-Driven Design Europe||Conference||Brussels, BE||Jan 28-29|
|Experiencing Domain-Driven Design||3 day DDD training||Workshop||Leuven, BE||Mar 2-4|
|Experiencing Domain-Driven Design||3 day DDD training||Workshop||Berlin, DE||Mar 23-25|
This work by Mathias Verraes is licensed under a Creative Commons Attribution-NonCommercial-ShareAlike 4.0 License.