54 lines
No EOL
2.1 KiB
C#
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 });
|
|
}
|
|
} |