From ca8f5a8f133e7f5b00b9d35ff6d15720804569af Mon Sep 17 00:00:00 2001 From: zyx <zyx123456> Date: 星期三, 31 一月 2024 10:15:32 +0800 Subject: [PATCH] Merge branch 'ryzhwcs' of http://47.97.1.152:5880/r/zy-wcs into ryzhwcs --- src/main/java/com/zy/asrs/controller/OpenController.java | 276 ++++++++++++++++++++++++++++++++++++++++++------------ 1 files changed, 212 insertions(+), 64 deletions(-) diff --git a/src/main/java/com/zy/asrs/controller/OpenController.java b/src/main/java/com/zy/asrs/controller/OpenController.java index 1ad9267..6e3ff59 100644 --- a/src/main/java/com/zy/asrs/controller/OpenController.java +++ b/src/main/java/com/zy/asrs/controller/OpenController.java @@ -2,26 +2,26 @@ import com.alibaba.fastjson.JSON; import com.baomidou.mybatisplus.mapper.EntityWrapper; +import com.core.annotations.AppAuth; import com.core.common.BaseRes; import com.core.common.Cools; import com.core.common.R; import com.core.exception.CoolException; -import com.zy.asrs.entity.BasDevp; -import com.zy.asrs.entity.CommandInfo; -import com.zy.asrs.entity.TaskWrk; -import com.zy.asrs.entity.WrkMast; +import com.zy.asrs.entity.*; +import com.zy.asrs.entity.param.TaskOverParam; import com.zy.asrs.entity.param.WMSAndAGVInterfaceParam; -import com.zy.asrs.entity.param.taskCreateParam; +import com.zy.asrs.entity.param.TaskCreateParam; import com.zy.asrs.service.*; import com.zy.common.web.BaseController; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Value; import org.springframework.transaction.annotation.Transactional; import org.springframework.web.bind.annotation.*; import javax.servlet.http.HttpServletRequest; -import java.util.ArrayList; -import java.util.List; +import java.io.IOException; +import java.util.*; @Slf4j @RestController @@ -38,17 +38,47 @@ private TaskWrkController taskWrkController; @Autowired private BasDevpService basDevpService; + @Autowired + private ApiLogService apiLogService; + @Autowired + private BasCrnpService basCrnpService; + @Autowired + private StaDescService staDescService; + @Autowired + private LocMastService locMastService; + + @Value("${wms.url}") + private String wmsUrl; private static final boolean auth = true; public static final ArrayList<String> APP_KEY_LIST = new ArrayList<String>() {{ add("ea1f0459efc02a79f046f982767939ae"); }}; + //agv浠诲姟瀹屾垚 + @PostMapping("/toAgvTaskOver") + @AppAuth(memo = "agv浠诲姟瀹屾垚鎺ュ彛") + public R getAgvTaskOver(@RequestHeader String appkey, + @RequestBody TaskOverParam param, + HttpServletRequest request){ + auth(appkey, param, request); + if (Cools.isEmpty(param)) { + return R.parse(BaseRes.PARAM); + } + if (Cools.isEmpty(param.getWharfCode())){ + return R.error("鐮佸ご[wharfCode]涓嶈兘涓虹┖"); + } + if (Cools.isEmpty(param.getStatus())){ + return R.error("瀹屾垚鏍囪[status]涓嶈兘涓虹┖"); + } + openService.getAgvTaskOver(param); + return R.ok(); + } //鍒涘缓浠诲姟 @PostMapping("/taskCreate") public R taskCreate(@RequestHeader String appkey, - @RequestBody taskCreateParam param, + @RequestBody TaskCreateParam param, HttpServletRequest request) { auth(appkey, param, request); if (Cools.isEmpty(param)) { @@ -108,9 +138,12 @@ //AGV璇锋眰鍏ュ簱鐮佸ご鎺ュ彛 @PostMapping("/targetWharfApply") + @AppAuth(memo = "AGV璇锋眰鍏ュ簱鐮佸ご鎺ュ彛") public R targetWharfApply(@RequestHeader String appkey, @RequestBody WMSAndAGVInterfaceParam param, - HttpServletRequest request) { + HttpServletRequest request) throws IOException { + auth(appkey,param,request); + if (Cools.isEmpty(param)){ return R.error("鍙傛暟涓虹┖锛�"); } else if (Cools.isEmpty(param.getTaskNo())){ @@ -122,19 +155,25 @@ } else if (Cools.isEmpty(param.getFreeWharfs()) || param.getFreeWharfs().size()==0){ return R.error("绌洪棽鐨勫叆搴撶爜澶达紙AGV锛変负绌猴紒"); } - TaskWrk taskWrk = taskWrkService.selectByTaskNo(param.getTaskNo()); - - if (Cools.isEmpty(taskWrk)){ - return R.error("鏈煡璇㈠埌浠诲姟锛屼换鍔″彿锛�"+param.getTaskNo()); - } - return R.ok(taskWrk.getStartPoint()); + R r = openService.AgvToWCSToWms(param); + apiLogService.save("AGV璇锋眰鍏ュ簱鐮佸ご鎺ュ彛" + ,request.getRemoteAddr()+request.getRequestURI() + ,appkey + ,request.getRemoteAddr() + ,JSON.toJSONString(param) + ,r.toString() + ,true + ); + return r; } //AGV璇锋眰鍔ㄤ綔鎺ュ彛 @PostMapping("/agvTaskRequest") + @AppAuth(memo = "AGV璇锋眰鍔ㄤ綔鎺ュ彛") public R agvTaskRequest(@RequestHeader String appkey, @RequestBody WMSAndAGVInterfaceParam param, HttpServletRequest request) { + auth(appkey, param, request); if (Cools.isEmpty(param)){ return R.error("鍙傛暟涓虹┖锛�"); } else if (Cools.isEmpty(param.getRequestType())){ @@ -143,17 +182,51 @@ return R.error("鐮佸ご缂栧彿涓虹┖锛�"); } - try{ - BasDevp basDevp = basDevpService.selectById(param.getWharfCode()); - if (basDevp.getAutoing().equals("Y") && basDevp.getLoading().equals("N")){ - return R.ok(); - }else { - return R.error(); - } - }catch (Exception e){ - log.error("AGV璇锋眰鍔ㄤ綔鎺ュ彛鎶ラ敊:"+e); - return R.error("绋嬪簭鎶ラ敊锛屾湭鏌ヨ鍒扮珯鐐�"); + Map<String,Integer> map = new HashMap<>(); + map.put("J-1102",102);map.put("J-1101",101); + map.put("J-1103",105);map.put("J-1104",106); + map.put("J-1105",109);map.put("J-1106",110); + map.put("J-1107",113);map.put("J-1108",114); + map.put("J-1109",117);map.put("J-1110",118); + map.put("J-1111",121);map.put("J-1112",122); + map.put("H-1102",300);map.put("H-1101",305); + map.put("G-1102",400);map.put("G-1101",405); +// StaDesc staDesc = staDescService.selectOne(new EntityWrapper<StaDesc>() +// .eq("stn_desc", param.getWharfCode())); +// +// if (Cools.isEmpty(staDesc)){ +// return R.error("绋嬪簭鎶ラ敊锛屾湭鏌ヨ鍒扮珯鐐�"); +// } + if (Cools.isEmpty(map.get(param.getWharfCode()))){ + return R.error("鏈煡璇㈠埌绔欑偣"); } + BasDevp basDevp = basDevpService.selectById(map.get(param.getWharfCode())); +// BasDevp basDevp = basDevpService.selectById(staDesc.getStnNo()); + if (basDevp.getAutoing().equals("Y") && (basDevp.getInEnable().equals("Y") || basDevp.getOutEnable().equals("Y"))){ + apiLogService.save("AGV璇锋眰鍏ュ簱鐮佸ご鎺ュ彛" + ,request.getRemoteAddr()+request.getRequestURI() + ,appkey + ,request.getRemoteAddr() + ,JSON.toJSONString(param) + ,R.ok().toString() + ,true + ); + return R.ok("鍙叆"); + }else { + apiLogService.save("AGV璇锋眰鍏ュ簱鐮佸ご鎺ュ彛" + ,request.getRemoteAddr()+request.getRequestURI() + ,appkey + ,request.getRemoteAddr() + ,JSON.toJSONString(param) + ,R.error("绔欑偣鐘舵�佷笉鍙叆").toString() + ,true + ); + return R.error("绔欑偣鐘舵�佷笉鍙叆"); + } + + + + } @@ -166,48 +239,91 @@ auth(appkey, params, request); List<WMSAndAGVInterfaceParam> params1 =new ArrayList<>(); for (WMSAndAGVInterfaceParam param:params){ - try { - if (Cools.isEmpty(param)){ - return R.error("鍙傛暟涓虹┖锛�"); - } else if (Cools.isEmpty(param.getTaskNo())){ - return R.error("浠诲姟鍙蜂负绌猴紒"); - } else if (Cools.isEmpty(param.getTaskType())){ - return R.error("浠诲姟绫诲瀷涓虹┖锛�"); - } else if (Cools.isEmpty(param.getWarehouseId())){ - return R.error("浠撳簱鏍囪瘑涓虹┖锛�"); - } - if (Cools.isEmpty(param.getTaskPriority())){ - param.setTaskPriority(1); - } - if (Cools.isEmpty(param.getContainerCode())){ - return R.error("瀹瑰櫒缂栫爜(鎵樼洏鐮�)涓虹┖锛�"); - } - if (Cools.isEmpty(param.getEmptyContainer())){ - return R.error("鏄惁绌烘墭鐩樹俊鍙蜂负绌猴紒"); - } -// if (Cools.isEmpty(param.getTaskTunnel())){ -// return R.error("浠诲姟宸烽亾涓虹┖锛�"); -// } -// if (Cools.isEmpty(param.getGroupNo())){ -// return R.error("浠诲姟缁勪负绌猴紒"); -// } -// if (Cools.isEmpty(param.getTaskSerialNo())){ -// return R.error("浠诲姟鎵ц椤哄簭涓虹┖锛�"); -// } - if (Cools.isEmpty(param.getTargetWharf())){ - return R.error("鐩爣鐮佸ご鍖哄煙涓虹┖锛�");//G寮�澶�=7杞﹂棿锛孒寮�澶�=8灞傦紝J寮�澶�=9杞﹂棿 - } - openService.taskCreate(new taskCreateParam(param)); - - params1.add(param); -// return R.ok(param); - }catch (Exception e){ - String errorMsg = Cools.isEmpty(e.getLocalizedMessage()) ? "" : e.getLocalizedMessage(); - return R.error("鐢熸垚浠诲姟澶辫触锛岃鑱旂郴绠$悊鍛�!"+ errorMsg); + if (Cools.isEmpty(param)){ + return R.error("鍙傛暟涓虹┖锛�"); + } else if (Cools.isEmpty(param.getTaskNo())){ + return R.error("浠诲姟鍙蜂负绌猴紒"); + } else if (Cools.isEmpty(param.getTaskType())){ + return R.error("浠诲姟绫诲瀷涓虹┖锛�"); + } else if (Cools.isEmpty(param.getWarehouseId())){ + return R.error("浠撳簱鏍囪瘑涓虹┖锛�"); } + if (Cools.isEmpty(param.getTaskPriority())){ + param.setTaskPriority(1); + } + if (Cools.isEmpty(param.getSourceLocationCode()) || Cools.isEmpty(param.getTargetLocationCode())){ + return R.error("鍒濆鐩爣鎴栬�呯洰鏍囦綅涓虹┖"); + } +// if (Cools.isEmpty(param.getContainerCode())){ +// return R.error("瀹瑰櫒缂栫爜(鎵樼洏鐮�)涓虹┖锛�"); +// } +// if (Cools.isEmpty(param.getEmptyContainer())){ +// return R.error("鏄惁绌烘墭鐩樹俊鍙蜂负绌猴紒"); +// } +// if (!param.getTaskType().equals("YK")){ +// if (Cools.isEmpty(param.getTargetWharf())){ +// return R.error("鐩爣鐮佸ご鍖哄煙涓虹┖锛�");//G寮�澶�=7杞﹂棿锛孒寮�澶�=8灞傦紝J寮�澶�=9杞﹂棿 +// } +// } + + LocMast locMast = locMastService.selectByLocNo(param.getSourceLocationCode()); + if(Cools.isEmpty(locMast)){ + return R.error("鍒濆搴撲綅鏃犳硶鎵惧埌"); + } + + Integer ioType = TaskCreateParam.convertParamIoType(param.getTaskType()); + if(ioType == 2){ + //鍑哄簱浠诲姟鍒涘缓 + StaDesc staDesc = staDescService.selectOne(new EntityWrapper<StaDesc>() + .eq("type_no",2) + .eq("crn_no",locMast.getCrnNo()) + .eq("stn_no",param.getTargetLocationCode())); + if(Cools.isEmpty(staDesc)){ + return R.error("鍑哄簱璺姴涓嶅瓨鍦�"); + } + param.setTargetLocationCode(staDesc.getStnNo().toString()); + R r = openService.taskCreate(new TaskCreateParam(param)); + }else if (ioType == 3){ + //绉诲簱浠诲姟鍒涘缓 + + } + +// if (param.getTaskType().equals("CK") && param.getTargetWharf().contains("J")){ +// staDesc = staDescService.selectOne(new EntityWrapper<StaDesc>() +// .eq("crn_no",param.getTaskTunnel()) +// .eq("type_no",2) +// .lt("stn_no",200)); +// }else if (param.getTaskType().equals("CK") && param.getTargetWharf().contains("H")){ +// staDesc = staDescService.selectOne(new EntityWrapper<StaDesc>() +// .eq("crn_no",param.getTaskTunnel()) +// .eq("type_no",2) +// .lt("stn_no",400) +// .gt("stn_no",200)); +// }else { +// staDesc = staDescService.selectOne(new EntityWrapper<StaDesc>() +// .eq("crn_no",param.getTaskTunnel()) +// .eq("type_no",2) +// .lt("stn_no",500) +// .ge("stn_no",400)); +// } + //param.setTargetLocationCode(staDesc.getStnNo().toString()); + + + R r = openService.taskCreate(new TaskCreateParam(param)); + + apiLogService.save("Wms浠诲姟涓嬪彂鎺ュ彛" + ,request.getRemoteAddr()+request.getRequestURI() + ,appkey + ,request.getRemoteAddr() + ,JSON.toJSONString(param) + ,r.toString() + ,true + ); + } - return R.ok(params1); + + return R.ok(); } //浠诲姟鍙栨秷鎺ュ彛 @@ -215,6 +331,7 @@ public R taskCancel(@RequestHeader String appkey, @RequestBody WMSAndAGVInterfaceParam param, HttpServletRequest request) { + auth(appkey, param, request); if (Cools.isEmpty(param)){ return R.error("鍙傛暟涓虹┖锛�"); } else if (Cools.isEmpty(param.getTaskNo())){ @@ -270,6 +387,37 @@ } } + //璁惧鐘舵�佹煡璇㈡帴鍙� + @PostMapping("/deviceStatus") + @Transactional + public R deviceStatus(@RequestHeader String appkey, + HttpServletRequest request) { + auth(appkey, "璁惧鐘舵�佹煡璇㈡帴鍙�", request); + List<BasDevp> basDevps = basDevpService.selectList(new EntityWrapper<>()); + List<Map<String, Object>> list = new ArrayList<>(); + for (BasDevp basDevp:basDevps){ + Map<String, Object> map = new HashMap<>(); + map.put("devNo", basDevp.getDevNo()); + map.put("devType", "杈撻�佺嚎"); + map.put("devStatus", basDevp.getAutoing().equals("Y")? 1:0); + map.put("errorCode", 0); + map.put("errorMsg", ""); + map.put("newDate",new Date()); + list.add(map); + } + List<BasCrnp> basCrnps = basCrnpService.selectList(new EntityWrapper<>()); + for (BasCrnp basCrnp:basCrnps){ + Map<String, Object> map = new HashMap<>(); + map.put("devNo", basCrnp.getCrnNo()); + map.put("devType", "鍫嗗灈鏈�"); + map.put("devStatus", basCrnp.getCrnSts()); + map.put("errorCode", 0); + map.put("errorMsg", ""); + map.put("newDate",new Date()); + list.add(map); + } + return R.ok(list); + } } -- Gitblit v1.9.1