115 lines
3.4 KiB
C#
115 lines
3.4 KiB
C#
using BankContracts.AdapterContracts;
|
||
using BankContracts.BindingModels;
|
||
using Microsoft.AspNetCore.Authorization;
|
||
using Microsoft.AspNetCore.Mvc;
|
||
using System.Security.Claims;
|
||
|
||
namespace BankWebApi.Controllers;
|
||
|
||
[Authorize]
|
||
[Route("api/[controller]")]
|
||
[ApiController]
|
||
[Produces("application/json")]
|
||
public class ClerksController(IClerkAdapter adapter) : ControllerBase
|
||
{
|
||
private readonly IClerkAdapter _adapter = adapter;
|
||
|
||
/// <summary>
|
||
/// получение всех записей клерков
|
||
/// </summary>
|
||
/// <returns>список клерков</returns>
|
||
[HttpGet]
|
||
public IActionResult GetAllRecords()
|
||
{
|
||
return _adapter.GetList().GetResponse(Request, Response);
|
||
}
|
||
|
||
/// <summary>
|
||
/// получние записи о клерке по данным
|
||
/// </summary>
|
||
/// <param name="data">уникальный идентификатор или другое поле</param>
|
||
/// <returns>запись клерка</returns>
|
||
[HttpGet("{data}")]
|
||
public IActionResult GetRecord(string data)
|
||
{
|
||
return _adapter.GetElement(data).GetResponse(Request, Response);
|
||
}
|
||
|
||
/// <summary>
|
||
/// создание записи клерка
|
||
/// </summary>
|
||
/// <param name="model">модель от пользователя</param>
|
||
/// <returns></returns>
|
||
[HttpPost("register")]
|
||
[AllowAnonymous]
|
||
public IActionResult Register([FromBody] ClerkBindingModel model)
|
||
{
|
||
return _adapter.RegisterClerk(model).GetResponse(Request, Response);
|
||
}
|
||
|
||
/// <summary>
|
||
/// изменение записи клерка
|
||
/// </summary>
|
||
/// <param name="model">новая модель</param>
|
||
/// <returns></returns>
|
||
[HttpPut]
|
||
public IActionResult ChangeInfo([FromBody] ClerkBindingModel model)
|
||
{
|
||
return _adapter.ChangeClerkInfo(model).GetResponse(Request, Response);
|
||
}
|
||
|
||
/// <summary>
|
||
/// вход для клерка
|
||
/// </summary>
|
||
/// <param name="model">модель с логином и паролем</param>
|
||
/// <returns></returns>
|
||
[HttpPost("login")]
|
||
[AllowAnonymous]
|
||
public IActionResult Login([FromBody] LoginBindingModel model)
|
||
{
|
||
var res = _adapter.Login(model, out string token);
|
||
if (string.IsNullOrEmpty(token))
|
||
{
|
||
return res.GetResponse(Request, Response);
|
||
}
|
||
|
||
Response.Cookies.Append(AuthOptions.CookieName, token, new CookieOptions
|
||
{
|
||
HttpOnly = true,
|
||
SameSite = SameSiteMode.None,
|
||
Secure = true,
|
||
Expires = DateTime.UtcNow.AddDays(2)
|
||
});
|
||
|
||
return res.GetResponse(Request, Response);
|
||
}
|
||
|
||
/// <summary>
|
||
/// Получение данных текущего клерка
|
||
/// </summary>
|
||
/// <returns>Данные кладовщика</returns>
|
||
[HttpGet("me")]
|
||
public IActionResult GetCurrentUser()
|
||
{
|
||
var userId = User.FindFirst(ClaimTypes.NameIdentifier)?.Value;
|
||
if (string.IsNullOrEmpty(userId))
|
||
{
|
||
return Unauthorized();
|
||
}
|
||
|
||
var response = _adapter.GetElement(userId);
|
||
return response.GetResponse(Request, Response);
|
||
}
|
||
|
||
/// <summary>
|
||
/// Выход клерка
|
||
/// </summary>
|
||
/// <returns></returns>
|
||
[HttpPost("logout")]
|
||
public IActionResult Logout()
|
||
{
|
||
Response.Cookies.Delete(AuthOptions.CookieName);
|
||
return Ok();
|
||
}
|
||
}
|