What is MediatR? Why do we need it? And How to use it?
Mediator Pattern - The mediator pattern ensures that objects do not interact directly instead of through a mediator. It reduces coupling between objects which makes it easy to maintain the code. Mediator pattern unified the service interfaces around a common design, one request in, one response out.
MediatR is a simple, unambitious mediator implementation in .NET.
Let’s now dive deeper into the working of a simple web API with MediatR. Complete code for the same can be found here.
1. Create a new web API project.
data:image/s3,"s3://crabby-images/8528e/8528e3fb1e1a67e631fa73e4459abb8c4f1bee96" alt=""
data:image/s3,"s3://crabby-images/f910f/f910f25fbf27669e3a07b7386292125ea34f3b4c" alt=""
OpenAPI support makes it easy to test the API.
2. Create a folder with these three classes.
data:image/s3,"s3://crabby-images/7ddd6/7ddd6f70b1d8382520ec091c2f0e296b929c92ff" alt=""
Solution Hierarchy
2.1 ApiRequestModel: This class represents a request for API.
data:image/s3,"s3://crabby-images/6fe21/6fe212cea901020e53ce2216b7beb44ff2c5b6a9" alt=""
ApiRequestModel
— IRequest<> It represents a request with a response.
2.2 ApiResponseModel : This class represents a response of API.
data:image/s3,"s3://crabby-images/3af4d/3af4dfe1dd531385044aa2d48af8cd5ed993ef28" alt=""
ApiResponseModel
2.3 ApiHandler: And this class keeps the logical part.
data:image/s3,"s3://crabby-images/17105/17105c8d7d86d107a1aaf3f81789d902b0ad8a72" alt=""
ApiResponseModel
IRequesthandler<> binds request and response with handler class. The logic of API is kept in the Handle method.
3. Now let’s check the controller. I wrote a base controller that would be inherited by other controllers.
data:image/s3,"s3://crabby-images/f83a0/f83a0fe6b34f112ed4d7ee75cc514c1081661b80" alt=""
ApiControllerBase
ISender is responsible for communication between different mediator-linked objects. It sends a request through a mediator pipeline to be handled by a single handler.
In this code, HomeController is inheriting the base controller. ApiController communicates with ApiHandler based on ApiRequestModel and ApiResponseModel pair.
data:image/s3,"s3://crabby-images/287cc/287cce68f9c2fb9520e56a58602531e6b1238b82" alt=""
ApiController
You can test this API using swagger (OpenAPI).
data:image/s3,"s3://crabby-images/f96aa/f96aa7aeee071b303faee8f2dddeac2662a42ed8" alt=""
From the above example, you can see a separation of request, response, logic, and communication using MediatR. And if you want to move to CQRS (Command and Query Responsibility Segregation) pattern, the mediator makes the transition seamless.