This repository serves as a hands-on learning experience for Clean Architecture principles in .NET Core. It organizes the codebase into distinct layers for scalability, maintainability, and separation of concerns.
The heart of the application, CleanArchitecture.Domain, holds the domain entities and business logic. It represents the core of your application and remains independent of any external frameworks.
CleanArchitecture.Application encapsulates application-specific business rules, use cases, and application services. It acts as a mediator between the domain layer and the infrastructure layer.
CleanArchitecture.Infrastructure contains implementation details that are external to the application. It includes data access, external services, and other infrastructure concerns.
CleanArchitecture.Identity focuses on user identity and authentication aspects, handling user-related functionalities.
The CleanArchitecture.Persistence project deals with data storage and retrieval, using technologies such as Entity Framework Core to interact with the database.
CleanArchitecture.Api serves as the entry point for the Web API application. It utilizes the Clean Architecture principles to handle incoming HTTP requests and coordinate actions across different layers.
CleanArchitecture.MVC represents the MVC (Model-View-Controller) layer, handling the presentation logic for the user interface. It interacts with the application layer to retrieve and display data.
Ready to dive deeper into Clean Architecture? Check out the following resources:
-
Clean Architecture: A Craftsman's Guide to Software Structure and Design by Robert C. Martin
- An in-depth guide by Uncle Bob himself, exploring the principles and patterns of Clean Architecture.
-
Domain-Driven Design: Tackling Complexity in the Heart of Software by Eric Evans
- A classic book on Domain-Driven Design, offering insights into designing complex systems.
-
Exploring Clean Architecture in ASP.NET Core on Microsoft Docs
- Microsoft's guide on implementing Clean Architecture in ASP.NET Core applications.
-
The Clean Architecture by Robert C. Martin
- Uncle Bob's blog post that introduced the Clean Architecture concept.
-
- An online community and platform by Robert C. Martin, offering videos, articles, and discussions on clean code and architecture.
-
Stack Overflow - Clean Architecture
- Explore questions and discussions related to Clean Architecture on Stack Overflow.
Remember, the best way to learn is by doing. Feel free to explore the code in each layer and experiment with building your own features following the Clean Architecture principles!
-
.NET Core 8:
- Utilizes the latest version of .NET Core for enhanced performance and features.
-
FluentValidation:
- Integrates FluentValidation for robust input validation and improved request handling.
Learn More: FluentValidation Documentation
- Mediator:
- Implements the Mediator pattern for efficient communication between components.
Learn More: MediatR Documentation
- AutoMapper:
- Uses AutoMapper for simplified object-to-object mapping.
Learn More: AutoMapper Documentation
- CQRS (Command Query Responsibility Segregation):
- Adopts the CQRS pattern for a clear separation of concerns between commands and queries.
Learn More: CQRS Pattern Overview
- Entity Framework Core:
- Leverages Entity Framework Core for data access and database management.
Learn More: Entity Framework Core Documentation
- Serilog:
- Incorporates Serilog for structured logging and easy log analysis.
Learn More: Serilog Documentation
- JWT (JSON Web Tokens):
- Implements JWT for secure authentication and authorization.
Learn More: JWT Introduction
- Authorization:
- Integrates authorization mechanisms to control access to different parts of the application.
Learn More: ASP.NET Core Authorization
- Globalization:
- Supports globalization for multi-language and culture-specific content.
Learn More: Globalization and Localization in ASP.NET Core
- Dependency Injection:
- Utilizes the built-in dependency injection in .NET Core for managing application components.
Learn More: Dependency Injection in .NET Core
If you're new to Clean Architecture and .NET Core, follow these steps to get started:
-
Understand the Layers:
- Explore the CleanArchitecture.Domain, CleanArchitecture.Application, and CleanArchitecture.Infrastructure layers to grasp the separation of concerns.
-
Study CQRS:
- Dig into the CQRS pattern implemented in this project to understand the benefits of separating command and query responsibilities.
-
Explore Dependency Injection:
- Investigate how dependency injection is used in .NET Core within the context of this project.
Learn More: Dependency Injection in .NET Core
-
Read the CleanArchitecture.Api and CleanArchitecture.MVC Projects:
- Analyze the entry points of the application and understand how they interact with the underlying layers.
-
Experiment with Features:
- Modify or add features to see how changes propagate through the application layers while adhering to Clean Architecture principles.
To deploy the application, follow the deployment instructions in the Deployment section.
This project is configured for CI/CD with GitHub Actions. The workflow is triggered on each push to the main branch, running build and test tasks.
Run the application in Docker containers using Docker Compose:
-
Build and run the Docker containers:
docker-compose up -d
Related Repositories:
-
Access the Web API:
- The API will be accessible at http://localhost:5000.
-
Access the MVC application:
- The MVC application will be accessible at http://localhost:5001.
-
Stop the containers:
docker-compose down
The CI/CD pipeline is automatically triggered on each push to the main branch. It includes the following steps:
-
Build:
- Builds the application, ensuring the code compiles successfully.
-
Test:
- Runs automated tests to verify the integrity of the codebase.
-
Publish:
- Publishes the application, preparing it for deployment.
-
Deploy:
- Deploys the application to the specified environment.
Learn More: GitHub Actions Documentation
Feel free to customize the CI/CD workflow in the .github/workflows
directory based on your deployment needs.
This Web API provides a basic structure adhering to Clean Architecture. Customize it based on your specific application needs.
- Fork the project.
- Create a new branch:
git checkout -b feature/my-feature
. - Make changes and commit them:
git commit -m 'Add new feature'
. - Push to the branch:
git push origin feature/my-feature
. - Open a pull request.
Related Repositories:
This project is licensed under the MIT License - see the LICENSE file for details.
Related Repositories: