survey-webapp/SurveyBackend/SurveyBackend.API/Controllers/AuthController.cs

40 lines
No EOL
1.1 KiB
C#

using Microsoft.AspNetCore.Mvc;
using SurveyBackend.DTOs;
using SurveyBackend.Mappers.UserDTOs;
using SurveyBackend.Services.Services;
namespace SurveyBackend.Controllers;
[ApiController]
[Route("auth")]
public class AuthController : ControllerBase
{
private readonly AuthorizationService _authorizationService;
public AuthController(AuthorizationService authorizationService)
{
_authorizationService = authorizationService;
}
[HttpPost("login")]
public async Task<IActionResult> LogIn([FromBody] UserLoginDto loginData)
{
var token = await _authorizationService.LogInUser(loginData.Email, loginData.Password);
return token is null ? Unauthorized() : Ok(new { token = token });
}
[HttpPost("register")]
public async Task<IActionResult> Register([FromBody] UserRegistrationDto registerData)
{
try
{
await _authorizationService.RegisterUser(UserRegistrationMapper.UserRegistrationToModel(registerData));
}
catch (Exception ex)
{
return BadRequest(ex.Message);
}
return Ok();
}
}