package com.doumee.cloud.admin; import com.doumee.api.BaseController; import com.doumee.biz.system.SystemUserBiz; import com.doumee.config.DataSyncConfig; import com.doumee.config.annotation.CloudRequiredPermission; import com.doumee.config.annotation.LoginNoRequired; import com.doumee.core.annotation.excel.ExcelExporter; import com.doumee.core.annotation.pr.PreventRepeat; import com.doumee.core.annotation.trace.Trace; import com.doumee.core.model.ApiResponse; import com.doumee.core.model.PageData; import com.doumee.core.model.PageWrap; import com.doumee.core.utils.Constants; import com.doumee.dao.admin.request.LaborMemberDTO; import com.doumee.dao.admin.request.MemberImport; import com.doumee.dao.admin.request.MemberQuery; import com.doumee.dao.business.dto.RegisterDriverDTO; import com.doumee.dao.business.dto.ResetPasswordDTO; import com.doumee.dao.business.model.Member; import com.doumee.dao.business.model.MemberCard; import com.doumee.dao.business.model.MemberRole; import com.doumee.dao.system.dto.UpdatePwdDto; import com.doumee.service.business.MemberService; import com.doumee.service.business.ext.ERPSyncService; import com.doumee.service.business.impl.hksync.fhk.HkSyncOrgUserFromHKServiceImpl; import com.doumee.service.business.impl.hksync.fhk.HkSyncOrgUserFromSelfServiceImpl; import io.swagger.annotations.*; import org.apache.shiro.authz.annotation.RequiresPermissions; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.validation.annotation.Validated; import org.springframework.web.bind.annotation.*; import org.springframework.web.multipart.MultipartFile; import javax.servlet.http.HttpServletResponse; import java.io.File; import java.util.ArrayList; import java.util.List; /** * @author 江蹄蹄 * @date 2023/11/30 15:33 */ @Api(tags = "人员信息表") @RestController @RequestMapping(Constants.CLOUD_SERVICE_URL_INDEX+"/business/member") public class MemberCloudController extends BaseController { // @Autowired private ERPSyncService erpSyncService; @Autowired private HkSyncOrgUserFromHKServiceImpl hkSyncOrgUserFHKService; @Autowired private HkSyncOrgUserFromSelfServiceImpl hkSyncOrgUserFromSelfService; @Autowired private DataSyncConfig dataSyncConfig; @Autowired private MemberService memberService; @Autowired private SystemUserBiz systemUserBiz; @PreventRepeat @ApiOperation("新建") @PostMapping("/create") @CloudRequiredPermission("business:member:create") public ApiResponse create(@RequestBody Member member,@RequestHeader(Constants.HEADER_USER_TOKEN) String token) { if(Constants.formatIntegerNum(dataSyncConfig.getOrgUserDataOrigin()) == DataSyncConfig.origin.self){ member.setLoginUserInfo(this.getLoginUser(token)); Member insert = memberService.create(member); //创建人脸信息 return ApiResponse.success("操作成功!"); }else{ return ApiResponse.failed("对不起,无权限操作!"); } } @PreventRepeat @ApiOperation("创建劳务人员信息") @PostMapping("/laborMemberCreate") @CloudRequiredPermission("business:member:create") public ApiResponse laborMemberCreate(@RequestBody LaborMemberDTO member){ return ApiResponse.success(memberService.laborMemberCreate(member)); } @ApiOperation("根据ID删除") @GetMapping("/delete/{id}") @CloudRequiredPermission("business:member:delete") public ApiResponse deleteById(@PathVariable Integer id,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ memberService.deleteById(id,this.getLoginUser(token)); return ApiResponse.success(null); } @ApiOperation("批量删除") @GetMapping("/delete/batch") @CloudRequiredPermission("business:member:delete") public ApiResponse deleteByIdInBatch(@RequestParam String ids,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ String [] idArray = ids.split(","); List idList = new ArrayList<>(); for (String id : idArray ){ idList.add(Integer.valueOf(id)); } memberService.deleteByIdInBatch(idList,this.getLoginUser(token)); return ApiResponse.success(null); } @ApiOperation("员工权限下发") @GetMapping("/roleAuth/{id}") @CloudRequiredPermission("business:empower:create") public ApiResponse roleAuthById(@PathVariable Integer id,@RequestHeader(Constants.HEADER_USER_TOKEN) String token) { memberService.roleAuthById(id,this.getLoginUser(token)); return ApiResponse.success(null); } @ApiOperation("同步人脸信息") @PostMapping("/updateFace") public ApiResponse updateFace(@RequestBody Member member,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ member.setLoginUserInfo(this.getLoginUser(token)); memberService.updateFace(member); return ApiResponse.success(null); } @ApiOperation("批量授权下发") @PostMapping("/batchRoleAuth") public ApiResponse batchRoleAuth(@RequestBody Member memberRole, @RequestHeader(Constants.HEADER_USER_TOKEN) String token){ memberRole.setLoginUserInfo(this.getLoginUser(token)); memberService.batchRoleAuth(memberRole); return ApiResponse.success(null); } @ApiOperation("强制删除安防平台人员信息") @PostMapping("/delHkForce") public ApiResponse delHkForce(@RequestBody Member member,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ memberService.delHkForce(member); return ApiResponse.success(null); } @ApiOperation("重新下发人脸") @PostMapping("/empowerByList") public ApiResponse empowerByList(@RequestBody Member member,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ memberService.empowerByList(member); return ApiResponse.success(null); } @ApiOperation("根据ID修改") @PostMapping("/updateById") @CloudRequiredPermission("business:member:update") public ApiResponse updateById(@RequestBody Member member,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ member.setLoginUserInfo(this.getLoginUser(token)); memberService.updateById(member); return ApiResponse.success(null); } @ApiOperation("设置或取消主管") @PostMapping("/updateHead") @CloudRequiredPermission("business:member:head") public ApiResponse updateHead(@RequestBody Member member,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ member.setLoginUserInfo(this.getLoginUser(token)); memberService.updateHead(member); return ApiResponse.success(null); } @ApiOperation("根据ID 禁启用 ") @PostMapping("/updateStatusById") @CloudRequiredPermission("business:member:update") public ApiResponse updateStatusById(@RequestBody Member member,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ member.setLoginUserInfo(this.getLoginUser(token)); memberService.updateStatusById(member); return ApiResponse.success(null); } @ApiOperation("根据ID 设置在职、离职 ") @PostMapping("/updateWorkStatus") @CloudRequiredPermission("business:member:update") public ApiResponse updateWorkStatus(@RequestBody Member member,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ member.setLoginUserInfo(this.getLoginUser(token)); memberService.updateWorkStatus(member); return ApiResponse.success(null); } @ApiOperation(value = "人员信息导入" ,notes = "保单申请") @PostMapping("/importExcel") @ApiImplicitParams({ @ApiImplicitParam(name = "file", value = "file", required = true, paramType = "query", dataType = "file", dataTypeClass = File.class), @ApiImplicitParam(name = "组织类型 0相关方 1内部组织", value = "companyType", required = true, paramType = "query", dataType = "Integer",example = "0",dataTypeClass = Integer.class), }) @CloudRequiredPermission("business:member:create") public ApiResponse importExcel (@ApiParam(value = "file") MultipartFile file,@ApiParam(value = "companyType") Integer companyType, @RequestHeader(Constants.HEADER_USER_TOKEN) String token) { return ApiResponse.success(memberService.importBatch(file,companyType,this.getLoginUser(token))); } @ApiOperation("批量拉黑") @GetMapping("/batchBlock") @CloudRequiredPermission("business:member:update") public ApiResponse batchBlock(@RequestParam String ids,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ String [] idArray = ids.split(","); List idList = new ArrayList<>(); for (String id : idArray ){ idList.add(Integer.valueOf(id)); } memberService.batchBlock(idList,2,this.getLoginUser(token)); return ApiResponse.success(null); } @ApiOperation("批量冻结") @GetMapping("/batchFreeze") @CloudRequiredPermission("business:member:update") public ApiResponse batchFreeze(@RequestParam String ids,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ String [] idArray = ids.split(","); List idList = new ArrayList<>(); for (String id : idArray ){ idList.add(Integer.valueOf(id)); } memberService.batchBlock(idList,1,this.getLoginUser(token)); return ApiResponse.success(null); } @ApiOperation("批量移出黑名单") @GetMapping("/batchRemoveBlock") @CloudRequiredPermission("business:member:update") public ApiResponse batchCancelBlock(@RequestParam String ids,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ String [] idArray = ids.split(","); List idList = new ArrayList<>(); for (String id : idArray ){ idList.add(Integer.valueOf(id)); } memberService.batchRemoveBlock(idList,2,this.getLoginUser(token)); return ApiResponse.success(null); } @ApiOperation("批量解除冻结") @GetMapping("/batchRemoveFreeze") @CloudRequiredPermission("business:member:update") public ApiResponse batchRemoveFreeze(@RequestParam String ids,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ String [] idArray = ids.split(","); List idList = new ArrayList<>(); for (String id : idArray ){ idList.add(Integer.valueOf(id)); } memberService.batchRemoveBlock(idList,1,this.getLoginUser(token)); return ApiResponse.success(null); } @ApiOperation("是否可拜访状态修改") @PostMapping("/updateCanVisitById") @CloudRequiredPermission("business:member:update") public ApiResponse updateCanVisitById(@RequestBody Member member,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ member.setLoginUserInfo(this.getLoginUser(token)); memberService.updateCanVisitById(member); return ApiResponse.success(null); } @ApiOperation("分页查询") @PostMapping("/page") @CloudRequiredPermission("business:member:query") public ApiResponse> findPage (@RequestBody PageWrap pageWrap,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ return ApiResponse.success(memberService.findPage(pageWrap)); } @ApiOperation("查询全部") @PostMapping("/list") @CloudRequiredPermission("business:member:query") public ApiResponse> list (@RequestBody Member model,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ return ApiResponse.success(memberService.findList(model)); } @ApiOperation("查询全部司机") @PostMapping("/driveList") @CloudRequiredPermission("business:member:query") public ApiResponse> findDriveList (@RequestBody Member model,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ return ApiResponse.success(memberService.findDriveList(model)); } @ApiOperation("导出Excel") @PostMapping("/exportExcel") @CloudRequiredPermission("business:member:exportExcel") public void exportExcel (@RequestBody PageWrap pageWrap, HttpServletResponse response, @RequestHeader(Constants.HEADER_USER_TOKEN) String token){ List memberList = new ArrayList<>(); if(pageWrap.getModel().getType().equals(Constants.memberType.visitor)){ memberList = memberService.findVisitPage(pageWrap).getRecords(); }else if(pageWrap.getModel().getType().equals(Constants.memberType.internal)){ pageWrap.getModel().setLoginUserInfo(this.getLoginUser(token)); memberList = memberService.findMemberInfoPage(pageWrap).getRecords(); } ExcelExporter.build(Member.class).export(memberList, "人员信息表", response); } @ApiOperation("根据ID查询") @GetMapping("/{id}") @CloudRequiredPermission("business:member:query") public ApiResponse findById(@PathVariable Integer id,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ return ApiResponse.success(memberService.findById(id)); } /** * * 分页查询内部人员信息 * @param pageWrap * @return */ @ApiOperation("分页查询内部人员信息") @PostMapping("/findMemberInfoPage") @CloudRequiredPermission("business:member:query") public ApiResponse> findMemberInfoPage(@RequestBody PageWrap pageWrap,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ if(pageWrap.getModel().getType().equals(Constants.memberType.visitor)){ return ApiResponse.success(memberService.findVisitPage(pageWrap)); }else if(pageWrap.getModel().getType().equals(Constants.memberType.internal)){ pageWrap.getModel().setLoginUserInfo(this.getLoginUser(token)); return ApiResponse.success(memberService.findMemberInfoPage(pageWrap)); }else { return ApiResponse.success(null); } } @ApiOperation("分页查询访客人员信息") @PostMapping("/findVisitPage") @CloudRequiredPermission("business:member:query") public ApiResponse> findVisitPage (@RequestBody PageWrap pageWrap,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ return ApiResponse.success(memberService.findVisitPage(pageWrap)); } @ApiOperation("异常人员冻结/拉黑") @PostMapping("/findUnusualPage") @CloudRequiredPermission("business:member:query") public ApiResponse> findUnusualPage (@RequestBody PageWrap pageWrap,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ return ApiResponse.success(memberService.findUnusualPage(pageWrap)); } @ApiOperation("根据类型查询人员信息") @PostMapping("/findTypeMemberInfo") //@CloudRequiredPermission("business:member:query") public ApiResponse> findTypeMemberInfo (@RequestBody Member member,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ return ApiResponse.success(memberService.findList(member)); } @ApiOperation("全量信息同步") @PostMapping("/syncAll") @CloudRequiredPermission("business:member:sync") public ApiResponse sync(@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ if(Constants.formatIntegerNum(dataSyncConfig.getOrgUserDataOrigin()) == DataSyncConfig.origin.erp){ erpSyncService.syncUsers(null); }else if(Constants.formatIntegerNum(dataSyncConfig.getOrgUserDataOrigin()) == DataSyncConfig.origin.hk){ hkSyncOrgUserFHKService.syncUserData(this.getLoginUser(token)); }else if(Constants.formatIntegerNum(dataSyncConfig.getOrgUserDataOrigin()) == DataSyncConfig.origin.self){ hkSyncOrgUserFromSelfService.syncUserData(this.getLoginUser(token)); return ApiResponse.success("同步成功"); } return ApiResponse.success("同步成功"); } @ApiOperation("测试人员冻结") @PostMapping("/testFreeFz") public ApiResponse testFreeFz(@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ memberService.memberFreeze(); return ApiResponse.success(null); } @LoginNoRequired @ApiOperation("司机注册") @PostMapping("/registerDriver") public ApiResponse registerDriver(@RequestBody RegisterDriverDTO registerDriverDTO ){ memberService.registerDriver(registerDriverDTO); return ApiResponse.success("注册成功"); } @Trace(withRequestParameters = false) @ApiOperation("修改当前用户密码") @PostMapping("/updatePwd") public ApiResponse updatePwd (@RequestHeader(Constants.HEADER_USER_TOKEN) String token, @Validated @RequestBody UpdatePwdDto dto) { dto.setUserId(this.getLoginUser(token).getId()); systemUserBiz.updatePwd(dto); return ApiResponse.success(null); } /********************************************************阜宁运维*********************************************************************************************/ @PreventRepeat @ApiOperation("阜宁运维 - 新建") @PostMapping("/ywCreate") @CloudRequiredPermission("business:member:create") public ApiResponse ywCreate(@RequestBody Member member,@RequestHeader(Constants.HEADER_USER_TOKEN) String token) { member.setLoginUserInfo(this.getLoginUser(token)); memberService.ywCreate(member); return ApiResponse.success("操作成功!"); } @ApiOperation("阜宁运维 - 根据ID修改") @PostMapping("/ywUpdateById") @CloudRequiredPermission("business:member:update") public ApiResponse ywUpdateById(@RequestBody Member member,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ member.setLoginUserInfo(this.getLoginUser(token)); memberService.ywUpdate(member); return ApiResponse.success(null); } @ApiOperation("阜宁运维 - 查询列表") @PostMapping("/ywList") @CloudRequiredPermission("business:member:query") public ApiResponse> ywList (@RequestBody Member model,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ return ApiResponse.success(memberService.ywList(model)); } @ApiOperation("阜宁运维 - 分页查询") @PostMapping("/ywFindPage") @CloudRequiredPermission("business:member:query") public ApiResponse> ywFindPage (@RequestBody PageWrap pageWrap,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ return ApiResponse.success(memberService.ywFindPage(pageWrap)); } }