Files
PIBD-23_Coursework_Bank/TheBank/BankWebApi/Controllers/ClerksController.cs

115 lines
3.4 KiB
C#
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
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();
}
}