From 71f61d13531b3e2a0099ba5afe3f268c99c5bacf Mon Sep 17 00:00:00 2001 From: zxl <763096477@qq.com> Date: 星期四, 29 五月 2025 18:13:33 +0800 Subject: [PATCH] 修改大屏录像可用率指标,点位在线指标,数据中心录像可用率, --- ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java | 119 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 118 insertions(+), 1 deletions(-) diff --git a/ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java b/ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java index 45b302c..d557e97 100644 --- a/ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java +++ b/ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java @@ -8,6 +8,7 @@ import com.baomidou.mybatisplus.extension.conditions.query.LambdaQueryChainWrapper; import com.baomidou.mybatisplus.extension.conditions.update.LambdaUpdateChainWrapper; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.github.pagehelper.util.StringUtil; import com.ycl.config.PlatformConfig; import com.ycl.exception.ServiceException; import com.ycl.platform.domain.entity.*; @@ -30,6 +31,7 @@ import com.ycl.system.mapper.SysConfigMapper; import com.ycl.system.model.LoginUser; import com.ycl.system.page.PageUtil; +import com.ycl.task.DeleteWorkOrderImgTask; import com.ycl.utils.DateUtils; import com.ycl.utils.SecurityUtils; import com.ycl.utils.http.HttpUtils; @@ -60,7 +62,9 @@ import org.springframework.util.CollectionUtils; import org.springframework.util.StringUtils; import pojo.CascadeOption; +import utils.file.FileUtils; +import java.time.LocalDate; import java.time.LocalDateTime; import java.time.ZoneId; import java.util.*; @@ -104,6 +108,8 @@ @Autowired private RedisCache redisCache; + @Autowired + private DeleteWorkOrderImgTask deleteWorkOrderImgTask; @Override public synchronized Boolean innerAddWorkOrder(List<WorkOrder> workOrderList) { @@ -215,6 +221,7 @@ } List<String> willAddSerialNumber = waitAddList.stream().map(WorkOrder::getSerialNumber).collect(Collectors.toList()); //鍙敓鎴愯�冩牳璁惧銆佷笖鏈夎繍缁村崟浣嶇殑宸ュ崟 + List<YwPoint> pointList = new LambdaQueryChainWrapper<>(ywPointService.getBaseMapper()) .select(YwPoint::getUnitId, YwPoint::getSerialNumber, YwPoint::getImportantTag, YwPoint::getImportantTag, YwPoint::getImportantCommandImageTag) .in(YwPoint::getSerialNumber, willAddSerialNumber) @@ -287,6 +294,7 @@ } log.info("鍗冲皢鐢熸垚鐨勫伐鍗�:{}", workOrder); } + redisCache.setCacheObject(RedisConstant.WORKORDER_NUM, workOrderNum); redisCache.releaseLock(RedisConstant.WORKORDER_NUM_LOCK, requestId); // 淇濆瓨宸ュ崟鍜屾晠闅滅被鍨� @@ -536,7 +544,7 @@ ywPointService.updateRecovery(serialNumbers, 0); //绛涢�夊嚭绂荤嚎宸ュ崟ip骞朵慨鏀瑰湪绾跨姸鎬� if (!CollectionUtils.isEmpty(serialNumbers)) { - Map<String, List<String>> errorTypes = workOrderErrorTypeMapper.getErrorListByNumbers(serialNumbers).stream().collect(Collectors.groupingBy( + Map<String, List<String>> errorTypes = workOrderErrorTypeMapper.getErrorListByNumbers(workOrderNoList).stream().collect(Collectors.groupingBy( WorkOrderVO::getIp, Collectors.mapping( WorkOrderVO::getErrorType, @@ -605,9 +613,41 @@ img.setWorkOrderNo(workOrder.getWorkOrderNo()); img.setImgUrl(frameImg); img.setCreateTime(new Date()); + //淇濈暀鏈�鏂扮殑5寮� workOrderCheckImgMapper.insert(img); } } + + /** + * 娓呯悊宸ュ崟鍥剧墖 + * */ + public void clearWorkOrderImg(String workOrderNo) { + //鍒ゆ柇璇ュ伐鍗曠殑鍥剧墖鏄惁宸茬粡澶т簬5寮犱簡 + //鎸夌収鍒涘缓鏃ユ湡闄嶅簭鎺掑垪 + if (StringUtil.isEmpty(workOrderNo)) { + return; + } + List<WorkOrderCheckImg> workOrderList = new LambdaQueryChainWrapper<WorkOrderCheckImg>(workOrderCheckImgMapper) + .select() + .eq(WorkOrderCheckImg::getWorkOrderNo, workOrderNo) + .orderByDesc(WorkOrderCheckImg::getCreateTime) + .list(); + if (workOrderList.size()>=5){ + List<String> imgList = workOrderList.subList(4,workOrderList.size()).stream().map(WorkOrderCheckImg::getImgUrl).collect(Collectors.toList()); + List<Integer> idList = workOrderList.subList(4, workOrderList.size()).stream().map(WorkOrderCheckImg::getId).collect(Collectors.toList()); + //鍒犻櫎鐓х墖 锛屽苟涓旂墿鐞嗗垹闄ゆ湇鍔″櫒鍐呭搴旂収鐗囩殑鍚嶅瓧 + +// /profile/2024-11-18_1d8e6d37-a4d0-4bba-8473-ff4e50eda83d.png + log.error("鍒犻櫎宸ュ崟鐓х墖闆嗗悎url:{}",imgList); + log.error("鍒犻櫎宸ュ崟瀛樺偍鏁版嵁闆嗗悎id:{}",idList); + for (String filePath: imgList){ + delImgFormClient(filePath); + } + workOrderCheckImgMapper.deleteBatchIds(idList); + } + + } + @Override public List<WorkOrderYwConditionRecordVO> selectYwConditionByYwId(String workOrderNo) { @@ -650,9 +690,29 @@ @Override public Result remove(List<String> ids) { if (baseMapper.deleteBatchIds(ids) > 0) { + //鎵归噺鍒犻櫎鏄惁琚敤鍒�? + return Result.ok("鍒犻櫎鎴愬姛"); } return Result.error("鍒犻櫎澶辫触"); + } + + /*** + * 閫氳繃url鍒犻櫎鏈嶅姟鍣ㄥ唴鐨勫浘鐗� + * @param url + */ + public void delImgFormClient(String url){ + //鎻愬彇鏂囦欢鍚� /profile/2024-11-17_79c02666-da1e-45ba-9f29-7523c848fa4a.png + // 杩欓儴鍒�2024-11-17_79c02666-da1e-45ba-9f29-7523c848fa4a.png + String imgPath = FileUtils.getImgName(url); + if (imgPath.isEmpty()){ + log.error("url閿欒锛歿}",imgPath); + }else{ + //鎻愬彇鏃ユ湡閮ㄥ垎 缁勮鐩綍 : /opt/zgyw/uploadPath + / + yyyy-MM-dd + + String pathName = DeleteWorkOrderImgTask.imgSaveBasePath + "/" + FileUtils.extractDateFromString(url); + log.error("鍒犻櫎宸ュ崟鍥剧墖闆嗗悎{}",pathName+"/" + imgPath); + FileUtils.deleteFile(pathName+"/" + imgPath); + } } /** @@ -667,6 +727,18 @@ String workOrderNo = workOrder.getWorkOrderNo(); //鍒犻櫎宸ュ崟瀹℃牳璁板綍 workOrderAuditingRecordMapper.delete(new QueryWrapper<WorkOrderAuditingRecord>().eq("work_order_no", workOrderNo)); + //闇�瑕佺墿鐞嗗垹闄ゆ湇鍔″櫒涓殑鍥剧墖 + //鏌ヨ鍒板伐鍗曠収鐗囬泦鍚� + List<String> workOrderImg = workOrderCheckImgMapper + .selectList(new QueryWrapper<WorkOrderCheckImg>().eq("work_order_no", workOrderNo)) + .stream().map(WorkOrderCheckImg::getImgUrl).collect(Collectors.toList()); + log.error("鍒犻櫎宸ュ崟鍥剧墖闆嗗悎:{}",workOrderImg); + log.error("鍒犻櫎璺緞:{}",PlatformConfig.getUploadPath()); + + for (String filePath: workOrderImg){ + delImgFormClient(filePath); + } + //鍒犻櫎宸ュ崟鍥剧墖璁板綍 workOrderCheckImgMapper.delete(new QueryWrapper<WorkOrderCheckImg>().eq("work_order_no", workOrderNo)); //鍒犻櫎宸ュ崟涓嬪彂璁板綍 @@ -681,6 +753,9 @@ } return Result.error("鍒犻櫎澶辫触"); } + + + /** * 鍒嗛〉鏌ヨ @@ -745,6 +820,11 @@ } @Override + public List<WorkOrderVO> distributeList(){ + return baseMapper.distributeList(); + } + + @Override @Transactional public Result distributeFast(DistributeWorkOrderVO data) { // 鑾峰彇褰撳墠鏃堕棿 @@ -800,6 +880,9 @@ distributeUnLock(); } } + + + @Override @Transactional @@ -1147,6 +1230,11 @@ @Override public Result detailByNo(String workOrderNo) { WorkOrderDetailVO workOrder = baseMapper.detailByNo(workOrderNo); + //鎶ョ┖鍘熷洜1. sql 涓� inner join 琛� t_work_order_distribute_record 涓� 鏃犱笌璇ヨ〃鍏宠仈鐨勮褰� wo.work_order_no = dr.work_order_no + if(workOrder == null){ + workOrder = baseMapper.detailByNoButNoDistributeRecord(workOrderNo); + } + // 鏄惁鎶ュ boolean hasReport = new LambdaQueryChainWrapper<>(reportMapper) .eq(Report::getSerialNumber, workOrder.getSerialNumber()) @@ -1156,6 +1244,8 @@ List<SysDictData> errorList = workOrderErrorTypeService.getBaseMapper().getErrorList(workOrder.getWorkOrderNo()); List<String> errList = errorList.stream().map(SysDictData::getDictLabel).collect(Collectors.toList()); workOrder.setErrorTypeList(errList); + //璇︽儏鏃跺啀娆℃竻鐞� + clearWorkOrderImg(workOrderNo); // 妫�娴嬪浘鐗� List<WorkOrderCheckImg> imgList = new LambdaQueryChainWrapper<>(workOrderCheckImgMapper) .eq(WorkOrderCheckImg::getWorkOrderNo, workOrderNo) @@ -1165,6 +1255,9 @@ workOrder.setImgList(imgList); return Result.ok().data(workOrder); } + + @Autowired + private WorkOrderMapper workOrderMapper; /** * 宸ュ崟瀵煎嚭鐨勯�昏緫 @@ -1195,6 +1288,30 @@ query.setErrorTypeList(errorTypeList); } List<WorkOrderVO> export = baseMapper.export(query); + + + List<String> workOrderNos = export.stream().map(WorkOrderVO::getWorkOrderNo).collect(Collectors.toList()); + List<WorkOrderVO> auditTimeList = workOrderMapper.getAuditTimeList(workOrderNos); + Map<String, List<Date>> auditTimeMap = auditTimeList.stream() + .collect(Collectors.groupingBy( + WorkOrderVO::getWorkOrderNo, // 鍒嗙粍鐨勯敭 + Collectors.mapping(WorkOrderVO::getAuditTime, Collectors.toList()))); + if (!CollectionUtils.isEmpty(workOrderNos)){ + export.forEach(workOrderVO -> { + List<Date> auditTimes = auditTimeMap.get(workOrderVO.getWorkOrderNo()); + if (!CollectionUtils.isEmpty(auditTimes)){ + //瀹℃牳閫氳繃鏃堕棿 + Date passTime = Collections.max(auditTimes); + ZoneId zoneId = ZoneId.systemDefault(); + workOrderVO.setPassTime(passTime.toInstant().atZone(zoneId).toLocalDateTime()); + } + }); + } + + + + + if (CollectionUtils.isEmpty(export)) return new ArrayList<WorkOrderVO>(); List<String> ips = export.stream().map(WorkOrderVO::getIp).collect(Collectors.toList()); //鏌ュ嚭鐩稿悓ip鐨勮澶囥�佸苟鏌ュ嚭鏍囩 -- Gitblit v1.8.0