1 year ago
#387817
Stix
Authorization and Authentication with Clean Architecture using Asp.Net Core Identity
I'm learning about Clean and Vertical Slice Architecture for the first time and I'm having trouble understanding where Authorization and Authentication would fit in if we are using ASP.NET Core Identity. Also it feels as though, in some scenarios, separating the Identity User (with username, password, email etc), from any user related domain entity would be tricky.
For example, if we had a solution which used ASP.NET Core MVC, ASP.NET Core Identity, then an example project structure could be as follows:
Presentation/WebUI Project:
- cshtml views / Razor pages would live here, along with controllers (if not using Razor pages).
- The program/startup.cs for this project is where the extension methods from other layers could be called:
app.services.InjectInfrastructure(); // same for application
Infrastructure Project:
- Implementations of application layer contracts.
- Database contexts.
- Perhaps implementations of repositories if you are using them.
Application Project:
- Commands / queries (assuming using something like MassTransit.Mediator or MediatR).
- Validators (for example with fluent validation).
Domain Project:
- Domain entities (anaemic or with methods if following DDD).
- Any aggregates, value objects etc (if using).
We could therefore have a scenario that has the following flow:
- Controller action invoked to get some data (representing the application layer query), which returns rendered html (cshtml view).
- Data is populated on this html page and a POST request (representing the application layer Command) is sent to a controller action.
- The command or query is sent using MediatR.
- Command handler runs (with data access such as dbcontext or repository), which validates, makes the appropriate changes to the data and returns a response.
- Response returned to the controller, which can then determine if the command/query has been successful
- Controller redirects to another action or populates ModelState errors.
Where I struggle to separate auth concerns is in a scenario where a user in the system has different roles and permissions depending on chocies they make on sign in.
For example, a education application where a teacher can select the school they are currently representing. In one school, they may have a certain role (for example head teacher) and in another they may have a role with lesser privellage.
In a scenario such as this, it seems like the Roles, Application Users (both identity concerns) are tightly coupled with the domain (which would house the different schools and roles that each school has).
My overarching question being, how would we implement this sort of Authentication/Authorization scenario using ASP.NET identity in a clean architecture fashion?
At the moment this scenario poses multiple problems:
- If we are to decouple Authentication / Authorization from the presentation layer, we cannot rely on the [Authorize(Role = "X")] [Authorize(Policy = "Y")] decorators on our controllers, as this logic should be delegated to infrastructure (to ensure if we wanted to swap presentation layer at any point, we do not need to rewrite authentication / authorization)
- The user in this scenario is tightly coupled to the domain logic, so I can only see it working if identity related entities and domain entities are squashed together in a single dbContext
Has anyone ever come across / implemented a system like this using clean architecture? Any insight anyone has on this would be great!
asp.net-mvc
asp.net-core
asp.net-identity
clean-architecture
0 Answers
Your Answer