CompanyController.cs 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. using Microsoft.AspNetCore.Authorization;
  2. using Microsoft.AspNetCore.Http;
  3. using Microsoft.AspNetCore.Mvc;
  4. using MTWorkHR.Application.Filters;
  5. using MTWorkHR.Application.Identity;
  6. using MTWorkHR.Application.Models;
  7. using MTWorkHR.Application.Services;
  8. using MTWorkHR.Application.Services.Interfaces;
  9. namespace MTWorkHR.API.Controllers
  10. {
  11. [Route("api/[controller]")]
  12. [ApiController]
  13. [AppAuthorize]
  14. public class CompanyController : ControllerBase
  15. {
  16. private readonly ICompanyService _companyService;
  17. public CompanyController(ICompanyService CompanyService)
  18. {
  19. this._companyService = CompanyService;
  20. }
  21. [HttpGet("GetAll")]
  22. public async Task<ActionResult<List<CompanyDto>>> GetAll([FromQuery] PagingInputDto pagingInput)
  23. {
  24. return Ok( await _companyService.GetAll(pagingInput));
  25. }
  26. [HttpGet("Get")]
  27. public async Task<ActionResult<CompanyDto>> Get()
  28. {
  29. return Ok(await _companyService.GetById());
  30. }
  31. [HttpGet("GetById")]
  32. public async Task<ActionResult<CompanyDto>> GetById(long companyId)
  33. {
  34. return Ok(await _companyService.GetById(companyId));
  35. }
  36. [HttpPost("Create")]
  37. [ProducesResponseType(StatusCodes.Status200OK)]
  38. [Consumes("multipart/form-data")]
  39. [AllowAnonymous]
  40. public async Task<ActionResult<CompanyDto>> Create([FromForm] CompanyDto input)
  41. {
  42. return await _companyService.Create(input);
  43. }
  44. [HttpPost("Update")]
  45. [ProducesResponseType(StatusCodes.Status200OK)]
  46. [Consumes("multipart/form-data")]
  47. public async Task<ActionResult<CompanyDto>> Update([FromForm] CompanyDto input)
  48. {
  49. return await _companyService.Update(input);
  50. }
  51. [HttpDelete("Delete")]
  52. [ProducesResponseType(StatusCodes.Status200OK)]
  53. // [AppAuthorize(Permissions = "Company.Delete")]
  54. [Authorize(Policy = "SuperAdminOnly")]
  55. public async Task Delete([FromQuery] long id)
  56. {
  57. await _companyService.Delete(id);
  58. }
  59. [HttpDelete("Suspend")]
  60. [ProducesResponseType(StatusCodes.Status200OK)]
  61. //[AppAuthorize(Permissions = "Company.Suspend")]
  62. [Authorize(Policy = "SuperAdminOnly")]
  63. public async Task Suspend([FromQuery] long id)
  64. {
  65. await _companyService.Suspend(id);
  66. }
  67. }
  68. }