您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

UsersController.cs 2.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. using Diligent.WebAPI.Contracts.DTOs.User;
  2. using Diligent.WebAPI.Data.Entities;
  3. namespace Diligent.WebAPI.Host.Controllers.V1
  4. {
  5. [ApiVersion("1.0")]
  6. [Route("v{version:apiVersion}/users")]
  7. [ApiController]
  8. public class UsersController : ControllerBase
  9. {
  10. private readonly IUserService _userService;
  11. private readonly IMapper _mapper;
  12. public UsersController(IUserService userService, IMapper mapper)
  13. {
  14. _userService = userService;
  15. _mapper = mapper;
  16. }
  17. [Authorize]
  18. [HttpGet]
  19. public async Task<IActionResult> GetAll()
  20. {
  21. return Ok(_mapper.Map<IEnumerable<User?>, IEnumerable<UserResponseDTO>>(await _userService.GetAll()));
  22. }
  23. [Authorize]
  24. [HttpPost("toggleEnable/{id}")]
  25. public async Task<IActionResult> ToggleEnable(int id)
  26. {
  27. var user = await _userService.GetById(id);
  28. if (user == null)
  29. {
  30. return BadRequest("User not found");
  31. }
  32. await _userService.ToggleEnable(user);
  33. return Ok(user.Id);
  34. }
  35. [Authorize]
  36. [HttpDelete("{id}")]
  37. public async Task<IActionResult> DeleteUser(int id)
  38. {
  39. var user = await _userService.GetById(id);
  40. if (user == null)
  41. {
  42. return BadRequest("User not found");
  43. }
  44. await _userService.RemoveUser(user);
  45. return Ok(user.Id);
  46. }
  47. [Authorize]
  48. [HttpGet("{id}")]
  49. public async Task<IActionResult> GetUser(int id)
  50. {
  51. var user = await _userService.GetById(id);
  52. if (user == null)
  53. {
  54. return BadRequest("User not found");
  55. }
  56. return Ok(_mapper.Map<User, UserDetailsResponseDTO>(user));
  57. }
  58. [Authorize]
  59. [HttpPost("invite")]
  60. public async Task<IActionResult> InviteUser([FromBody] InviteDTO invite)
  61. {
  62. var response = await _userService.SendRegistrationLink(invite);
  63. if (response.IsError is true)
  64. return BadRequest(new { message = response.ErrorMessage });
  65. return Ok(response.Data);
  66. }
  67. [Authorize]
  68. [HttpPost("verify-invite")]
  69. public async Task<IActionResult> VerifyInvite(string email, string token)
  70. {
  71. // controller endpoint currently used only for testing
  72. // user should be enabled to log in after accepting invite and updating his account
  73. var user = await _userService.GetByEmail(email);
  74. var result = await _userService.VerifyToken(user, token);
  75. return Ok(result);
  76. }
  77. [Authorize]
  78. [HttpPost]
  79. public async Task<IActionResult> CreateUser([FromBody] CreateUserRequestDto model)
  80. {
  81. await _userService.CreateUser(model);
  82. return Ok();
  83. }
  84. }
  85. }