UPDATE: This project has now been upgraded to .NET 8. I’ve blogged about it here.
I’ve become a huge fan of the Clean Architecture pattern when working on .NET API’s. I won’t go into a ton of detail here, as there are a lot of great resources out there on the subject already, including from the person that I first learned it from, Jason Taylor. If you’re unfamiliar with this pattern, do yourself a favor and check out this presentation by Jason from the GOTO 2019 conference:
But at the 10,000 foot level, an API project using the Clean Architecture pattern has 4 separate projects (along with the necessary unit testing projects):
- Domain – This project is meant to hold the domain entities of the application. The classes in this project map to the data tables or records in whatever data store the application is configured to use.
- Application – This project contains the business logic and rules that make the application as a whole run as it’s supposed to. It directly references the Domain project, but no other projects within the solution.
- Infrastructure – This project contains the implementation of any logic that needs to communicate with outside entities, such as a database, the file system, other HTTP API’s, and so forth. It references the Application project to gain access to application contracts that it will then implement for accessing the aforementioned external entities.
- Api – This is the front-end of the application, and provides the start-up code and the API endpoint entry points.
Solution Template Nuget Package
I’ve created a Nuget package called StaticSphere.CleanArchitecture.Api
, and published it to Nuget.org. You can install it using the following command:
dotnet new --install StaticSphere.CleanArchitecture.Api
Once installed, you can create a new solution by running the following command:
dotnet new clean-arch <<parameters>>
When executed, you’ll get a full .NET 6 ASP.NET API solution that contains the following folder structure (assuming you named to the solution HelloWorld):
- src
- HelloWorld.Api
- HelloWorld.Application
- HelloWorld.Domain
- HelloWorld.Infrastructure
- tests
- HelloWorld.Api.Tests
- HelloWorld.Application.Tests
- HelloWorld.Infrastructure.Tests
The projects are all .NET 6 applications with nullable references types and implicit usings enabled. The unit testing projects use Xunit out of the box. There are also support files such as .gitignore, .editorconfig, etc.
There are parameters that can be passed to the dotnet new
command that alter the solution that is created:
- –includeTests – Determines if the test projects should be included or not. Default value: true
- –skipRestore – If specified, skips the automatic restore of the project on create. Default value: false
- –useStartup – Determines if the API project should use Startup.cs instead of the newer Minimal API style Program.cs file. Default value: false
- –includeEF – If set, the created solution will include Entity Framework Core, and will be configured to use the specified provider (only these providers are currently supported)
- postgres – Adds Postgres Entity Framework configuration
- sqlserver – Adds SQL Server Entity Framework configuration
Open Source
The Nuget package that contains the solution template is completely free and open source, and is MIT licensed. The Nuget package can be found here, and the source code for the template can be found here. If you have any suggestions, or would like to contribute to the template, please let me know!
A great work. I haven’t tried this but currently following exactly same path for all the projects I initiated since .net core 3.0. Excited to try your template.
Thanks! Let me know if you have any issues with it, or have any suggestions! It’s a beautiful pattern!
Hello,
Can you help me with domain registration and login and connect it to the application layer?
I’m not sure exactly what you’re asking for here. There are a ton of videos on YouTube that cover setting up ASP.NET Authentication and Authorization, OAuth, or other patterns. As for domain registration, that’s going to be something that you need to look at with your chosen hosting service along with GoDaddy, Google Domains, DNSimple, etc.