| | |
| | | BaseResponse<TaskPersonDetailListResponse> response = HKService.taskPersoDetail(param); |
| | | if(response!=null |
| | | && StringUtils.equals(response.getCode(),HKConstants.RESPONSE_SUCCEE) && response.getData()!=null |
| | | ) { |
| | | ){ |
| | | if (response.getData().getList() != null |
| | | && response.getData().getList().size() > 0) { |
| | | TaskPersonDetailResponse model = response.getData().getList().get(0); |
| | |
| | | .set(Empower::getRemark, remark) |
| | | .set(Empower::getSendInfo, remark) |
| | | .set(Empower::getSendStatus, Constants.EmpowerStatus.pass)); |
| | | if(Constants.equalsInteger(c.getMemberDeleted(), Constants.ONE)&& Constants.equalsInteger(c.getIsdeleted(), Constants.ONE) ){ |
| | | //如果是删除权限成功,检查是否删除人员 |
| | | checkDelMemberTask(c.getMemberId(),c.getMemberHkId()); |
| | | } |
| | | } else { |
| | | empowerMapper.update(null, new UpdateWrapper<Empower>() |
| | | .lambda() |
| | |
| | | } else { |
| | | //如果是已删除的数据,下发失败(防止设备离线),则尝试重新下发任务 |
| | | if(Constants.equalsInteger(c.getIsdeleted(), Constants.ONE) ){ |
| | | // && Constants.formatIntegerNum(c.getTryNum())+1 < tryNum ){ |
| | | /* empowerMapper.update(null, new UpdateWrapper<Empower>() |
| | | .lambda() |
| | | .eq(Empower::getId, c.getId()) |
| | | .set(Empower::getRemark, "下发失败,等待重新删除权限") |
| | | .set(Empower::getTryNum,Constants.formatIntegerNum(c.getTryNum())+1) |
| | | .set(Empower::getSendInfo, "下发失败,等待重新删除权限") |
| | | .set(Empower::getSendStatus, Constants.EmpowerStatus.wait));*/ |
| | | empowerMapper.update(null, new UpdateWrapper<Empower>() |
| | | .lambda() |
| | | .eq(Empower::getId, c.getId()) |
| | | .set(Empower::getRemark, "删除权限下发失败") |
| | | .set(Empower::getSendInfo, "删除权限下发失败") |
| | | .set(Empower::getTryNum,Constants.formatIntegerNum(c.getTryNum())+1) |
| | | .set(Empower::getSendStatus, Constants.EmpowerStatus.fail)); |
| | | }else{ |
| | | empowerMapper.update(null, new UpdateWrapper<Empower>() |
| | | .lambda() |
| | | .eq(Empower::getId, c.getId()) |
| | | .set(Empower::getRemark, "下发失败") |
| | | .set(Empower::getTryNum,Constants.formatIntegerNum(c.getTryNum())+1) |
| | | .set(Empower::getSendInfo, "下发失败") |
| | | .set(Empower::getSendStatus, Constants.EmpowerStatus.fail)); |
| | | } |
| | | } |
| | | checkDelMemberTask(c.getMemberId()); |
| | | }else if(response!=null && StringUtils.equals(response.getCode(),HKConstants.RESPONSE_DOWNLOAD_ERROR) ){ |
| | | empowerMapper.update(null, new UpdateWrapper<Empower>() |
| | | .lambda() |
| | | .eq(Empower::getId, c.getId()) |
| | | .set(Empower::getRemark, "下发失败") |
| | | // .set(Empower::getFailFlag, Constants.ONE)//无需重发(下载任务不存在) |
| | | .set(Empower::getTryNum,Constants.formatIntegerNum(c.getTryNum())+1) |
| | | .set(Empower::getSendInfo, "下发失败") |
| | | .set(Empower::getSendStatus, Constants.EmpowerStatus.fail)); |
| | | } |
| | | } |
| | | }catch (Exception e){ |
| | |
| | | //标记删除成功的数据(海康对接状态为已同步,,同步失败的仍为待同步,等下一次继续处理,知道全部删除完毕) |
| | | memberMapper.update(null,new UpdateWrapper<Member>().lambda() |
| | | .set(Member::getHkStatus,Constants.ONE)//同步成功 |
| | | .set(Member::getRemark,"同步海康删除失败")//同步失败 |
| | | .set(Member::getRemark,"已同步")//同步失败 |
| | | .set(Member::getHkDate,date) |
| | | .in(Member::getId, id)); |
| | | //删除所有绑定的卡片信息 |
| | |
| | | /** |
| | | * 检查删除人员的权限是否都删除完成,如果权限删除完成, 进行海康人员的删除操作 |
| | | */ |
| | | private void checkDelMemberTask(Integer memberId) { |
| | | private void checkDelMemberTask(Integer memberId,String memberHkid) { |
| | | Date date = new Date(); |
| | | Member member = memberMapper.selectById(memberId); |
| | | if(member!=null && Constants.equalsInteger(member.getIsdeleted(),Constants.ONE) ){ |
| | | // Member member = memberMapper.selectById(memberId); |
| | | // if(member!=null && Constants.equalsInteger(member.getIsdeleted(),Constants.ONE) ){ |
| | | if(empowerMapper.selectCount(new QueryWrapper<Empower>().lambda() |
| | | .eq(Empower::getMemberId,member.getId()) |
| | | .eq(Empower::getMemberId,memberId) |
| | | .eq(Empower::getIsdeleted,Constants.ONE) |
| | | .ne(Empower::getFailFlag,Constants.ONE) |
| | | .ne(Empower::getSendStatus,Constants.EmpowerStatus.pass)) ==0){ |
| | | //如果权限都已经删除成功,则删除海康人员和卡片数据 |
| | | doHkDeleteUser(member.getId(),member.getHkId(),date); |
| | | } |
| | | doHkDeleteUser(memberId,memberHkid,date); |
| | | // } |
| | | } |
| | | } |
| | | |
| | |
| | | List<Empower> allList =getAllFailDealList( endId); |
| | | if(allList!=null && allList.size()>0){ |
| | | Date date = new Date(); |
| | | List<Integer> retryIds = new ArrayList<>(); |
| | | List<Integer> noIds = new ArrayList<>(); |
| | | for(Empower empower:allList){ |
| | | if(Constants.equalsObject(empower.getIsdeleted(),Constants.ONE)){ |
| | | //如果是删除的权限下发,查询是否伺候有下发成功的数据,如果有,则不处理 |
| | | Empower param = empowerMapper.selectOne(new QueryWrapper<Empower>().lambda() |
| | | .eq(Empower::getMemberId,empower.getMemberId()) |
| | | .eq(Empower::getDeviceId,empower.getDeviceId() ) |
| | | .gt(Empower::getId,empower.getId()) |
| | | .last("limit 1")); |
| | | if(empower ==null || Constants.equalsInteger(empower.getIsdeleted(),Constants.ONE)){ |
| | | // addIds.add(did); |
| | | } |
| | | //如果是删除的权限下发,查询是否伺候有下发成功的数据,如果有,则不处理 |
| | | if(empower.getId().equals(392479)){ |
| | | System.out.println("============================"); |
| | | } |
| | | //更新重新下发次数 |
| | | // int flag= empowerMapper.selectCount(new QueryWrapper<Empower>().lambda() |
| | | // .eq(Empower::getMemberId,empower.getMemberId()) |
| | | // .eq(Empower::getDeviceId,empower.getDeviceId() ) |
| | | // .gt(Empower::getId,empower.getId()) |
| | | // .last("limit 1")); |
| | | if(empower.getTempCouunt() ==0){ |
| | | retryIds.add(empower.getId()); |
| | | }else{ |
| | | //如果之后时间内又重新下发记录,则跳过不做处理 |
| | | noIds.add(empower.getId()); |
| | | } |
| | | } |
| | | |
| | | if(retryIds.size()>0){ |
| | | empowerMapper.update(null,new UpdateWrapper<Empower>().lambda() |
| | | .eq(Empower::getEditDate,date) |
| | | .setSql("try_num = ifnull(tyr_num,0) +1" ) |
| | | .set(Empower::getCreateDate,date) |
| | | .set(Empower::getSendStatus,Constants.EmpowerStatus.wait) |
| | | .set(Empower::getSendDate,null) |
| | | .set(Empower::getEditDate,date) |
| | | .set(Empower::getRemark,"下发失败,待重新下发~") |
| | | .set(Empower::getRemark,"下发失败,待重新下发~") |
| | | .eq(Empower::getId,empower.getId())); |
| | | .set(Empower::getSendInfo,"下发失败,待重新下发~") |
| | | .in(Empower::getId,retryIds)); |
| | | } |
| | | if(noIds.size()>0){ |
| | | empowerMapper.update(null,new UpdateWrapper<Empower>().lambda() |
| | | .set(Empower::getEditDate,date) |
| | | .set(Empower::getRemark,"下发失败,已失效~") |
| | | .set(Empower::getSendInfo,"下发失败,已失效~") |
| | | .set(Empower::getFailFlag,Constants.ONE) |
| | | .in(Empower::getId,noIds)); |
| | | } |
| | | return allList.get(allList.size()-1).getId(); |
| | | } |
| | |
| | | List<Empower> list = empowerMapper.selectJoinList(Empower.class,queryWrapper); |
| | | return list; |
| | | } |
| | | private List<Empower> getAllFailDealList(int endId ) { |
| | | private List<Empower> getAllFailDealList(int endId ) { |
| | | MPJLambdaWrapper<Empower> queryWrapper = new MPJLambdaWrapper<>(); |
| | | queryWrapper.selectAll(Empower.class); |
| | | queryWrapper.selectAs(Device::getChannelNo,Empower::getDeviceChannelNo); |
| | | queryWrapper.selectAs(Member::getHkStatus,Empower::getMemberHkStatus); |
| | | queryWrapper.selectAs(Member::getIsdeleted,Empower::getMemberDeleted); |
| | | queryWrapper.selectAs(Member::getHkId,Empower::getMemberHkId); |
| | | queryWrapper.selectAs(Device::getHkId,Empower::getDeviceIndexCode); |
| | | queryWrapper.selectAs(Device::getResourceType,Empower::getDeviceType); |
| | | queryWrapper.leftJoin(Device.class,Device::getId,Empower::getDeviceId); |
| | | queryWrapper.leftJoin(Member.class,Member::getId,Empower::getMemberId); |
| | | queryWrapper.select(Empower::getId,Empower::getMemberId,Empower::getDeviceId,Empower::getIsdeleted); |
| | | queryWrapper.select(" (select count(1) from empower ee where ee.member_id=t.MEMBER_ID and ee.device_id =t.DEVICE_ID and ee.id>t.id) as tempCouunt"); |
| | | queryWrapper.eq(Empower::getSendStatus,Constants.EmpowerStatus.fail); |
| | | queryWrapper.gt(Empower::getId,endId); |
| | | queryWrapper.orderByAsc(Empower::getId ); |
| | | // queryWrapper.orderByAsc(Empower::getCreateDate ); |
| | | queryWrapper.last("limit 100");//每次限制下发100个 |
| | | queryWrapper.ne( Empower::getFailFlag,Constants.ONE); |
| | | List<Empower> list = empowerMapper.selectJoinList(Empower.class,queryWrapper); |
| | | return list; |
| | | } |
| | |
| | | MPJLambdaWrapper<Empower> queryWrapper = new MPJLambdaWrapper<>(); |
| | | queryWrapper.selectAll(Empower.class); |
| | | queryWrapper.selectAs(Device::getChannelNo,Empower::getDeviceChannelNo); |
| | | queryWrapper.selectAs(Member::getIsdeleted,Empower::getMemberDeleted); |
| | | queryWrapper.selectAs(Member::getHkId,Empower::getMemberHkId); |
| | | queryWrapper.selectAs(Device::getHkId,Empower::getDeviceIndexCode); |
| | | queryWrapper.selectAs(Device::getResourceType,Empower::getDeviceType); |