| 1234567891011121314151617181920212223242526272829303132333435363738394041424344 |
- using SharedKernel.Extensions;
- using MediatR;
- using Web.Api.Extensions;
- using Web.Api.Common;
- namespace Web.Api.Endpoints.Auth;
- internal sealed class Login : IEndpoint
- {
- public sealed record Request(
- string Email,
- string Password
- );
- public void MapEndpoint(IEndpointRouteBuilder app)
- {
- app.MapPost("api/auth/login", async (
- Request request,
- HttpContext httpContext,
- ISender sender,
- CancellationToken ct
- ) => {
- var ipAddress = httpContext.GetClientIP();
- var userAgent = httpContext.GetUserAgent();
- var command = new Application.Features.Api.Auth.Login.Command(
- request.Email,
- request.Password,
- ipAddress,
- userAgent
- );
- var result = await sender.Send(command, ct);
- return result.Match(
- data => ApiResponse.Ok(data),
- CustomResults.Problem
- );
- })
- .WithTags("Auth")
- .AllowAnonymous();
- }
- }
|