CompanyController.java 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. package com.izouma.nineth.web;
  2. import com.izouma.nineth.domain.Company;
  3. import com.izouma.nineth.domain.UserBalance;
  4. import com.izouma.nineth.dto.PageQuery;
  5. import com.izouma.nineth.exception.BusinessException;
  6. import com.izouma.nineth.repo.CompanyRepo;
  7. import com.izouma.nineth.repo.UserBalanceRepo;
  8. import com.izouma.nineth.service.CompanyService;
  9. import com.izouma.nineth.utils.ObjUtils;
  10. import com.izouma.nineth.utils.SecurityUtils;
  11. import com.izouma.nineth.utils.excel.ExcelUtils;
  12. import lombok.AllArgsConstructor;
  13. import org.springframework.data.domain.Page;
  14. import org.springframework.security.access.prepost.PreAuthorize;
  15. import org.springframework.web.bind.annotation.*;
  16. import javax.servlet.http.HttpServletResponse;
  17. import java.io.IOException;
  18. import java.util.List;
  19. import java.util.Optional;
  20. @RestController
  21. @RequestMapping("/company")
  22. @AllArgsConstructor
  23. public class CompanyController extends BaseController {
  24. private CompanyService companyService;
  25. private CompanyRepo companyRepo;
  26. private UserBalanceRepo userBalanceRepo;
  27. @PreAuthorize("hasAnyRole('ADMIN','SAAS')")
  28. @PostMapping("/save")
  29. public Company save(@RequestBody Company record) {
  30. if (record.getId() != null) {
  31. Company orig = companyRepo.findById(record.getId()).orElseThrow(new BusinessException("无记录"));
  32. ObjUtils.merge(orig, record);
  33. return companyRepo.save(orig);
  34. }
  35. return companyRepo.save(record);
  36. }
  37. @PreAuthorize("hasRole('ADMIN') || hasRole('META')")
  38. @PostMapping("/all")
  39. public Page<Company> all(@RequestBody PageQuery pageQuery) {
  40. return companyService.all(pageQuery);
  41. }
  42. @GetMapping("/get/{id}")
  43. public Company get(@PathVariable Long id) {
  44. return companyRepo.findById(id).orElseThrow(new BusinessException("无记录"));
  45. }
  46. @PostMapping("/del/{id}")
  47. public void del(@PathVariable Long id) {
  48. companyRepo.softDelete(id);
  49. }
  50. @GetMapping("/excel")
  51. @ResponseBody
  52. public void excel(HttpServletResponse response, PageQuery pageQuery) throws IOException {
  53. List<Company> data = all(pageQuery).getContent();
  54. ExcelUtils.export(response, data);
  55. }
  56. @PreAuthorize("hasAnyRole('ADMIN', 'SAAS')")
  57. @PostMapping("/addAdmin")
  58. public void addAdmin(@RequestParam Long companyId, @RequestParam String username, @RequestParam String password) {
  59. companyService.addAdmin(companyId, username, password);
  60. }
  61. @PreAuthorize("hasAnyRole('ADMIN', 'SAAS')")
  62. @PostMapping("/delAdmin")
  63. public void delAdmin(@RequestParam Long companyId, @RequestParam Long userId) {
  64. companyService.delAdmin(companyId, userId);
  65. }
  66. @GetMapping("/balance")
  67. public UserBalance balance() {
  68. Long companyId = Optional.ofNullable(SecurityUtils.getAuthenticatedUser().getCompanyId()).orElseThrow(new BusinessException("非企业账号"));
  69. return userBalanceRepo.findByUserId(companyId).orElse(new UserBalance(companyId));
  70. }
  71. }