package cn.wisenergy.chnmuseum.party.web.controller; import cn.wisenergy.chnmuseum.party.common.enums.AuditOperationEnum; import cn.wisenergy.chnmuseum.party.common.enums.AuditStatusEnum; import cn.wisenergy.chnmuseum.party.common.enums.AuditTypeEnum; import cn.wisenergy.chnmuseum.party.common.validator.groups.Update; import cn.wisenergy.chnmuseum.party.common.vo.GenericPageParam; import cn.wisenergy.chnmuseum.party.model.Audit; import cn.wisenergy.chnmuseum.party.model.TUser; import cn.wisenergy.chnmuseum.party.service.AuditService; import cn.wisenergy.chnmuseum.party.service.impl.TUserServiceImpl; import cn.wisenergy.chnmuseum.party.web.controller.base.BaseController; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import io.swagger.annotations.Api; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang3.StringUtils; import org.apache.shiro.authz.annotation.RequiresPermissions; import org.springframework.validation.annotation.Validated; import org.springframework.web.bind.annotation.*; import javax.annotation.Resource; import java.util.HashMap; import java.util.List; import java.util.Map; /** * <pre> * 禁用审核 前端控制器 * </pre> * * @author Danny Lee * @since 2021-03-26 */ @Slf4j @RestController @RequestMapping("/audit") @Api(tags = {"审核管理操作接口"}) public class AuditController extends BaseController { @Resource private AuditService auditService; @Resource private TUserServiceImpl userService; @GetMapping("/getUserList") @RequiresPermissions("/audit/getUserList") @ApiOperation(value = "获取用户禁用审核列表", notes = "获取用户禁用审核列表") @ApiImplicitParams(value = { @ApiImplicitParam(name = "_index", value = "分页起始偏移量", paramType = "query", dataType = "Integer"), @ApiImplicitParam(name = "_size", value = "返回条数", paramType = "query", dataType = "Integer"), @ApiImplicitParam(name = "name", value = "账号名称或提交人", paramType = "query", dataType = "String"), @ApiImplicitParam(name = "name", value = "账号名称或提交人", paramType = "query", dataType = "String"), @ApiImplicitParam(name = "status", value = "待初审 TBC, 驳回 REFUSED,待复审 TBCA, 通过APPROVED_FINAL", paramType = "query", dataType = "String"), @ApiImplicitParam(name = "level", value = "初审 TBC,复审 TBCA", paramType = "query", dataType = "String") }) public Map<String, Object> getUserList(String name, String status, String level) { Page<Audit> auditList; try { TUser user1 = getcurUser(); TUser user = new TUser(); if (StringUtils.isNotBlank(name)) { user.setUserName(name); } if (StringUtils.isNotBlank(status)) { user.setStatus(status); } if (StringUtils.isNotBlank(level)) { user.setAuditStatus(level); } user.setOrgCode(user1.getOrgCode()); auditList = auditService.getUserList(getPage(), user); return getResult(auditList); } catch (Exception e) { e.printStackTrace(); } return getFailResult(); } @PutMapping("/update") @RequiresPermissions("/audit/update") @ApiOperation(value = "修改禁用审核信息", notes = "修改禁用审核信息") public Map<String, Object> updateAudit(@Validated(value = {Update.class}) Audit audit) { boolean flag; if (!AuditStatusEnum.TBCA.name().equals(audit.getStatus())) { audit.setLevel(AuditStatusEnum.TBCA.name()); } if (!AuditStatusEnum.REFUSED.name().equals(audit.getStatus())) { audit.setRemarks(""); } try { if (AuditTypeEnum.ACCOUNT.name().equals(audit.getType())) { Audit audit1 = auditService.getById(audit.getId()); TUser user = new TUser(); user.setId(audit1.getRefItemId()); user.setAuditStatus(audit.getStatus()); if (AuditStatusEnum.APPROVED_FINAL.name().equals(audit.getStatus())) { user.setStatus(AuditOperationEnum.DISABLE.name()); } userService.updateById(user); } flag = auditService.updateById(audit); if (!flag) { return getFailResult(); } return getSuccessResult(); } catch (Exception e) { e.printStackTrace(); } return getFailResult(); } @DeleteMapping("/delete") @RequiresPermissions("/audit/delete") @ApiOperation(value = "根据ID删除禁用审核", notes = "根据ID删除禁用审核") @ApiImplicitParams(value = { @ApiImplicitParam(name = "id", value = "标识ID", paramType = "path", dataType = "String") }) public Map<String, Object> deleteAudit(@PathVariable("id") String id) { boolean result = auditService.removeById(id); if (result) { return getSuccessResult(); } return getFailResult(); } @GetMapping("/getList") @RequiresPermissions("/audit/getList") @ApiOperation(value = "获取禁用审核全部列表(无分页)", notes = "获取禁用审核全部列表(无分页)") @ApiImplicitParams(value = { @ApiImplicitParam(name = "auditStatus", value = "审核状态", paramType = "query", dataType = "String") }) public Map<String, Object> getAuditList(@RequestParam(value = "auditStatus", defaultValue = "APPROVED_FINAL", required = false) AuditStatusEnum auditStatus) { List<Audit> auditList = auditService.list(); return getResult(auditList); } @ApiImplicitParams(value = { @ApiImplicitParam(name = "_index", value = "分页起始偏移量", paramType = "query", dataType = "Integer"), @ApiImplicitParam(name = "_size", value = "返回条数", paramType = "query", dataType = "Integer"), @ApiImplicitParam(name = "nameOrCode", value = "名称或编码", paramType = "query", dataType = "String"), @ApiImplicitParam(name = "startDate", value = "创建时间-开始", paramType = "query", dataType = "String"), @ApiImplicitParam(name = "endDate", value = "创建时间-结束", paramType = "query", dataType = "String") }) @PostMapping("/getPageList") @RequiresPermissions("/audit/getPageList") @ApiOperation(value = "获取禁用审核分页列表", notes = "获取禁用审核分页列表") public Map<String, Object> getAuditPageList(GenericPageParam genericPageParam) { LambdaQueryWrapper<Audit> queryWrapper = new LambdaQueryWrapper<>(); // 对名称或编码模糊查询 if (StringUtils.isNotBlank(genericPageParam.getNameOrCode())) { queryWrapper.like(Audit::getContent, genericPageParam.getNameOrCode()); } // 根据创建时间区间检索 if (genericPageParam.getStartDate() != null && genericPageParam.getEndDate() != null) { queryWrapper.ge(Audit::getCreateTime, genericPageParam.getStartDate().atTime(0, 0, 0)) .le(Audit::getCreateTime, genericPageParam.getEndDate().atTime(23, 59, 59)); } // 设置排序规则 queryWrapper.orderByDesc(Audit::getCreateTime); // 设置查询内容 queryWrapper.select( Audit::getId, Audit::getContent, Audit::getCreateTime); Page<Audit> page = this.auditService.page(getPage(), queryWrapper); return getResult(page); } @ApiOperation(value = "获取禁用审核详情", notes = "获取禁用审核详情") @GetMapping("/getById") @RequiresPermissions("/audit/getById") public Map<String, Object> getById(String id) { HashMap<String, Object> resultMap = new HashMap<>(); try { Audit audit = new Audit(); UpdateWrapper<Audit> wrapper = new UpdateWrapper<>(); wrapper.eq("ref_item_id", id); audit = auditService.getOne(wrapper); resultMap.put("resultCode", "500"); resultMap.put("message", "用户未登录!"); resultMap.put("data", audit); return resultMap; } catch (Exception e) { e.printStackTrace(); } return getFailResult(); } }