Add initial implementation of API, database, and user management components.
This commit is contained in:
69
MikrocopApi/Controllers/UsersController.cs
Normal file
69
MikrocopApi/Controllers/UsersController.cs
Normal file
@@ -0,0 +1,69 @@
|
||||
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());
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user