| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124 |
- package com.izouma.zhirongip.web;
- import cn.hutool.core.util.ObjectUtil;
- import com.izouma.zhirongip.domain.Institution;
- import com.izouma.zhirongip.domain.Personal;
- import com.izouma.zhirongip.domain.User;
- import com.izouma.zhirongip.dto.InstitutionDTO;
- import com.izouma.zhirongip.dto.UserRegister;
- import com.izouma.zhirongip.enums.ApplyStatus;
- import com.izouma.zhirongip.enums.AuthorityName;
- import com.izouma.zhirongip.repo.PersonalRepo;
- import com.izouma.zhirongip.repo.UserRepo;
- import com.izouma.zhirongip.security.Authority;
- import com.izouma.zhirongip.service.InstitutionService;
- import com.izouma.zhirongip.dto.PageQuery;
- import com.izouma.zhirongip.exception.BusinessException;
- import com.izouma.zhirongip.repo.InstitutionRepo;
- import com.izouma.zhirongip.service.UserService;
- import com.izouma.zhirongip.utils.ObjUtils;
- import com.izouma.zhirongip.utils.SecurityUtils;
- import com.izouma.zhirongip.utils.excel.ExcelUtils;
- import io.swagger.annotations.ApiOperation;
- import lombok.AllArgsConstructor;
- import org.apache.commons.lang3.RandomStringUtils;
- import org.springframework.data.domain.Page;
- import org.springframework.security.access.prepost.PreAuthorize;
- import org.springframework.web.bind.annotation.*;
- import javax.servlet.http.HttpServletResponse;
- import java.io.IOException;
- import java.util.Collections;
- import java.util.List;
- import java.util.Set;
- @RestController
- @RequestMapping("/institution")
- @AllArgsConstructor
- public class InstitutionController extends BaseController {
- private final InstitutionService institutionService;
- private final InstitutionRepo institutionRepo;
- private final PersonalRepo personalRepo;
- private final UserRepo userRepo;
- private final UserService userService;
- //@PreAuthorize("hasRole('ADMIN')")
- @PostMapping("/save")
- public Institution save(@RequestBody Institution record) {
- Long userId = SecurityUtils.getAuthenticatedUser().getId();
- if (record.getId() != null) {
- Institution orig = institutionRepo.findById(record.getId()).orElseThrow(new BusinessException("无记录"));
- orig.setUserId(userId);
- ObjUtils.merge(orig, record);
- orig.setStatus(ApplyStatus.PENDING);
- return institutionRepo.save(orig);
- }
- if (SecurityUtils.getAuthenticatedUser().getAuthorities().contains(Authority.get(AuthorityName.ROLE_ADMIN))) {
- User user = userService.create(UserRegister.builder()
- .authorities(Collections.singleton(Authority.get(AuthorityName.ROLE_INSTITUTION)))
- .username(RandomStringUtils.randomAlphanumeric(16))
- .nickname(RandomStringUtils.randomAlphanumeric(16))
- .build());
- record.setStatus(ApplyStatus.PASS);
- record.setUserId(user.getId());
- } else {
- Institution byUserId = institutionRepo.findByUserId(userId);
- if (ObjectUtil.isNotNull(byUserId)) {
- throw new BusinessException("已申请");
- }
- Personal personal = personalRepo.findByUserId(userId);
- if (ObjectUtil.isNotNull(personal)) {
- throw new BusinessException("已申请个人认证");
- }
- record.setUserId(userId);
- record.setStatus(ApplyStatus.PENDING);
- }
- return institutionRepo.save(record);
- }
- //@PreAuthorize("hasRole('ADMIN')")
- @PostMapping("/all")
- public Page<InstitutionDTO> all(@RequestBody PageQuery pageQuery) {
- return institutionService.all(pageQuery);
- }
- @GetMapping("/get/{id}")
- public Institution get(@PathVariable Long id) {
- return institutionRepo.findById(id).orElseThrow(new BusinessException("无记录"));
- }
- @PostMapping("/del/{id}")
- public void del(@PathVariable Long id) {
- Institution institution = institutionRepo.findById(id).orElseThrow(new BusinessException("无记录"));
- userRepo.findById(institution.getUserId()).ifPresent(user -> {
- Set<Authority> authoritySet = user.getAuthorities();
- authoritySet.remove(Authority.get(AuthorityName.ROLE_INSTITUTION));
- userRepo.save(user);
- });
- institutionRepo.softDelete(id);
- }
- @GetMapping("/excel")
- @ResponseBody
- public void excel(HttpServletResponse response, PageQuery pageQuery) throws IOException {
- List<InstitutionDTO> data = all(pageQuery).getContent();
- ExcelUtils.export(response, data);
- }
- @PreAuthorize("hasRole('ADMIN')")
- @ApiOperation("审核")
- @PostMapping("/audit")
- public void audit(@RequestParam Long id, @RequestParam boolean pass, String remark) {
- institutionService.audit(id, pass, remark);
- }
- @PreAuthorize("hasRole('INSTITUTION')")
- @GetMapping("/my")
- public Institution my() {
- return institutionRepo.findByUserId(SecurityUtils.getAuthenticatedUser().getId());
- }
- }
|