survey-webapp/SurveyBackend/SurveyBackend.API/Controllers/AuthController.cs
2025-04-27 15:40:57 +05:00

54 lines
No EOL
2.1 KiB
C#

using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
using SurveyBackend.DTOs;
using SurveyBackend.Mappers;
using IAuthorizationService = SurveyBackend.Core.Services.IAuthorizationService;
namespace SurveyBackend.Controllers;
[ApiController]
[Route("api/auth")]
public class AuthController : ControllerBase
{
private readonly IAuthorizationService _authorizationService;
public AuthController(IAuthorizationService authorizationService)
{
_authorizationService = authorizationService;
}
/// <summary>
/// Авторизация
/// </summary>
/// <remarks>Принимает на вход email и password. При отсутствии такого email вернет 404, при неправильном пароле 401, при успехе 200 и валидный токен</remarks>
/// <param name="loginData"></param>
/// <response code="200">Success: Возвращает токен</response>
/// <response code="401">Unauthorized: Неправильный пароль</response>
/// <returns></returns>
[AllowAnonymous]
[HttpPost("login")]
[ProducesResponseType(StatusCodes.Status401Unauthorized)]
[ProducesResponseType(StatusCodes.Status200OK)]
public async Task<IActionResult> LogIn([FromBody] UserLoginDto loginData)
{
var token = await _authorizationService.LogInUser(loginData.Email, loginData.Password);
return Ok(new { token = token });
}
/// <summary>
/// Регистрация
/// </summary>
/// <remarks>Принимает на вход кучу всяких полей, потом разберемся</remarks>
/// <param name="registerData"></param>
/// <returns></returns>
[AllowAnonymous]
[HttpPost("register")]
[ProducesResponseType(StatusCodes.Status401Unauthorized)]
[ProducesResponseType(StatusCodes.Status200OK)]
public async Task<IActionResult> Register([FromBody] UserRegistrationDto registerData)
{
var token = await _authorizationService.RegisterUser(
AuthMapper.UserRegistrationToModel(registerData));
return Ok(new { token = token });
}
}