From 4158164db6bbdbbcf2c2c096ba619307dc4148d8 Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期一, 17 十一月 2025 15:05:01 +0800
Subject: [PATCH] 任务下发功能优化

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/TaskSchedules.java  |   37 ++++++++++++++++++++++++++-----------
 rsf-server/src/main/java/com/vincent/rsf/server/system/constant/GlobalConfigCode.java |    2 ++
 2 files changed, 28 insertions(+), 11 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/TaskSchedules.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/TaskSchedules.java
index b9b3f16..810f26b 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/TaskSchedules.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/TaskSchedules.java
@@ -7,6 +7,7 @@
 import com.fasterxml.jackson.databind.ObjectMapper;
 import com.fasterxml.jackson.databind.cfg.CoercionAction;
 import com.fasterxml.jackson.databind.cfg.CoercionInputShape;
+import com.vincent.rsf.framework.common.DateUtils;
 import com.vincent.rsf.framework.common.R;
 import com.vincent.rsf.framework.exception.CoolException;
 import com.vincent.rsf.server.api.config.RemotesInfoProperties;
@@ -240,7 +241,7 @@
     /**
      * 闈炲厜鐢电珯鐐逛换鍔′笅鍙�
      */
-    @Scheduled(cron = "0/锛�5 * * * * ?  ")
+    @Scheduled(cron = "0/55 * * * * ?  ")
     @Transactional(rollbackFor = Exception.class)
     public void pubTaskToWcs() {
         Long loginUserId = SystemAuthUtils.getLoginUserId();
@@ -252,19 +253,33 @@
                 .in(Task::getTaskType, list)
                 .in(Task::getTaskStatus, integers)
                 .orderByDesc(Task::getSort));
-        for (Task task : tasks) {
-            /**绉诲簱涓嶅仛绔欑偣鎿嶄綔*/
-            if (!task.getTaskType().equals(TaskType.TASK_TYPE_LOC_MOVE.type)) {
-                BasStation station = basStationService.getOne(new LambdaQueryWrapper<BasStation>()
-                        .eq(BasStation::getStationName,
-                                task.getTaskStatus().equals(TaskStsType.GENERATE_IN.id) ? task.getOrgSite() : task.getTargSite()));
-                if (station.getType().equals(StationTypeEnum.STATION_TYPE_MUTI.type)) {
-                    continue;
+        if (tasks.isEmpty()) {
+            return;
+        }
+        Config config = configService.getOne(new LambdaQueryWrapper<Config>().eq(Config::getFlag, GlobalConfigCode.ALLOW_PUB_TASK));
+        if (!Objects.isNull(config) && !Objects.isNull(config.getVal())) {
+            Integer val = Integer.parseInt(config.getVal());
+            if (val > 1) {
+                List<Task> tasks1 = tasks.stream().sorted(Comparator.comparing(Task::getCreateTime)).collect(Collectors.toList());
+                Task task = tasks1.stream().findFirst().get();
+                if (DateUtils.diffToSeconds(task.getCreateTime(), new Date()) < val) {
+                    return;
                 }
             }
-            /**涓嬪彂鏅�氱珯鐐逛换鍔★紝鎶ラ敊鍥炴粴锛屼笉鍐嶅線涓嬫墽琛�*/
-            pubTaskToWcs(tasks);
         }
+//        for (Task task : tasks) {
+//            /**绉诲簱涓嶅仛绔欑偣鎿嶄綔*/
+//            if (!task.getTaskType().equals(TaskType.TASK_TYPE_LOC_MOVE.type)) {
+//                BasStation station = basStationService.getOne(new LambdaQueryWrapper<BasStation>()
+//                        .eq(BasStation::getStationName,
+//                                task.getTaskStatus().equals(TaskStsType.GENERATE_IN.id) ? task.getOrgSite() : task.getTargSite()));
+//                if (station.getType().equals(StationTypeEnum.STATION_TYPE_MUTI.type)) {
+//                    continue;
+//                }
+//            }
+//        }
+        /**涓嬪彂鏅�氱珯鐐逛换鍔★紝鎶ラ敊鍥炴粴锛屼笉鍐嶅線涓嬫墽琛�*/
+        pubTaskToWcs(tasks);
     }
 
     /**
diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/system/constant/GlobalConfigCode.java b/rsf-server/src/main/java/com/vincent/rsf/server/system/constant/GlobalConfigCode.java
index 9260e4b..3201de1 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/system/constant/GlobalConfigCode.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/system/constant/GlobalConfigCode.java
@@ -25,4 +25,6 @@
     /**娣辨祬搴撲綅绉诲姩浼樺寲*/
     public final static String ALLOW_MOVE_TO_DEEP_LOC = "AllowMoveToDeepLoc";
 
+    public final static String ALLOW_PUB_TASK = "AllowPubTask";
+
 }

--
Gitblit v1.9.1