From 36b753105aa294e6a34fd7acccbd26693b9b93d1 Mon Sep 17 00:00:00 2001
From: Junjie <xjj@123>
Date: 星期二, 23 四月 2024 13:51:31 +0800
Subject: [PATCH] #
---
zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/rcs/thread/FlowExecute.java | 177 +++++++++++++++++++++++++++++++++++++++++++++++++++-------
1 files changed, 154 insertions(+), 23 deletions(-)
diff --git a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/rcs/thread/FlowExecute.java b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/rcs/thread/FlowExecute.java
index f1158fe..5ba60e1 100644
--- a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/rcs/thread/FlowExecute.java
+++ b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/rcs/thread/FlowExecute.java
@@ -3,10 +3,22 @@
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.zy.asrs.framework.common.Cools;
+import com.zy.asrs.framework.exception.CoolException;
import com.zy.asrs.wcs.asrs.entity.param.FlowLogicCodeParam;
+import com.zy.asrs.wcs.core.entity.Task;
+import com.zy.asrs.wcs.core.service.TaskService;
+import com.zy.asrs.wcs.core.utils.RedisUtil;
+import com.zy.asrs.wcs.core.utils.ShuttleDispatcher;
+import com.zy.asrs.wcs.core.utils.Utils;
+import com.zy.asrs.wcs.rcs.cache.SlaveConnection;
+import com.zy.asrs.wcs.rcs.entity.Device;
+import com.zy.asrs.wcs.rcs.model.enums.SlaveType;
+import com.zy.asrs.wcs.rcs.model.protocol.ShuttleProtocol;
import org.apache.commons.codec.digest.DigestUtils;
import org.apache.commons.codec.digest.Md5Crypt;
+import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import java.util.List;
@@ -15,44 +27,65 @@
@Component
public class FlowExecute {
+ @Autowired
+ private RedisUtil redisUtil;
+ @Autowired
+ private TaskService taskService;
+ @Autowired
+ private ShuttleDispatcher shuttleDispatcher;
+
//鎵ц娴佺▼鍥�
public boolean execute(List<JSONObject> list) {
String currentId = list.get(0).getString("id");
- String listId = DigestUtils.md5Hex(JSON.toJSONString(list));
+ JSONObject devpType = list.get(0).getJSONObject("data").getJSONObject("devpType");
+ String staNo = devpType.getString("staNo");
+ //鎼滅储宸ヤ綔妗�
+ List<Task> tasks = taskService.list(new LambdaQueryWrapper<Task>()
+ .eq(Task::getOriginSite, staNo)
+ .eq(Task::getStatus, 1));
- while (currentId != null) {
- //鑾峰彇娴佺▼鍥�
- JSONObject flow = findFLow(list, currentId);
- if (flow == null) {
- break;
+ for (Task task : tasks) {
+ String redisKey = DigestUtils.md5Hex(JSON.toJSONString(list));
+
+ while (currentId != null) {
+ //鑾峰彇娴佺▼鍥�
+ JSONObject flow = findFLow(list, currentId);
+ if (flow == null) {
+ break;
+ }
+
+ //鎵ц
+ boolean result = executeFlow(task, flow, redisKey);
+
+ //鎵ц鍚庣画娴佺▼
+ if (Cools.isEmpty(flow.get("nextTrue")) && Cools.isEmpty(flow.get("nextFalse"))) {
+ break;//鏃犲悗缁祦绋�
+ }
+
+ //鏇存柊id
+ currentId = result ? flow.getString("nextTrue") : flow.getString("nextFalse");
}
- //鎵ц
- boolean result = executeFlow(flow, listId);
-
- //鎵ц鍚庣画娴佺▼
- if (Cools.isEmpty(flow.get("nextTrue")) && Cools.isEmpty(flow.get("nextFalse"))) {
- break;//鏃犲悗缁祦绋�
- }
-
- //鏇存柊id
- currentId = result ? flow.getString("nextTrue") : flow.getString("nextFalse");
+ System.out.println("鎵ц瀹屾垚");
+ redisUtil.del(redisKey);//閲婃斁缂撳瓨
}
-
- System.out.println("鎵ц瀹屾垚");
return true;
}
- private boolean executeFlow(JSONObject flow, String listId) {
+ private boolean executeFlow(Task task, JSONObject flow, String redisKey) {
System.out.println(flow.getString("id") + "琚墽琛�");
- String type = flow.getString("type");
+ JSONObject data = flow.getJSONObject("data");
+ String type = data.getString("type");
+ boolean result = false;
if (type.equals("devp")) {
-
+ result = executeDevpFlow(task, data, redisKey);
} else if (type.equals("shuttle")) {
-
+ result = executeShuttleFlow(task, data, redisKey);
+ } else if (type.equals("lift")) {
+ result = executeLiftFlow(task, data, redisKey);
}
- return true;
+ return result;
}
private JSONObject findFLow(List<JSONObject> list, String id) {
@@ -64,6 +97,104 @@
return null;
}
+ private boolean executeDevpFlow(Task task, JSONObject data, String redisKey) {
+ JSONObject devpType = data.getJSONObject("devpType");
+ String staNo = devpType.getString("staNo");
+ //鎼滅储宸ヤ綔
+
+ return true;
+ }
+
+ private boolean executeShuttleFlow(Task task, JSONObject data, String redisKey) {
+ JSONObject shuttleType = data.getJSONObject("shuttleType");
+ String oper = shuttleType.getString("shuttleOper");
+ if (oper.equals("searchIdleShuttle")) {
+ //鎼滅储绌洪棽杞�
+ ShuttleThread shuttleThread = shuttleDispatcher.searchIdleShuttle(task);
+ if (shuttleThread == null) {
+ throw new CoolException("绌挎杞︿笉瀛樺湪");
+ }
+ //瀛樺叆缂撳瓨
+ redisSet(redisKey, "shuttleDevice", shuttleThread.getDevice());
+ return true;
+ } else if (oper.equals("judgeShuttleCurrentTaskLev")) {
+ //鍒ゆ柇灏忚溅鏄惁鍦ㄤ换鍔℃ゼ灞�
+ //鍙栧嚭缂撳瓨灏忚溅
+ Object shuttleDeviceObj = redisGet(redisKey, "shuttleDevice");
+ if (shuttleDeviceObj == null) {
+ throw new CoolException("绌挎杞︾紦瀛樹负绌�");
+ }
+ Device device = JSON.parseObject(String.valueOf(shuttleDeviceObj), Device.class);
+ if (device == null) {
+ throw new CoolException("绌挎杞﹁澶囦笉瀛樺湪");
+ }
+
+ ShuttleThread shuttleThread = (ShuttleThread) SlaveConnection.get(SlaveType.Shuttle, device.getId().intValue());
+ if (shuttleThread == null) {
+ throw new CoolException("绌挎杞︿笉瀛樺湪");
+ }
+
+ ShuttleProtocol shuttleProtocol = shuttleThread.getStatus();
+ if (shuttleProtocol == null) {
+ throw new CoolException("绌挎杞︿笉瀛樺湪");
+ }
+
+ //灏忚溅鍧愭爣
+ String shuttleLocNo = shuttleProtocol.getCurrentLocNo();
+ String taskLocNo = null;
+ if (task.getTaskSts() < 100) {
+ taskLocNo = task.getDestLoc();
+ } else if (task.getTaskSts() > 100 && task.getTaskSts() < 200) {
+ taskLocNo = task.getOriginLoc();
+ }
+
+ // 灏忚溅鍜屼换鍔℃ゼ灞備竴鑷�
+ if (Utils.getLev(shuttleLocNo) == Utils.getLev(taskLocNo)) {
+ return true;
+ }else {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ private boolean executeLiftFlow(Task task, JSONObject data, String redisKey) {
+ JSONObject liftType = data.getJSONObject("liftType");
+ String oper = liftType.getString("liftOper");
+ if (oper.equals("move")) {
+ //鎻愬崌鏈哄崌闄�
+ }
+
+ return true;
+ }
+
+ private boolean redisSet(String redisKey, String key, Object data) {
+ if (redisUtil.hasKey(redisKey)) {
+ Object obj = redisUtil.get(redisKey);
+ JSONObject object = JSON.parseObject(String.valueOf(obj));
+ object.put(key, data);
+ redisUtil.set(redisKey, JSON.toJSONString(object));
+ } else {
+ JSONObject object = new JSONObject();
+ object.put(key, data);
+ redisUtil.set(redisKey, JSON.toJSONString(object));
+ }
+ return true;
+ }
+
+ private Object redisGet(String redisKey, String key) {
+ if (redisUtil.hasKey(redisKey)) {
+ Object obj = redisUtil.get(redisKey);
+ JSONObject object = JSON.parseObject(String.valueOf(obj));
+ if (!object.containsKey(key)) {
+ return null;
+ }
+ return object.get(key);
+ }
+ return null;
+ }
+
// private boolean executeFlow(List<Map<String, Object>> list) {
// for (Map<String, Object> map : list) {
// JSONObject data = (JSONObject) map.get("data");
--
Gitblit v1.9.1