70 lines
2.8 KiB
C#
70 lines
2.8 KiB
C#
using MikrocopApi.Dtos;
|
|
using MikrocopApi.Mappers;
|
|
using MikrocopApi.Services;
|
|
using Microsoft.AspNetCore.Authorization;
|
|
using Microsoft.AspNetCore.Mvc;
|
|
|
|
namespace MikrocopApi.Controllers;
|
|
|
|
[ApiController]
|
|
[Authorize]
|
|
[Route("api/users")]
|
|
public sealed class UsersController : ControllerBase
|
|
{
|
|
private readonly IUserService _userService;
|
|
|
|
public UsersController(IUserService userService)
|
|
{
|
|
_userService = userService;
|
|
}
|
|
|
|
[HttpPost]
|
|
[ProducesResponseType<UserDto>(StatusCodes.Status201Created)]
|
|
[ProducesResponseType<ValidationProblemDetails>(StatusCodes.Status400BadRequest)]
|
|
[ProducesResponseType<ProblemDetails>(StatusCodes.Status409Conflict)]
|
|
public async Task<IActionResult> Create([FromBody] CreateUserDto request, CancellationToken cancellationToken)
|
|
{
|
|
var user = await _userService.CreateAsync(request, cancellationToken);
|
|
return CreatedAtAction(nameof(GetById), new { id = user.Id }, user);
|
|
}
|
|
|
|
[HttpGet("{id:guid}")]
|
|
[ProducesResponseType<UserDto>(StatusCodes.Status200OK)]
|
|
[ProducesResponseType<ProblemDetails>(StatusCodes.Status404NotFound)]
|
|
public async Task<IActionResult> GetById([FromRoute] Guid id, CancellationToken cancellationToken)
|
|
{
|
|
var user = await _userService.GetByIdAsync(id, cancellationToken);
|
|
return Ok(user);
|
|
}
|
|
|
|
[HttpPut("{id:guid}")]
|
|
[ProducesResponseType(StatusCodes.Status204NoContent)]
|
|
[ProducesResponseType<ValidationProblemDetails>(StatusCodes.Status400BadRequest)]
|
|
[ProducesResponseType<ProblemDetails>(StatusCodes.Status404NotFound)]
|
|
[ProducesResponseType<ProblemDetails>(StatusCodes.Status409Conflict)]
|
|
public async Task<IActionResult> Update([FromRoute] Guid id, [FromBody] UpdateUserDto request, CancellationToken cancellationToken)
|
|
{
|
|
await _userService.UpdateAsync(id, request, cancellationToken);
|
|
return NoContent();
|
|
}
|
|
|
|
[HttpDelete("{id:guid}")]
|
|
[ProducesResponseType(StatusCodes.Status204NoContent)]
|
|
[ProducesResponseType<ProblemDetails>(StatusCodes.Status404NotFound)]
|
|
public async Task<IActionResult> Delete([FromRoute] Guid id, CancellationToken cancellationToken)
|
|
{
|
|
await _userService.DeleteAsync(id, cancellationToken);
|
|
return NoContent();
|
|
}
|
|
|
|
[HttpPost("{id:guid}/validate-password")]
|
|
[ProducesResponseType<ValidatePasswordResponseDto>(StatusCodes.Status200OK)]
|
|
[ProducesResponseType<ValidationProblemDetails>(StatusCodes.Status400BadRequest)]
|
|
[ProducesResponseType<ProblemDetails>(StatusCodes.Status404NotFound)]
|
|
public async Task<IActionResult> ValidatePassword([FromRoute] Guid id, [FromBody] ValidatePasswordRequestDto request, CancellationToken cancellationToken)
|
|
{
|
|
var isValid = await _userService.ValidatePasswordAsync(id, request.Password, cancellationToken);
|
|
return Ok(isValid.ToDto());
|
|
}
|
|
}
|