UserController.cs 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. using Countries.NET.Database;
  2. using Microsoft.AspNetCore.Authorization;
  3. using Microsoft.AspNetCore.Http;
  4. using Microsoft.AspNetCore.Mvc;
  5. using MTWorkHR.Application.Filters;
  6. using MTWorkHR.Application.Identity;
  7. using MTWorkHR.Application.Models;
  8. using MTWorkHR.Identity.Services;
  9. namespace MTWorkHR.API.Controllers
  10. {
  11. [Route("api/[controller]")]
  12. [ApiController]
  13. [AppAuthorize]
  14. public class UserController : ControllerBase
  15. {
  16. private readonly IUserService _userService;
  17. public UserController(IUserService userService)
  18. {
  19. this._userService = userService;
  20. }
  21. [HttpPost("GetAll")]
  22. [AppAuthorize(Permissions = "User")]
  23. public async Task<ActionResult<List<UserAllDto>>> GetAll([FromBody] UserPagingInputDto pagingInput)
  24. {
  25. return Ok( await _userService.GetAll(pagingInput));
  26. }
  27. [HttpGet("GetAllCompanyEmployees")]
  28. [AppAuthorize(Permissions = "User")]
  29. public async Task<ActionResult<List<UserDto>>> GetAllCompanyEmployees()
  30. {
  31. return Ok(await _userService.GetAllCompanyEmployees());
  32. }
  33. [HttpGet("Get")]
  34. [AppAuthorize(Permissions = "User")]
  35. public async Task<ActionResult<UserDto>> Get()
  36. {
  37. return Ok(await _userService.GetById());
  38. }
  39. [HttpGet("GetById")]
  40. [AppAuthorize(Permissions = "User")]
  41. public async Task<ActionResult<UserDto>> GetById([FromQuery] string userId)
  42. {
  43. return Ok(await _userService.GetById(userId));
  44. }
  45. [HttpGet("GetEmployeeById")]
  46. [AppAuthorize(Permissions = "User")]
  47. public async Task<ActionResult<EmployeeInfoDto>> GetEmployeeById([FromQuery] string userId)
  48. {
  49. return Ok(await _userService.GetEmployeeInfo(userId));
  50. }
  51. [HttpGet("GetByEmail")]
  52. [AppAuthorize(Permissions = "User")]
  53. public async Task<ActionResult<UserDto>> GetByEmail(string userId)
  54. {
  55. return Ok(await _userService.GetByEmail(userId));
  56. }
  57. [HttpPost("Create")]
  58. [ProducesResponseType(StatusCodes.Status200OK)]
  59. [Consumes("multipart/form-data")]
  60. [AppAuthorize(Permissions = "User.Create")]
  61. public async Task<ActionResult<UserDto>> Create([FromForm] UserDto input)
  62. {
  63. return await _userService.Create(input);
  64. }
  65. [HttpPost("Update")]
  66. [Consumes("multipart/form-data")]
  67. [ProducesResponseType(StatusCodes.Status200OK)]
  68. [AppAuthorize(Permissions = "User.Update")]
  69. public async Task<ActionResult<UserDto>> Update([FromForm] UserUpdateDto input)
  70. {
  71. return Ok(await _userService.Update(input));
  72. }
  73. [Authorize(Policy = "SuperAdminOnly")]
  74. [HttpDelete("Delete")]
  75. [AppAuthorize(Permissions = "User.Delete")]
  76. [ProducesResponseType(StatusCodes.Status200OK)]
  77. public async Task Delete([FromQuery] string id)
  78. {
  79. await _userService.Delete(id);
  80. }
  81. [Authorize(Policy = "SuperAdminOnly")]
  82. [HttpDelete("Suspend")]
  83. [AppAuthorize(Permissions = "User.Suspend")]
  84. [ProducesResponseType(StatusCodes.Status200OK)]
  85. public async Task Suspend([FromQuery] string id)
  86. {
  87. await _userService.Suspend(id);
  88. }
  89. [HttpPost("ResetPassword")]
  90. [ProducesResponseType(StatusCodes.Status200OK)]
  91. [AppAuthorize(Permissions = "User.ResetPassword")]
  92. public async Task<bool> ResetPassword([FromBody] ResetPasswordDto input)
  93. {
  94. return await _userService.ResetPassword(input);
  95. }
  96. [HttpGet("GetBlobFile")]
  97. [ProducesResponseType(StatusCodes.Status200OK)]
  98. public async Task<ActionResult> GetBlobFile([FromQuery] string filePath)
  99. {
  100. var res = await _userService.Download(filePath);
  101. return File(res.Content, res.ContentType);
  102. }
  103. }
  104. }