Logo

dev-resources.site

for different kinds of informations.

comparing Domain-Driven Design (DDD) and Clean Architecture

Published at
12/3/2024
Categories
architecture
typescript
nestjs
Author
Salman Asu
Categories
3 categories in total
architecture
open
typescript
open
nestjs
open
comparing Domain-Driven Design (DDD) and Clean Architecture

main difference between domain-driven design and clean architecture is we are seperating business login, infrastructure and presentation layer for individual module in domain-driven design(DDD).

where seperating business login, infrastructure and presentation layer onces for all module in clean architecture.

Here’s a simplified folder structure comparing Domain-Driven Design (DDD) and Clean Architecture, ensuring clarity and scalability while reducing unnecessary depth.

let take an example for creating folder structure for user and blog module...

Domain-Driven Design (DDD)

src/
β”œβ”€β”€ modules/                    # Feature-based modules
β”‚   β”œβ”€β”€ user/                   # User module
β”‚   β”‚   β”œβ”€β”€ application/        # Use cases (business logic)
β”‚   β”‚   β”‚   β”œβ”€β”€ create-user.usecase.ts
β”‚   β”‚   β”‚   └── update-user.usecase.ts
β”‚   β”‚   β”œβ”€β”€ domain/             # Core business logic
β”‚   β”‚   β”‚   β”œβ”€β”€ user.entity.ts
β”‚   β”‚   β”‚   β”œβ”€β”€ user.repository.ts
β”‚   β”‚   β”‚   └── user.validator.ts
β”‚   β”‚   β”œβ”€β”€ infrastructure/     # Data access and persistence
β”‚   β”‚   β”‚   β”œβ”€β”€ user.repository.impl.ts
β”‚   β”‚   β”‚   └── prisma.service.ts
β”‚   β”‚   β”œβ”€β”€ interfaces/         # Controllers, APIs, and DTOs
β”‚   β”‚   β”‚   β”œβ”€β”€ user.controller.ts
β”‚   β”‚   β”‚   β”œβ”€β”€ create-user.dto.ts
β”‚   β”‚   β”‚   └── update-user.dto.ts
β”‚   β”‚   └── user.module.ts      # Module setup
β”‚   β”œβ”€β”€ blog/                   # Blog module
β”‚   β”‚   β”œβ”€β”€ application/
β”‚   β”‚   β”œβ”€β”€ domain/
β”‚   β”‚   β”œβ”€β”€ infrastructure/
β”‚   β”‚   β”œβ”€β”€ interfaces/
β”‚   β”‚   └── blog.module.ts
β”œβ”€β”€ shared/                     # Shared utilities and services
β”‚   β”œβ”€β”€ exceptions/
β”‚   β”‚   └── custom-error.ts
β”‚   β”œβ”€β”€ utils/
β”‚   β”‚   └── logger.service.ts
β”œβ”€β”€ main.ts                     # Entry point
└── app.module.ts               # Root application module

Clean Architecture

src/
β”œβ”€β”€ core/                       # Core application logic
β”‚   β”œβ”€β”€ usecases/               # Application use cases
β”‚   β”‚   β”œβ”€β”€ create-user.usecase.ts
β”‚   β”‚   β”œβ”€β”€ update-user.usecase.ts
β”‚   β”‚   β”œβ”€β”€ create-blog.usecase.ts
β”‚   β”‚   └── update-blog.usecase.ts
β”‚   β”œβ”€β”€ entities/               # Domain models/entities
β”‚   β”‚   β”œβ”€β”€ user.entity.ts
β”‚   β”‚   β”œβ”€β”€ blog.entity.ts
β”‚   β”‚   └── index.ts
β”‚   β”œβ”€β”€ repositories/           # Repository interfaces
β”‚   β”‚   β”œβ”€β”€ user.repository.ts
β”‚   β”‚   β”œβ”€β”€ blog.repository.ts
β”‚   β”‚   └── index.ts
β”‚   └── validators/             # Domain-level validations
β”‚       β”œβ”€β”€ user.validator.ts
β”‚       β”œβ”€β”€ blog.validator.ts
β”‚       └── index.ts
β”œβ”€β”€ adapters/                   # Adapters for data and frameworks
β”‚   β”œβ”€β”€ database/               # Database layer
β”‚   β”‚   β”œβ”€β”€ prisma/
β”‚   β”‚   β”‚   β”œβ”€β”€ schema.prisma
β”‚   β”‚   β”‚   β”œβ”€β”€ prisma.service.ts
β”‚   β”‚   β”‚   └── user.repository.impl.ts
β”‚   β”‚   └── blog.repository.impl.ts
β”‚   └── controllers/            # Controllers (API endpoints)
β”‚       β”œβ”€β”€ user.controller.ts
β”‚       β”œβ”€β”€ blog.controller.ts
β”‚       └── index.ts
β”œβ”€β”€ config/                     # Configuration files
β”‚   └── app.config.ts
β”œβ”€β”€ shared/                     # Shared utilities
β”‚   β”œβ”€β”€ exceptions/
β”‚   β”‚   └── custom-error.ts
β”‚   β”œβ”€β”€ utils/
β”‚   β”‚   └── logger.service.ts
β”‚   └── index.ts
β”œβ”€β”€ main.ts                     # Entry point
└── app.module.ts               # Root application module

Choose DDD if the application is domain-complex and feature-based, or Clean Architecture if you want to prioritize clear separation of layers. Let me know which one resonates!

want to know more about me, just write sallbro on search engine...

Featured ones: