From 038634540d95d4a5787b80a1fbab131df4d99823 Mon Sep 17 00:00:00 2001
From: zhang <zc857179121@qq.com>
Date: 星期一, 13 四月 2026 17:11:09 +0800
Subject: [PATCH] 1

---
 zy-asc-conveyor/src/main/java/com/zy/acs/conveyor/core/operation/handler/SendTaskOperationHandler.java |   73 ++++++++++++++++++++++++------------
 1 files changed, 48 insertions(+), 25 deletions(-)

diff --git a/zy-asc-conveyor/src/main/java/com/zy/acs/conveyor/core/operation/handler/SendTaskOperationHandler.java b/zy-asc-conveyor/src/main/java/com/zy/acs/conveyor/core/operation/handler/SendTaskOperationHandler.java
index 8132323..7a2e31d 100644
--- a/zy-asc-conveyor/src/main/java/com/zy/acs/conveyor/core/operation/handler/SendTaskOperationHandler.java
+++ b/zy-asc-conveyor/src/main/java/com/zy/acs/conveyor/core/operation/handler/SendTaskOperationHandler.java
@@ -1,17 +1,18 @@
 package com.zy.acs.conveyor.core.operation.handler;
 
 
+import com.alibaba.fastjson.JSON;
+import com.zy.acs.common.utils.News;
+import com.zy.acs.common.utils.RedisSupport;
 import com.zy.acs.conveyor.controller.vo.OpenBusSubmitParam;
 import com.zy.acs.conveyor.controller.vo.TaskDto;
-import com.zy.acs.conveyor.core.cache.SlaveConnection;
 import com.zy.acs.conveyor.core.enums.ConveyorStateType;
-import com.zy.acs.conveyor.core.enums.SlaveType;
-import com.zy.acs.conveyor.core.properties.DevpSlave;
-import com.zy.acs.conveyor.core.model.protocol.StaProtocol;
+import com.zy.acs.conveyor.core.model.StaProtocol;
 import com.zy.acs.conveyor.core.operation.OperationHandler;
 import com.zy.acs.conveyor.core.properties.CtuOperationConfig;
+import com.zy.acs.conveyor.core.properties.DevpSlave;
 import com.zy.acs.conveyor.core.properties.SlaveProperties;
-import com.zy.acs.conveyor.core.thread.SiemensDevpThread;
+import com.zy.acs.conveyor.core.service.StationService;
 import com.zy.acs.conveyor.entity.Job;
 import com.zy.acs.conveyor.service.CtuMainService;
 import com.zy.acs.conveyor.service.JobService;
@@ -23,6 +24,7 @@
 import java.util.ArrayList;
 import java.util.Date;
 import java.util.List;
+import java.util.Map;
 
 /**
  * 鍙戦�佷换鍔$粰RCS
@@ -42,6 +44,14 @@
     @Autowired
     private CtuMainService ctuMainService;
 
+
+    @Autowired
+    private StationService stationService;
+
+
+    private final RedisSupport redis = RedisSupport.defaultRedisSupport;
+
+
     @Override
     public ConveyorStateType getType() {
         return ConveyorStateType.SENDTASK;
@@ -55,39 +65,52 @@
                 // 閬嶅巻鍏ュ簱鍙�
                 for (DevpSlave.Sta inSta : devp.getInSta()) {
                     // 鏍规嵁杈撻�佺嚎plc閬嶅巻
-                    SiemensDevpThread devpThread = (SiemensDevpThread) SlaveConnection.get(SlaveType.Devp, devp.getId());
-                    StaProtocol staProtocol = devpThread.getStation().get(inSta.getTargetSta());
+                    Map<Integer, StaProtocol> stationMap = stationService.getStationMap(devp.getId());
+                    StaProtocol staProtocol = stationMap.get(inSta.getTargetSta());
                     if (staProtocol == null) {
                         continue;
                     } else {
                         staProtocol = staProtocol.clone();
                     }
                     // 鍒ゆ柇鏄惁婊¤冻鏉′欢
-                    if (!staProtocol.isLoading()) {
-                        if (staProtocol.getWorkNo() > 0) {
-                            log.error("杈撻�佺嚎涓婃湁浠诲姟鍙锋棤璐э紝闇�瑕佷汉宸ュ鐞嗭細{}", staProtocol.getSiteId());
-                        }
+                    if (staProtocol.getWorkNo() == 0 && staProtocol.isLoading()) {
+                        News.error("{},杈撻�佺嚎涓婃湁璐ф棤浠诲姟鍙凤紝闇�瑕佷汉宸ュ鐞嗙珯鐐癸細{}", config.getMark(), staProtocol.getSiteId());
                         continue;
                     }
-                    if (staProtocol.getWorkNo() == 0) {
-                        log.error("杈撻�佺嚎涓婃湁璐ф棤浠诲姟鍙凤紝闇�瑕佷汉宸ュ鐞嗭細{}", staProtocol.getSiteId());
+                    if (staProtocol.getWorkNo() > 0 && !staProtocol.isLoading()) {
+                        News.error("{},杈撻�佺嚎涓婃棤璐ф湁浠诲姟鍙凤紝闇�瑕佷汉宸ュ鐞嗙珯鐐癸細{}", config.getMark(), staProtocol.getSiteId());
                         continue;
                     }
-                    if (staProtocol.isAutoing()) {
-                        Job job = jobService.getJobByJobNoAndJobSts(staProtocol.getWorkNo(),ConveyorStateType.INBOUND.getStatus());
-                        if (job != null  ) {
-                            if (ctuMainService.sendTask(process(job))) {
-                                job.setJobSts(ConveyorStateType.SENDTASK.getStatus());
-                                job.setRcsTime(new Date());
-                                jobService.updateById(job);
-                                log.info("浠诲姟鍙戦�佺粰RCS鎴愬姛,WMS浠诲姟鍙凤細{},杈撻�佺嚎宸ヤ綔鍙凤細{}", job.getTaskNo(), job.getJobNo());
-                            } else {
-                                log.info("浠诲姟鍙戦�佺粰RCS澶辫触,WMS浠诲姟鍙凤細{},杈撻�佺嚎宸ヤ綔鍙凤細{}", job.getTaskNo(), job.getJobNo());
-                            }
+                    if (!staProtocol.isAutoing()) {
+                        News.error("{}锛氱珯鐐癸細{}锛岄潪鑷姩", config.getMark(), staProtocol.getSiteId());
+                        continue;
+                    }
+                    if (staProtocol.isInEnable()) {
+                        News.error("{},绔欑偣锛歿},娌℃湁鍙叆淇″彿", config.getMark(), staProtocol.getSiteId());
+                        continue;
+                    }
+                    Job jobByJobNo = jobService.getJobByJobNo(staProtocol.getWorkNo());
+                    if (jobByJobNo == null) {
+                        News.error("{}锛氱珯鐐癸細{}锛屾壘涓嶅埌浠诲姟", config.getMark(), staProtocol.getSiteId());
+                        continue;
+                    }
+                    if (jobByJobNo.getJobSts() != ConveyorStateType.INBOUND.getStatus()) {
+                        if (jobByJobNo.getJobSts() == ConveyorStateType.SENDTASK.getStatus()){
+                            continue;
                         }
+                        News.error("{}锛氱珯鐐癸細{}锛屼换鍔$姸鎬佷笉瀵癸紝{}", config.getMark(), staProtocol.getSiteId(), JSON.toJSON(jobByJobNo));
+                        continue;
+                    }
+
+                    if (ctuMainService.sendTask(process(jobByJobNo))) {
+                        jobByJobNo.setJobSts(ConveyorStateType.SENDTASK.getStatus());
+                        jobByJobNo.setRcsTime(new Date());
+                        jobService.updateById(jobByJobNo);
+                        News.error("{},浠诲姟鍙戦�佺粰RCS鎴愬姛,WMS浠诲姟鍙凤細{},杈撻�佺嚎宸ヤ綔鍙凤細{}", config.getMark(), jobByJobNo.getTaskNo(), jobByJobNo.getJobNo());
                     } else {
-                        log.error("杈撻�佺嚎涓鸿嚜鍔紝闇�瑕佸紑鍚細{}", staProtocol.getSiteId());
+                        News.error("{},浠诲姟鍙戦�佺粰RCS澶辫触,WMS浠诲姟鍙凤細{},杈撻�佺嚎宸ヤ綔鍙凤細{}", config.getMark(), jobByJobNo.getTaskNo(), jobByJobNo.getJobNo());
                     }
+
                 }
             }
         } catch (Exception e) {

--
Gitblit v1.9.1