|  |  |  | 
|---|
|  |  |  | import com.baomidou.mybatisplus.mapper.EntityWrapper; | 
|---|
|  |  |  | import com.core.common.Cools; | 
|---|
|  |  |  | import com.core.common.R; | 
|---|
|  |  |  | import com.core.common.SpringUtils; | 
|---|
|  |  |  | import com.core.exception.CoolException; | 
|---|
|  |  |  | import com.zy.asrs.domain.enums.TaskStatusType; | 
|---|
|  |  |  | import com.zy.asrs.entity.StaDesc; | 
|---|
|  |  |  | import com.zy.asrs.entity.TaskWrk; | 
|---|
|  |  |  | import com.zy.asrs.entity.ToWmsDTO; | 
|---|
|  |  |  | import com.zy.asrs.domain.enums.WorkNoType; | 
|---|
|  |  |  | 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.service.ApiLogService; | 
|---|
|  |  |  | import com.zy.asrs.service.OpenService; | 
|---|
|  |  |  | import com.zy.asrs.service.StaDescService; | 
|---|
|  |  |  | import com.zy.asrs.service.TaskWrkService; | 
|---|
|  |  |  | import com.zy.asrs.entity.param.TaskCreateParam; | 
|---|
|  |  |  | import com.zy.asrs.service.*; | 
|---|
|  |  |  | import com.zy.asrs.utils.Utils; | 
|---|
|  |  |  | import com.zy.common.service.CommonService; | 
|---|
|  |  |  | import com.zy.common.utils.HttpHandler; | 
|---|
|  |  |  | import com.zy.core.DevpThread; | 
|---|
|  |  |  | import com.zy.core.cache.MessageQueue; | 
|---|
|  |  |  | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Value; | 
|---|
|  |  |  | import org.springframework.stereotype.Service; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import javax.servlet.http.HttpServletRequest; | 
|---|
|  |  |  | import java.io.IOException; | 
|---|
|  |  |  | import java.util.*; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private StaDescService staDescService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private CommonService commonService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private LocMastService locMastService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private BasDevpService basDevpService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Value("${wms.url}") | 
|---|
|  |  |  | private String wmsUrl; | 
|---|
|  |  |  | public ArrayList<String> wharfCode1 = new ArrayList<String>(){{ | 
|---|
|  |  |  | add("J-1101"); add("J-1103"); add("J-1105"); add("J-1107"); add("J-1109"); add("J-1111"); | 
|---|
|  |  |  | add("J-1101"); add("J-1103"); add("J-1105"); add("J-1107"); add("J-1109"); add("J-1111");add("H-1101"); | 
|---|
|  |  |  | add("G-1101"); | 
|---|
|  |  |  | }}; | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public R taskCreate(taskCreateParam param) { | 
|---|
|  |  |  | public R taskCreate(TaskCreateParam param) { | 
|---|
|  |  |  | TaskWrk taskWrk = taskWrkService.selectByTaskNo(param.getTaskNo()); | 
|---|
|  |  |  | if (taskWrk != null) { | 
|---|
|  |  |  | try{ | 
|---|
|  |  |  | DeviceErrorService deviceErrorService = SpringUtils.getBean(DeviceErrorService.class); | 
|---|
|  |  |  | deviceErrorService.addDeviceError("wms下发任务异常", 1, "任务已存在,请勿重复提交,taskWrk:"+JSON.toJSONString(taskWrk)); | 
|---|
|  |  |  | } catch (Exception e2){ | 
|---|
|  |  |  | //                    log.error("e2:"+e2.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | throw new CoolException(param.getTaskNo() + "任务已存在,请勿重复提交"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (param.getIoType().equals(0)){ | 
|---|
|  |  |  | try{ | 
|---|
|  |  |  | DeviceErrorService deviceErrorService = SpringUtils.getBean(DeviceErrorService.class); | 
|---|
|  |  |  | deviceErrorService.addDeviceError("wms下发任务异常", 1, "生成任务失败,任务类型不存在!,iotype:"+JSON.toJSONString(param.getIoType())); | 
|---|
|  |  |  | } catch (Exception e2){ | 
|---|
|  |  |  | //                    log.error("e2:"+e2.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | throw new CoolException("生成任务失败,任务类型不存在!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Date now = new Date(); | 
|---|
|  |  |  | taskWrk = new TaskWrk(); | 
|---|
|  |  |  | int workNo1 = 0;//获取入库工作号 | 
|---|
|  |  |  | if (param.getIoType() .equals(1)){ | 
|---|
|  |  |  | workNo1 = commonService.getWorkNo(WorkNoType.PAKIN.type); | 
|---|
|  |  |  | } else if (param.getIoType() .equals(2)){ | 
|---|
|  |  |  | workNo1 = commonService.getWorkNo(WorkNoType.PAKOUT.type); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | workNo1 = commonService.getWorkNo(WorkNoType.PICK.type); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | taskWrk.setTaskNo(param.getTaskNo());//任务号 | 
|---|
|  |  |  | taskWrk.setWrkNo(workNo1); | 
|---|
|  |  |  | taskWrk.setStatus(TaskStatusType.RECEIVE.id);//任务状态:接收 | 
|---|
|  |  |  | taskWrk.setCreateTime(now); | 
|---|
|  |  |  | taskWrk.setModiTime(now); | 
|---|
|  |  |  | taskWrk.setAssignTime(new Date()); | 
|---|
|  |  |  | taskWrk.setModiUser(6666L); | 
|---|
|  |  |  | //        try{ | 
|---|
|  |  |  | //            if (param.getIoType()>1){ | 
|---|
|  |  |  | //                LocMast locMast=locMastService.selectOne(new EntityWrapper<LocMast>().eq("loc_no",param.getStartPoint())); | 
|---|
|  |  |  | //                if (Utils.locNoRowBoolean(locMast.getRow1())){ | 
|---|
|  |  |  | //                      param.setTaskPriority(11); | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  | //        }catch (Exception e){ | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | taskWrk.setIoPri(param.getTaskPriority()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | taskWrk.setIoType(param.getIoType());//任务类型 | 
|---|
|  |  |  | taskWrk.setIoPri(param.getTaskPriority());//优先级 | 
|---|
|  |  |  | taskWrk.setBarcode(param.getBarcode());//条码 | 
|---|
|  |  |  | 
|---|
|  |  |  | if(param.getIoType() == 1){ | 
|---|
|  |  |  | taskWrk.setWrkSts(1); | 
|---|
|  |  |  | if (!Cools.isEmpty(param.getTargetPoint())) { | 
|---|
|  |  |  | taskWrk.setTargetPoint(Utils.getWcsLocNo(param.getTargetPoint()));//终点 | 
|---|
|  |  |  | taskWrk.setOriginTargetPoint(param.getTargetPoint()); | 
|---|
|  |  |  | //                taskWrk.setTargetPoint(Utils.getWcsLocNo(param.getTargetPoint()));//终点  转换下 | 
|---|
|  |  |  | taskWrk.setTargetPoint(param.getTargetPoint());//终点 | 
|---|
|  |  |  | taskWrk.setStartPoint(param.getStartPoint()); | 
|---|
|  |  |  | taskWrk.setOriginStartPoint(param.getStartPointSta().toString()); | 
|---|
|  |  |  | taskWrk.setOriginTargetPoint(param.getTargetPointSta().toString()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } else if (param.getIoType() == 2) { | 
|---|
|  |  |  | taskWrk.setWrkSts(11); | 
|---|
|  |  |  | if (!Cools.isEmpty(param.getStartPoint())) { | 
|---|
|  |  |  | taskWrk.setStartPoint(Utils.getWcsLocNo(param.getStartPoint()));//起点 | 
|---|
|  |  |  | taskWrk.setOriginStartPoint(param.getStartPoint()); | 
|---|
|  |  |  | taskWrk.setStartPoint(param.getStartPoint());//起点 | 
|---|
|  |  |  | taskWrk.setTargetPoint(param.getTargetPoint()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | taskWrk.setTargetPoint(param.getTargetPoint()); | 
|---|
|  |  |  | taskWrk.setOriginStartPoint(param.getStartPointSta().toString()); | 
|---|
|  |  |  | taskWrk.setOriginTargetPoint(param.getTargetPointSta().toString()); | 
|---|
|  |  |  | }else if (param.getIoType() == 3){ | 
|---|
|  |  |  | taskWrk.setWrkSts(11); | 
|---|
|  |  |  | if (!Cools.isEmpty(param.getStartPoint())) { | 
|---|
|  |  |  | taskWrk.setStartPoint(param.getStartPoint());//起点 | 
|---|
|  |  |  | taskWrk.setTargetPoint(param.getTargetPoint()); | 
|---|
|  |  |  | taskWrk.setOriginStartPoint("0"); | 
|---|
|  |  |  | taskWrk.setOriginTargetPoint("0"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!taskWrkService.insert(taskWrk)) { | 
|---|
|  |  |  | try{ | 
|---|
|  |  |  | DeviceErrorService deviceErrorService = SpringUtils.getBean(DeviceErrorService.class); | 
|---|
|  |  |  | deviceErrorService.addDeviceError("wms下发任务异常", 1, "创建任务失败!,param:"+JSON.toJSONString(param)); | 
|---|
|  |  |  | } catch (Exception e2){ | 
|---|
|  |  |  | //                    log.error("e2:"+e2.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.error("创建任务失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | 
|---|
|  |  |  | ,wmsUrl+"wcsManager/wcsInterface/inboundTaskApply" | 
|---|
|  |  |  | ,null | 
|---|
|  |  |  | ,"127.0.0.1" | 
|---|
|  |  |  | ,JSON.toJSONString(param) | 
|---|
|  |  |  | ,JSON.toJSONString(toWmsDTO) | 
|---|
|  |  |  | ,response | 
|---|
|  |  |  | ,true | 
|---|
|  |  |  | ); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (jsonObject.getInteger("code").equals(200)) { | 
|---|
|  |  |  | if (!Cools.isEmpty(jsonObject.getInteger("code")) && jsonObject.getInteger("code").equals(200)) { | 
|---|
|  |  |  | //解析 | 
|---|
|  |  |  | List<WMSAndAGVInterfaceParam> params = new ArrayList<>(); | 
|---|
|  |  |  | params.add(param); | 
|---|
|  |  |  | WMSAndAGVInterfaceParam data = JSONObject.parseObject(jsonObject.get("data").toString(), WMSAndAGVInterfaceParam.class); | 
|---|
|  |  |  | String msg = null; | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | taskCreate(new taskCreateParam(data)); | 
|---|
|  |  |  | taskCreate(new TaskCreateParam(data)); | 
|---|
|  |  |  | }catch (Exception e){ | 
|---|
|  |  |  | msg = e.getMessage(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | staDesc = staDescService.selectOne(new EntityWrapper<StaDesc>() | 
|---|
|  |  |  | .eq("crn_no",data.getTaskTunnel()) | 
|---|
|  |  |  | .eq("type_no",1) | 
|---|
|  |  |  | .lt("crn_stn",200)); | 
|---|
|  |  |  | .lt("stn_no",200)); | 
|---|
|  |  |  | }else if (param.getWharfSource().contains("H")){ | 
|---|
|  |  |  | staDesc = staDescService.selectOne(new EntityWrapper<StaDesc>() | 
|---|
|  |  |  | .eq("crn_no",data.getTaskTunnel()) | 
|---|
|  |  |  | .eq("type_no",1) | 
|---|
|  |  |  | .lt("stn_no",400) | 
|---|
|  |  |  | .gt("stn_no",200)); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | staDesc = staDescService.selectOne(new EntityWrapper<StaDesc>() | 
|---|
|  |  |  | .eq("crn_no",data.getTaskTunnel()) | 
|---|
|  |  |  | .eq("type_no",1) | 
|---|
|  |  |  | .ge("crn_stn",200)); | 
|---|
|  |  |  | .lt("stn_no",500) | 
|---|
|  |  |  | .ge("stn_no",400)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //map1.put("taskTunnel", staDesc.getStnDesc()); | 
|---|
|  |  |  | map1.put("taskTunnel", "J-1104"); | 
|---|
|  |  |  | map1.put("taskTunnel", staDesc.getStnDesc()); | 
|---|
|  |  |  | //map1.put("taskTunnel", "J-1104"); | 
|---|
|  |  |  | return R.ok(map1); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.error((String) jsonObject.get("msg")); | 
|---|
|  |  |  | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | staProtocol = staProtocol.clone(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Short workNo = staProtocol.getWorkNo(); | 
|---|
|  |  |  | for (DevpSlave.Sta inSta : devp.getInSta()) { | 
|---|
|  |  |  | if (inSta.getBackSta().equals(staDesc.getStnNo())){ | 
|---|
|  |  |  | if (wharfCode1.contains(param.getWharfCode())){ | 
|---|
|  |  |  | if (!staProtocol.isLoading() && !staProtocol.isCar()){ | 
|---|
|  |  |  | //AGV出库完成以后 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Integer workNo = staProtocol.getWorkNo(); | 
|---|
|  |  |  | if (wharfCode1.contains(param.getWharfCode())){ | 
|---|
|  |  |  | if (!staProtocol.isLoading() && staProtocol.getWorkNo() >0){ | 
|---|
|  |  |  | //AGV出库完成以后 | 
|---|
|  |  |  | staProtocol.setWorkNo( 0); | 
|---|
|  |  |  | staProtocol.setStaNo(0); | 
|---|
|  |  |  | boolean result = MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(3, staProtocol)); | 
|---|
|  |  |  | if (result) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | if (staProtocol.isLoading() && !staProtocol.isCar() && workNo == 0){ | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new RuntimeException("agv返回完成后,命令下发失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | for (DevpSlave.Sta inSta : devp.getInSta()) { | 
|---|
|  |  |  | if (inSta.getBackSta().equals(staDesc.getStnNo())){ | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (staProtocol.isLoading() && workNo == 0){ | 
|---|
|  |  |  | //AGV入库完成以后 | 
|---|
|  |  |  | staProtocol.setWorkNo((short) 9999); | 
|---|
|  |  |  | staProtocol.setStaNo(inSta.getStaNo().shortValue()); | 
|---|
|  |  |  | staProtocol.setWorkNo(9999); | 
|---|
|  |  |  | staProtocol.setStaNo(inSta.getStaNo()); | 
|---|
|  |  |  | boolean result = MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(3, staProtocol)); | 
|---|
|  |  |  | if (result) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | throw new RuntimeException("agv返回完成后,命令下发失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //    @Override | 
|---|
|  |  |  | //    public R getAgvPickAndPlaceV1(TaskOverParam param) { | 
|---|
|  |  |  | //        BasDevp basDevp = basDevpService.selectById(param.getStaNo()); | 
|---|
|  |  |  | //        if (Cools.isEmpty(basDevp)){ | 
|---|
|  |  |  | //            return R.error("站点号有误"+param.getStaNo()); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //        if (param.getType()==0 && basDevp.getAgvStartPick()==1){ | 
|---|
|  |  |  | //            return R.ok(); | 
|---|
|  |  |  | //        }else if (param.getType()==1 && basDevp.getAgvStartPlace()==1){ | 
|---|
|  |  |  | //            return R.ok(); | 
|---|
|  |  |  | //        }else { | 
|---|
|  |  |  | //            return R.error("不允许"); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //    @Override | 
|---|
|  |  |  | //    public R getAgvPickAndPlaceV2(TaskOverParam param) { | 
|---|
|  |  |  | //        BasDevp basDevp = basDevpService.selectById(param.getStaNo()); | 
|---|
|  |  |  | //        if (Cools.isEmpty(basDevp)){ | 
|---|
|  |  |  | //            return R.error("站点号有误"+param.getStaNo()); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //        if (param.getType()==0){ | 
|---|
|  |  |  | //            basDevp.setAgvTargetPick(1); | 
|---|
|  |  |  | //            basDevpService.updateById(basDevp); | 
|---|
|  |  |  | //            return R.ok(); | 
|---|
|  |  |  | //        }else if (param.getType()==1){ | 
|---|
|  |  |  | //            basDevp.setAgvTargetPlace(1); | 
|---|
|  |  |  | //            basDevpService.updateById(basDevp); | 
|---|
|  |  |  | //            return R.ok(); | 
|---|
|  |  |  | //        }else { | 
|---|
|  |  |  | //            return R.error("请求类型异常"+param.getType()); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public List<Integer> getInEnableRoadway(){ | 
|---|
|  |  |  | int[] roadway = null; | 
|---|
|  |  |  | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | staProtocol = staProtocol.clone(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Short workNo = staProtocol.getWorkNo(); | 
|---|
|  |  |  | Integer workNo = staProtocol.getWorkNo(); | 
|---|
|  |  |  | if (workNo == 0 && !staProtocol.isLoading()){ | 
|---|
|  |  |  | if (Cools.isEmpty( map.get(inSta.getStaNo()))){ | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | staProtocol = staProtocol.clone(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Short workNo = staProtocol.getWorkNo(); | 
|---|
|  |  |  | Integer workNo = staProtocol.getWorkNo(); | 
|---|
|  |  |  | if (workNo == 0 && !staProtocol.isLoading()){ | 
|---|
|  |  |  | if (Cools.isEmpty( map.get(inSta.getStaNo()))){ | 
|---|
|  |  |  | continue; | 
|---|