introduction to domain driven design

16
Introduction to Domain Driven Design Ganesh Subramanian 22/12/2010 http://sysin.wordpress.com http://dynamicquerygen.sourceforge.net

Upload: nayda-fisher

Post on 03-Jan-2016

50 views

Category:

Documents


2 download

DESCRIPTION

Introduction to Domain Driven Design. Ganesh Subramanian 22/12/2010 http://sysin.wordpress.com http://dynamicquerygen.sourceforge.net. Problem. Problem. Diverse Characters to solve one problem Everybody talks in different language - PowerPoint PPT Presentation

TRANSCRIPT

Page 1: Introduction to Domain Driven Design

Introduction toDomain Driven Design

Ganesh Subramanian22/12/2010

http://sysin.wordpress.comhttp://dynamicquerygen.sourceforge.net

Page 2: Introduction to Domain Driven Design

Problem

Page 3: Introduction to Domain Driven Design

Diverse Characters to solve one problem Everybody talks in different language Ultimate Result- Delivered solution is brittle

and Fragile

Problem

Page 4: Introduction to Domain Driven Design

Everybody who are involved should talk in one LanguageStep 1 : Agree on language terminology and

definitionsStep 2: Call on the language expertStep 3 : Use Business model to device the

language

Solution

Page 5: Introduction to Domain Driven Design

What is DDD? Not a technology or a methodology A way of thinking and a set of priorities,

aimed at accelerating software projects that have to deal with complicated domains

Primary focus on the domain and domain logic

Complex domain designs based on a model.

Domain Driven Design

Page 6: Introduction to Domain Driven Design

Traditional Architecture

Presentation Layer

Business Layer

Data Access Layer

Infr

astr

uctu

re

Layer

Page 7: Introduction to Domain Driven Design

Layered Architecture

Page 8: Introduction to Domain Driven Design

User Interface Responsible for showing information to the user and

interpreting the user's commands Application

Does not contain business rules or knowledge Coordinates tasks and delegates work to domain objects Does not have state reflecting the business situation Interacts with application layer of other systems

Domain Contains business logic and rules Reflects the state of business situationHeart of business software

Infrastructure Provides generic technical capabilities that support the

higher layersPersistence, Sending Emails, libraries, utilities etc…

Layered Architecture (contd…)

Page 9: Introduction to Domain Driven Design

Building Blocks

Page 10: Introduction to Domain Driven Design

Shopping Cart Application

DDD in Practice

Page 11: Introduction to Domain Driven Design

Shopping Cart Application

Page 12: Introduction to Domain Driven Design

Shopping Cart Domain Model

Page 13: Introduction to Domain Driven Design

Entity A noun with an identity Mutable - State can change over time Can be associated with other entities and value objects Can’t be shared

Value Object A noun without an identity Immutable - State can’t change Can be associated with other entities Can be shared

Aggregate One root entity per aggregate Associated entities can refer to root but not other

entities in the aggregate All operations are done through root

Building Blocks Revisited

Page 14: Introduction to Domain Driven Design

Service Has operations that conceptually doesn’t below to an

domain object Stateless Interface is defined in terms of other elements of the

domain model A service can be part of any layer (Application, Domain,

Infrastructure) Factory

Creates the entities and value objects Use only when the entity creation is complex

Repository Collection of entities Takes care of updating an entity Takes care of retrieving an already persisted entity One repository per aggregate root

Building Blocks Revisited (Contd…)

Page 15: Introduction to Domain Driven Design

Layers in Shopping cart App

Page 16: Introduction to Domain Driven Design

???

Questions