|  |  |  | 
|---|
|  |  |  | import com.alibaba.fastjson.JSONObject; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.mapper.EntityWrapper; | 
|---|
|  |  |  | import com.core.common.Cools; | 
|---|
|  |  |  | import com.core.common.SnowflakeIdWorker; | 
|---|
|  |  |  | import com.core.exception.CoolException; | 
|---|
|  |  |  | import com.zy.asrs.constant.AsrsConstants; | 
|---|
|  |  |  | import com.zy.asrs.entity.*; | 
|---|
|  |  |  | import com.zy.asrs.entity.param.MesBuyPakinReportParam; | 
|---|
|  |  |  | import com.zy.asrs.entity.param.MesOrderReportParam; | 
|---|
|  |  |  | 
|---|
|  |  |  | import com.zy.asrs.service.*; | 
|---|
|  |  |  | import com.zy.asrs.task.AbstractHandler; | 
|---|
|  |  |  | import com.zy.asrs.task.core.ReturnT; | 
|---|
|  |  |  | import com.zy.common.utils.HttpHandler; | 
|---|
|  |  |  | import com.zy.common.service.AgvCommonService; | 
|---|
|  |  |  | import lombok.Synchronized; | 
|---|
|  |  |  | import lombok.extern.slf4j.Slf4j; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | 
|---|
|  |  |  | //移库类型数组 | 
|---|
|  |  |  | private static final List<Integer> MOVE_TYPE_List = new ArrayList<Integer>() {{ | 
|---|
|  |  |  | add(11); | 
|---|
|  |  |  | add(101); | 
|---|
|  |  |  | add(12); | 
|---|
|  |  |  | add(53); | 
|---|
|  |  |  | add(101); | 
|---|
|  |  |  | add(103); | 
|---|
|  |  |  | add(108); | 
|---|
|  |  |  | add(111); | 
|---|
|  |  |  | add(112); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Value("${agvBasDev.maxWorkNum}") | 
|---|
|  |  |  | private int maxWrokNum; | 
|---|
|  |  |  | @Value("${mes.report}") | 
|---|
|  |  |  | private Boolean flag; | 
|---|
|  |  |  | @Value("${mes.url}") | 
|---|
|  |  |  | private String url; | 
|---|
|  |  |  | @Value("${mes.getTokenUrl}") | 
|---|
|  |  |  | 
|---|
|  |  |  | private DocTypeService docTypeService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private OrderDetlService orderDetlService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private SnowflakeIdWorker snowflakeIdWorker; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private FlowLogService flowLogService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private ReportDataService reportDataService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private AgvCommonService agvCommonService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public ReturnT<String> completedPutWayWrk(AgvWrkMast agvWrkMast) { | 
|---|
|  |  |  | //用于上报mes的工作档明细 | 
|---|
|  |  |  | List<AgvWrkDetl> agvWrkDetlListOld = agvWrkDetlService.selectList(new EntityWrapper<AgvWrkDetl>().eq("wrk_no", agvWrkMast.getWrkNo())); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | long flowId = snowflakeIdWorker.nextId(); | 
|---|
|  |  |  | Date now = new Date(); | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | int wrkNo = agvWrkMast.getWrkNo(); | 
|---|
|  |  |  | String barcode = agvWrkMast.getBarcode(); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Integer pltType = agvWrkMast.getPltType(); | 
|---|
|  |  |  | if (Cools.isEmpty(pltType)) { | 
|---|
|  |  |  | AgvLocMast agvLocMast; | 
|---|
|  |  |  | if (!Cools.isEmpty(agvWrkMast.getLocNo())) { | 
|---|
|  |  |  | agvLocMast = agvLocMastService.selectById(agvWrkMast.getLocNo()); | 
|---|
|  |  |  | if (agvLocMast != null) { | 
|---|
|  |  |  | pltType = agvLocMast.getPltType(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!Cools.isEmpty(agvWrkMast.getSourceLocNo())) { | 
|---|
|  |  |  | agvLocMast = agvLocMastService.selectById(agvWrkMast.getSourceLocNo()); | 
|---|
|  |  |  | if (agvLocMast != null) { | 
|---|
|  |  |  | pltType = agvLocMast.getPltType(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (pltType != null) { | 
|---|
|  |  |  | agvWrkMast.setPltType(pltType); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //log.info("工作号--{},仓库编码:{}", agvWrkMast.getWrkNo(), agvWrkMast.getPltType()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | agvWrkMast.setModiTime(new Date()); | 
|---|
|  |  |  | //修改工作档状态为207.库存更新完成 | 
|---|
|  |  |  | agvWrkMast.setWrkSts(207L); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | switch (agvWrkMast.getIoType()) { | 
|---|
|  |  |  | case 1: | 
|---|
|  |  |  | agvLocMastService.updateLocStsByLocNo(agvWrkMast.getLocNo(), "F", agvWrkMast.getBarcode(), agvWrkMast.getWhsType().shortValue()); | 
|---|
|  |  |  | agvLocMastService.updateLocStsByLocNo(agvWrkMast.getLocNo(), "F", agvWrkMast.getBarcode(), agvWrkMast.getWhsType().shortValue(), agvWrkMast.getCtnNo()); | 
|---|
|  |  |  | //更新目标库位明细 | 
|---|
|  |  |  | log.info("更新目标库位明细 agvWrkMast.getLocNo(): " + agvWrkMast.getLocNo() + ", wrkNo: " + wrkNo); | 
|---|
|  |  |  | agvLocDetlService.addLocDetlInfo(agvWrkMast.getLocNo(), wrkNo); | 
|---|
|  |  |  | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 10: | 
|---|
|  |  |  | agvLocMastService.updateLocStsByLocNo(agvWrkMast.getLocNo(), "D", agvWrkMast.getBarcode(), agvWrkMast.getWhsType().shortValue()); | 
|---|
|  |  |  | agvBasDevpService.updateLocStsAndBarcodeByDevNo(agvWrkMast.getSourceLocNo(), "O", "", (short) 0); | 
|---|
|  |  |  | AgvBasDevp byDevNo = agvBasDevpService.getByDevNo(agvWrkMast.getSourceLocNo()); | 
|---|
|  |  |  | if (byDevNo != null) { | 
|---|
|  |  |  | if ("S".equals(byDevNo.getLocSts()) || "F".equals(byDevNo.getLocSts())) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | agvBasDevpService.updateLocStsAndBarcodeByDevNo(agvWrkMast.getSourceLocNo(), "O", "", agvWrkMast.getWhsType().shortValue()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //agvBasDevpService.updateLocStsAndBarcodeByDevNo(agvWrkMast.getSourceLocNo(), "O", "", (short) 0); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 11: | 
|---|
|  |  |  | case 12: | 
|---|
|  |  |  | agvLocMastService.updateLocStsByLocNo(agvWrkMast.getLocNo(), "F", agvWrkMast.getBarcode(), agvWrkMast.getWhsType().shortValue()); | 
|---|
|  |  |  | AgvLocDetl agvLocDetl1 = agvLocDetlService.selectByLocNo(agvWrkMast.getSourceLocNo()); | 
|---|
|  |  |  | if (agvLocDetl1 == null) { | 
|---|
|  |  |  | agvLocMastService.updateLocStsByLocNo(agvWrkMast.getLocNo(), "D", agvWrkMast.getBarcode(), agvWrkMast.getWhsType().shortValue()); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | agvLocMastService.updateLocStsByLocNo(agvWrkMast.getLocNo(), "F", agvWrkMast.getBarcode(), agvWrkMast.getWhsType().shortValue()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //更新库存明细 | 
|---|
|  |  |  | agvLocDetlService.updateStock(agvWrkMast.getSourceLocNo(), agvWrkMast.getLocNo()); | 
|---|
|  |  |  | agvLocDetlService.updateStock(agvWrkMast.getSourceLocNo(), agvWrkMast.getLocNo(),null); | 
|---|
|  |  |  | //修改源库位状态为O | 
|---|
|  |  |  | agvLocMastService.updateLocStsByLocNo(agvWrkMast.getSourceLocNo(), "O", "", null); | 
|---|
|  |  |  | agvLocMastService.updateLocStsByLocNo(agvWrkMast.getSourceLocNo(), "O", "", null, ""); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 53: | 
|---|
|  |  |  | //修改工作党明细 | 
|---|
|  |  |  | 
|---|
|  |  |  | AgvLocDetl agvLocDetl = agvLocDetlService.selectByMatnrAndBatchAndCsocodeAndisoCode(agvWrkMast.getLocNo(), agvWrkDetl.getMatnr(), agvWrkDetl.getBatch(), agvWrkDetl.getThreeCode(), agvWrkDetl.getDeadTime()); | 
|---|
|  |  |  | if (!Cools.isEmpty(agvLocDetl)) { | 
|---|
|  |  |  | double updateAnfme = agvLocDetl.getAnfme() - agvWrkDetl.getAnfme(); | 
|---|
|  |  |  | //                            OrderDetl orderDetl = orderDetlService.selectItem(agvWrkDetl.getOrderNo(), agvWrkDetl.getMatnr(), agvWrkDetl.getThreeCode()); | 
|---|
|  |  |  | //                            FlowLog flowLog = new FlowLog(); | 
|---|
|  |  |  | //                            flowLog.setFid(String.valueOf(flowId)); | 
|---|
|  |  |  | //                            flowLog.setSpare2(String.valueOf(agvWrkMast.getWrkNo())); | 
|---|
|  |  |  | //                            flowLog.setLocNo(agvWrkMast.getLocNo()); | 
|---|
|  |  |  | //                            flowLog.setSpare1(agvWrkDetl.getSuppCode()); | 
|---|
|  |  |  | //                            flowLog.setOpType(53L); | 
|---|
|  |  |  | //                            flowLog.setOrderNo(agvWrkDetl.getOrderNo()); | 
|---|
|  |  |  | //                            flowLog.setThreeCode(agvWrkDetl.getThreeCode()); | 
|---|
|  |  |  | //                            flowLog.setMatnr(agvWrkDetl.getMatnr()); | 
|---|
|  |  |  | //                            flowLog.setMaktx(agvWrkDetl.getMaktx()); | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //                            flowLog.setOrderPrevious(orderDetl.getAnfme()); | 
|---|
|  |  |  | //                            flowLog.setOrderCurrent(orderDetl.getAnfme()); | 
|---|
|  |  |  | //                            flowLog.setOrderChanged(0.0); | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //                            flowLog.setQtyPrevious(orderDetl.getQty()); | 
|---|
|  |  |  | //                            flowLog.setQtyCurrent(updateAnfme); | 
|---|
|  |  |  | //                            flowLog.setQtyChanged(agvWrkDetl.getAnfme()); | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //                            flowLog.setLocPrevious(agvLocDetl.getAnfme()); | 
|---|
|  |  |  | //                            flowLog.setLocCurrent(updateAnfme); | 
|---|
|  |  |  | //                            flowLog.setLocChanged(agvWrkDetl.getAnfme()); | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //                            flowLog.setAppeTime(now); | 
|---|
|  |  |  | //                            if (!flowLogService.insert(flowLog)) { | 
|---|
|  |  |  | //                                throw new CoolException("同步半成品调拨单流水记录失败"); | 
|---|
|  |  |  | //                            } | 
|---|
|  |  |  | log.info("53添加库存日志:{},{}", updateAnfme, JSON.toJSON(agvLocDetl)); | 
|---|
|  |  |  | agvLocDetlService.updateAnfme(updateAnfme, agvLocDetl.getLocNo(), agvLocDetl.getMatnr(), agvLocDetl.getBatch(), agvLocDetl.getThreeCode(), agvLocDetl.getDeadTime()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //AgvLocDetl agvLocDetl = agvLocDetlService.selectLocdetl(agvWrkMast.getLocNo(),agvWrkDetl.getMatnr(),agvWrkDetl.getBatch(),agvWrkDetl.getThreeCode(),agvWrkDetl.getDeadTime()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | agvLocMastService.updateLocStsByLocNo(agvWrkMast.getLocNo(), "F", agvWrkMast.getBarcode(), agvWrkMast.getWhsType().shortValue()); | 
|---|
|  |  |  | agvBasDevpService.updateLocStsAndBarcodeByDevNo(agvWrkMast.getSourceLocNo(), "O", "", agvWrkMast.getWhsType().shortValue()); | 
|---|
|  |  |  | byDevNo = agvBasDevpService.getByDevNo(agvWrkMast.getSourceLocNo()); | 
|---|
|  |  |  | if (byDevNo != null) { | 
|---|
|  |  |  | if ("S".equals(byDevNo.getLocSts()) || "F".equals(byDevNo.getLocSts())) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | agvBasDevpService.updateLocStsAndBarcodeByDevNo(agvWrkMast.getSourceLocNo(), "O", "", agvWrkMast.getWhsType().shortValue()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 57: | 
|---|
|  |  |  | Date now = new Date(); | 
|---|
|  |  |  | // 更新库存明细 | 
|---|
|  |  |  | List<AgvWrkDetl> wrkDetlList = agvWrkDetlService.selectList(new EntityWrapper<AgvWrkDetl>().eq("wrk_no", agvWrkMast.getWrkNo())); | 
|---|
|  |  |  | wrkDetlList.forEach(agvWrkDetl -> { | 
|---|
|  |  |  | 
|---|
|  |  |  | agvLocDetl.sync(agvWrkDetl); | 
|---|
|  |  |  | agvLocDetl.setModiTime(now); | 
|---|
|  |  |  | agvLocDetl.setAppeTime(now); | 
|---|
|  |  |  | log.info("57添加库存日志:{}", JSON.toJSON(agvLocDetl)); | 
|---|
|  |  |  | if (!agvLocDetlService.insert(agvLocDetl)) { | 
|---|
|  |  |  | throw new CoolException("保存工作明细失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | // 更新站点 + 库位状态     源库位是站点 | 
|---|
|  |  |  | agvBasDevpService.updateLocStsAndBarcodeByDevNo(agvWrkMast.getSourceLocNo(), "O", "", agvWrkMast.getWhsType().shortValue()); | 
|---|
|  |  |  | agvLocMastService.updateLocStsByLocNo(agvWrkMast.getLocNo(), "F", agvWrkMast.getBarcode(), agvWrkMast.getWhsType().shortValue()); | 
|---|
|  |  |  | byDevNo = agvBasDevpService.getByDevNo(agvWrkMast.getSourceLocNo()); | 
|---|
|  |  |  | if (byDevNo != null) { | 
|---|
|  |  |  | if ("S".equals(byDevNo.getLocSts()) || "F".equals(byDevNo.getLocSts())) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | agvBasDevpService.updateLocStsAndBarcodeByDevNo(agvWrkMast.getSourceLocNo(), "O", "", agvWrkMast.getWhsType().shortValue()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | agvLocMastService.updateLocStsByLocNo(agvWrkMast.getLocNo(), "F", agvWrkMast.getBarcode(), agvWrkMast.getWhsType().shortValue(), agvWrkMast.getCtnNo()); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 58: | 
|---|
|  |  |  | agvLocMastService.updateLocStsByLocNo(agvWrkMast.getLocNo(), "F", agvWrkMast.getBarcode(), agvWrkMast.getWhsType().shortValue()); | 
|---|
|  |  |  | agvBasDevpService.updateLocStsAndBarcodeByDevNo(agvWrkMast.getSourceLocNo(), "O", "", agvWrkMast.getWhsType().shortValue()); | 
|---|
|  |  |  | //agvBasDevpService.updateLocStsAndBarcodeByDevNo(agvWrkMast.getSourceLocNo(), "O", "", agvWrkMast.getWhsType().shortValue()); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 108: | 
|---|
|  |  |  | case 114: | 
|---|
|  |  |  | agvLocMastService.updateLocStsByLocNo(agvWrkMast.getLocNo(), "F", agvWrkMast.getBarcode(), agvWrkMast.getWhsType().shortValue()); | 
|---|
|  |  |  | //更新库存明细 | 
|---|
|  |  |  | agvLocDetlService.updateStock(agvWrkMast.getSourceLocNo(), agvWrkMast.getLocNo()); | 
|---|
|  |  |  | //修改源库位状态为O | 
|---|
|  |  |  | agvLocMastService.updateLocStsByLocNo(agvWrkMast.getSourceLocNo(), "O", "", agvWrkMast.getWhsType().shortValue(), "", (short) 0); | 
|---|
|  |  |  | //                    //更新库存明细 | 
|---|
|  |  |  | //                    agvLocDetlService.updateStock(agvWrkMast.getSourceLocNo(), agvWrkMast.getLocNo()); | 
|---|
|  |  |  | //                    //修改源库位状态为O | 
|---|
|  |  |  | //                    agvLocMastService.updateLocStsByLocNo(agvWrkMast.getSourceLocNo(), "O", "", agvWrkMast.getWhsType().shortValue(), "", (short) 0); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 109: | 
|---|
|  |  |  | // 库位 -- 接驳位 / 库位 | 
|---|
|  |  |  | 
|---|
|  |  |  | // 库位 -- 接驳位 / 库位 | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | //修改源库位状态为O | 
|---|
|  |  |  | agvLocMastService.updateLocStsByLocNo(agvWrkMast.getSourceLocNo(), "O", "", agvWrkMast.getWhsType().shortValue(), "", (short) 0); | 
|---|
|  |  |  | //agvLocMastService.updateLocStsByLocNo(agvWrkMast.getSourceLocNo(), "O", "", agvWrkMast.getWhsType().shortValue(), "", (short) 0); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 111: | 
|---|
|  |  |  | 
|---|
|  |  |  | locDetl.setLocNo(agvWrkMast.getLocNo()); | 
|---|
|  |  |  | locDetl.sync(agvWrkDetl); | 
|---|
|  |  |  | locDetl.setModiTime(new Date()); | 
|---|
|  |  |  | log.info("112添加库存日志:{}", JSON.toJSON(locDetl)); | 
|---|
|  |  |  | agvLocDetlService.insert(locDetl); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 接驳位 -- 库位 | 
|---|
|  |  |  | 
|---|
|  |  |  | case 121: | 
|---|
|  |  |  | agvLocMastService.updateLocStsByLocNo(agvWrkMast.getLocNo(), "F", agvWrkMast.getBarcode(), agvWrkMast.getWhsType().shortValue()); | 
|---|
|  |  |  | //更新库存明细 | 
|---|
|  |  |  | agvLocDetlService.updateStock(agvWrkMast.getSourceLocNo(), agvWrkMast.getLocNo()); | 
|---|
|  |  |  | agvLocDetlService.updateStock(agvWrkMast.getSourceLocNo(), agvWrkMast.getLocNo(),agvWrkMast.getAppeUser()); | 
|---|
|  |  |  | //修改源库位状态为O | 
|---|
|  |  |  | agvLocMastService.updateLocStsByLocNo(agvWrkMast.getSourceLocNo(), "O", "", agvWrkMast.getWhsType().shortValue(), "", (short) 0); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!isJSON(orderNo)) { | 
|---|
|  |  |  | //检查订单是否已完成 | 
|---|
|  |  |  | orderService.checkComplete(orderNo, agvWrkMast.getPltType()); | 
|---|
|  |  |  | orderService.checkComplete(orderNo, pltType); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | List<Map> maps = JSONArray.parseArray(orderNo, Map.class); | 
|---|
|  |  |  | Integer finalPltType = pltType; | 
|---|
|  |  |  | maps.forEach(map -> { | 
|---|
|  |  |  | String o = map.get("orderNo").toString(); | 
|---|
|  |  |  | orderService.checkComplete(o, agvWrkMast.getPltType()); | 
|---|
|  |  |  | orderService.checkComplete(o, finalPltType); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //TODO | 
|---|
|  |  |  | //暂时加上trycatch | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | reportMes(agvWrkMast, agvWrkDetlListOld); | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | reportMes(agvWrkMast, agvWrkDetlListOld); | 
|---|
|  |  |  | return SUCCESS; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | wrkMast.setIoTime(now); | 
|---|
|  |  |  | //优先级 | 
|---|
|  |  |  | wrkMast.setIoPri(300.0); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //源站点 | 
|---|
|  |  |  | wrkMast.setSourceLocNo(agvWrkMast.getLocNo()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //目标站点 | 
|---|
|  |  |  | wrkMast.setLocNo(agvWrkMast.getSourceLocNo()); | 
|---|
|  |  |  | if (agvWrkMast.getLocNo().startsWith("QO") && agvWrkMast.getLocNo().endsWith("F4") && Integer.valueOf(agvWrkMast.getBarcode().substring(0, 2)) == 30) { | 
|---|
|  |  |  | if (!agvWrkMast.getSourceLocNo().endsWith("02F1")) { | 
|---|
|  |  |  | AgvLocMast locByFloor = null; | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | locByFloor = agvCommonService.getLocByLocRule(3, 1, AsrsConstants.ERCHANG, true); | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (locByFloor != null && locByFloor.getLocNo().endsWith("02F1")) { | 
|---|
|  |  |  | AgvLocMast agvLocMast = agvLocMastService.selectById(agvWrkMast.getSourceLocNo()); | 
|---|
|  |  |  | agvLocMast.setLocSts("O"); | 
|---|
|  |  |  | agvLocMast.setModiTime(now); | 
|---|
|  |  |  | agvLocMast.setBarcode(""); | 
|---|
|  |  |  | agvLocMastService.updateById(agvLocMast); | 
|---|
|  |  |  | wrkMast.setLocNo(locByFloor.getLocNo()); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | wrkMast.setLocNo(agvWrkMast.getSourceLocNo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | wrkMast.setLocNo(agvWrkMast.getSourceLocNo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | wrkMast.setLocNo(agvWrkMast.getSourceLocNo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //wrkMast.setLocNo(agvWrkMast.getSourceLocNo()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //货架编码 | 
|---|
|  |  |  | wrkMast.setBarcode(agvWrkMast.getBarcode()); | 
|---|
|  |  |  | //货架类型 | 
|---|
|  |  |  | wrkMast.setWhsType(Integer.valueOf(agvWrkMast.getBarcode().substring(0, 2))); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | wrkMast.setAppeUser(9527L); | 
|---|
|  |  |  | wrkMast.setAppeUser(agvWrkMast.getAppeUser()); | 
|---|
|  |  |  | wrkMast.setAppeTime(now); | 
|---|
|  |  |  | wrkMast.setModiUser(9527L); | 
|---|
|  |  |  | wrkMast.setModiTime(now); | 
|---|
|  |  |  | wrkMast.setPltType(agvWrkMast.getPltType()); | 
|---|
|  |  |  | wrkMast.setLogErrMemo("completedCarryWrk"); | 
|---|
|  |  |  | if (!agvWrkMastService.insertByIncrease(wrkMast)) { | 
|---|
|  |  |  | throw new CoolException("保存工作档失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | AgvLocMast agvLocMast = agvLocMastService.selectById(agvWrkMast.getSourceLocNo()); | 
|---|
|  |  |  | AgvLocMast agvLocMast = agvLocMastService.selectById(wrkMast.getLocNo()); | 
|---|
|  |  |  | agvLocMast.setLocSts("S"); | 
|---|
|  |  |  | agvLocMast.setModiTime(now); | 
|---|
|  |  |  | agvLocMastService.updateById(agvLocMast); | 
|---|
|  |  |  | 
|---|
|  |  |  | reportMes(agvWrkMast, agvWrkDetlListOld); | 
|---|
|  |  |  | return SUCCESS; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public ReturnT<String> completedCarryWrk2(AgvWrkMast agvWrkMast) { | 
|---|
|  |  |  | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | log.error("" + e.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //TODO 张超 | 
|---|
|  |  |  | reportMes(agvWrkMast, agvWrkDetlListOld); | 
|---|
|  |  |  | return SUCCESS; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | throw new CoolException("任务下发失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | agvWrkMast.setWrkSts(202L); | 
|---|
|  |  |  | agvWrkMast.setModiTime(new Date()); | 
|---|
|  |  |  | agvWrkMastService.updateById(agvWrkMast); | 
|---|
|  |  |  | //agvWrkMast.setWrkSts(202L); | 
|---|
|  |  |  | //agvWrkMast.setModiTime(new Date()); | 
|---|
|  |  |  | //boolean b = agvWrkMastService.updateById(agvWrkMast); | 
|---|
|  |  |  | boolean b = agvWrkMastService.updateWrkStsByWrkNo(Math.abs(agvWrkMast.getWrkNo()), 202L); | 
|---|
|  |  |  | if (!b) { | 
|---|
|  |  |  | log.info("更新任务状态失败,{}", agvWrkMast.getWrkNo()); | 
|---|
|  |  |  | throw new CoolException("更新任务状态失败"); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | log.info("更新任务状态成功,{}", agvWrkMast.getWrkNo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (agvWrkMast.getIoType() == 1) { | 
|---|
|  |  |  | //修改AGV入库通知档状态入出状态为Y | 
|---|
|  |  |  | agvWaitPakinService.updateIoStatus(agvWrkMast.getWrkNo(), "Y"); | 
|---|
|  |  |  | 
|---|
|  |  |  | return SUCCESS; | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | //TODO | 
|---|
|  |  |  | //log.error("修改AGV入库通知档状态入出状态为Y" + e.getMessage()); | 
|---|
|  |  |  | //log.error("修改AGV入库通知档状态入出状态为Y,{}", e.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return FAIL; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private void reportMes(AgvWrkMast agvWrkMast, List<AgvWrkDetl> agvWrkDetls) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (Cools.isEmpty(agvWrkDetls)) { | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<AgvWrkDetl> data = new ArrayList<>(); | 
|---|
|  |  |  | //区分不同任务类型的上报方式 | 
|---|
|  |  |  | for (AgvWrkDetl agvWrkDetl : agvWrkDetls) { | 
|---|
|  |  |  | if (agvWrkDetl.getMatnr().compareTo("39") <= 0) { | 
|---|
|  |  |  | data.add(agvWrkDetl); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!data.isEmpty()) { | 
|---|
|  |  |  | if (IN_TYPE_LIST.contains(agvWrkMast.getIoType())) { | 
|---|
|  |  |  | reportMesPakinOrder(agvWrkMast, data); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //            if (OUT_TYPE_List.contains(agvWrkMast.getIoType())) { | 
|---|
|  |  |  | //                reportMesPakoutOrder(agvWrkMast, data); | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  | //            if (MOVE_TYPE_List.contains(agvWrkMast.getIoType())) { | 
|---|
|  |  |  | //                generateMesParam(agvWrkMast, data); | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (IN_TYPE_LIST.contains(agvWrkMast.getIoType())) { | 
|---|
|  |  |  | reportMesPakinOrder(agvWrkMast, agvWrkDetls); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (OUT_TYPE_List.contains(agvWrkMast.getIoType())) { | 
|---|
|  |  |  | reportMesPakoutOrder(agvWrkMast, agvWrkDetls); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (MOVE_TYPE_List.contains(agvWrkMast.getIoType())) { | 
|---|
|  |  |  | generateMesParam(agvWrkMast, agvWrkDetls); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private void reportMesPakinOrder(AgvWrkMast agvWrkMast, List<AgvWrkDetl> agvWrkDetls) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | iteam.setLineNo(orderDetl.getItemNum()); | 
|---|
|  |  |  | iteam.setSupplierCode(order.getSalesman()); | 
|---|
|  |  |  | iteam.setUnit(agvWrkDetl.getUnit()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | iteam.setRemark(agvWrkDetl.getThreeCode()); | 
|---|
|  |  |  | iteams.add(iteam); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | mesBuyPakinReportParam.setCode(orderNo); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | MesPakinReportParam mesPakinReportParam = new MesPakinReportParam(); | 
|---|
|  |  |  | mesPakinReportParam.setInboundOrderCode(agvWrkDetl.getOrderNo()); | 
|---|
|  |  |  | //mesPakinReportParam.setInboundOrderCode(agvWrkDetl.getOrderNo()); | 
|---|
|  |  |  | mesPakinReportParam.setBizType("0"); | 
|---|
|  |  |  | mesPakinReportParam.setInventoryAttr(new MesPakinReportParam.InventoryAttr(agvWrkDetl.getThreeCode().trim(), agvWrkDetl.getMatnr(), agvWrkMast.getLocNo())); | 
|---|
|  |  |  | mesPakinReportParam.setInventoryAttr(new MesPakinReportParam.InventoryAttr(null, agvWrkDetl.getMatnr(), agvWrkMast.getLocNo())); | 
|---|
|  |  |  | mesPakinReportParam.setNoQrCodeExecAmount(new MesPakinReportParam.NoQrCodeExecAmount(agvWrkDetl.getAnfme(), agvWrkDetl.getUnit(), null)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | doHttpRequest(mesPakinReportParam, getMesTokenInfo(), "上报mes入库信息", url, pakinReportPath, null, "127.0.0.1"); | 
|---|
|  |  |  | 
|---|
|  |  |  | MesOrderReportParam param = new MesOrderReportParam(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<MesOrderReportParam.TransferOrderItem> transferOrderItems = new ArrayList<>(); | 
|---|
|  |  |  | List<MesOrderReportParam.TransferOrderItem.InventoryDetail> inventoryDetails = new ArrayList<>(); | 
|---|
|  |  |  | List<MesOrderReportParam.RecordCustomFieldBaseCO.CustomField> customFields = new ArrayList<>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //MesOrderReportParam.RecordCustomFieldBaseCO.CustomField customFields = new MesOrderReportParam.RecordCustomFieldBaseCO.CustomField(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | MesOrderReportParam.RecordCustomFieldBaseCO recordCustomFieldBaseCO = new MesOrderReportParam.RecordCustomFieldBaseCO(); | 
|---|
|  |  |  | recordCustomFieldBaseCO.setCustomFields(customFields); | 
|---|
|  |  |  | //recordCustomFieldBaseCO.setCustomFields(customFields); | 
|---|
|  |  |  | param.setRecordCustomFieldBaseCO(recordCustomFieldBaseCO); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //添加transferOrderItem属性 | 
|---|
|  |  |  | 
|---|
|  |  |  | transferOrderItem.setTargetLocationCode(getTargetLocationByFloor(floor)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | transferOrderItems.add(transferOrderItem); | 
|---|
|  |  |  | transferOrderItem.setInventoryDetails(inventoryDetails); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | param.setTransferOrderItems(transferOrderItems); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | for (AgvWrkDetl agvWrkDetl : agvWrkDetls) { | 
|---|
|  |  |  | List<MesOrderReportParam.TransferOrderItem.InventoryDetail> inventoryDetails = new ArrayList<>(); | 
|---|
|  |  |  | MesOrderReportParam.TransferOrderItem.InventoryDetail inventoryDetail = new MesOrderReportParam.TransferOrderItem.InventoryDetail(); | 
|---|
|  |  |  | //添加amount属性 | 
|---|
|  |  |  | MesOrderReportParam.TransferOrderItem.InventoryDetail.Amount amount = new MesOrderReportParam.TransferOrderItem.InventoryDetail.Amount(agvWrkDetl.getAnfme(), agvWrkDetl.getUnit(), null); | 
|---|
|  |  |  | 
|---|
|  |  |  | inventoryDetail.setQcStatus(1); | 
|---|
|  |  |  | inventoryDetail.setStorageStatus(1); | 
|---|
|  |  |  | inventoryDetails.add(inventoryDetail); | 
|---|
|  |  |  | transferOrderItem.setInventoryDetails(inventoryDetails); | 
|---|
|  |  |  | //添加销售订单号 | 
|---|
|  |  |  | MesOrderReportParam.RecordCustomFieldBaseCO.CustomField customField = new MesOrderReportParam.RecordCustomFieldBaseCO.CustomField("workOrderCode__c", agvWrkDetl.getThreeCode().trim()); | 
|---|
|  |  |  | customFields.add(customField); | 
|---|
|  |  |  | //customFields.add(customField); | 
|---|
|  |  |  | recordCustomFieldBaseCO.setCustomFields(customField); | 
|---|
|  |  |  | doHttpRequest(param, getMesTokenInfo(), "上报mes调拨信息", url, orderReportPath, null, "127.0.0.1"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | doHttpRequest(param, getMesTokenInfo(), "上报mes调拨信息", url, orderReportPath, null, "127.0.0.1"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //获取mes token信息 | 
|---|
|  |  |  | private Map<String, Object> getMesTokenInfo() { | 
|---|
|  |  |  | Map<String, String> param = new HashMap<>(); | 
|---|
|  |  |  | param.put("appKey", appKey); | 
|---|
|  |  |  | param.put("appSecret", appSecret); | 
|---|
|  |  |  | //        Map<String, String> param = new HashMap<>(); | 
|---|
|  |  |  | //        param.put("appKey", appKey); | 
|---|
|  |  |  | //        param.put("appSecret", appSecret); | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //        JSONObject jsonObject = doHttpRequest(param, null, "获取MesToken", getTokenUrl, getTokenPath, null, "127.0.0.1"); | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //        Map<String, Object> headParam = new HashMap<>(); | 
|---|
|  |  |  | //        headParam.put("X-AUTH", JSON.parseObject(jsonObject.get("data").toString()).get("appAccessToken").toString()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | JSONObject jsonObject = doHttpRequest(param, null, "获取MesToken", getTokenUrl, getTokenPath, null, "127.0.0.1"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Map<String, Object> headParam = new HashMap<>(); | 
|---|
|  |  |  | headParam.put("X-AUTH", JSON.parseObject(jsonObject.get("data").toString()).get("appAccessToken").toString()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return headParam; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //       return headParam; | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //根据楼层默认出库仓位 | 
|---|
|  |  |  | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private JSONObject doHttpRequest(Object requestParam, Map<String, Object> headParam, String namespace, String url, String path, String appkey, String ip) { | 
|---|
|  |  |  | private void doHttpRequest(Object requestParam, Map<String, Object> headParam, String namespace, String url, String path, String appkey, String ip) { | 
|---|
|  |  |  | //保证上报表 | 
|---|
|  |  |  | ReportData reportData = new ReportData(); | 
|---|
|  |  |  | reportData.setReportJson(JSONObject.toJSONString(requestParam)); | 
|---|
|  |  |  | reportData.setMemo(namespace); | 
|---|
|  |  |  | reportData.setCreateTime(new Date()); | 
|---|
|  |  |  | reportData.setReportType("MES"); | 
|---|
|  |  |  | reportDataService.insert(reportData); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | String response = ""; | 
|---|
|  |  |  | boolean success = false; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | response = new HttpHandler.Builder() | 
|---|
|  |  |  | .setUri(url) | 
|---|
|  |  |  | .setPath(path) | 
|---|
|  |  |  | .setHeaders(headParam) | 
|---|
|  |  |  | .setJson(JSONObject.toJSONString(requestParam)) | 
|---|
|  |  |  | .setHttps(true) | 
|---|
|  |  |  | .build() | 
|---|
|  |  |  | .doPost(); | 
|---|
|  |  |  | JSONObject jsonObject = JSON.parseObject(response); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (Cools.isEmpty(jsonObject.get("code")) || Integer.parseInt(jsonObject.get("code").toString()) != 200) { | 
|---|
|  |  |  | throw new CoolException(jsonObject.get("dsc").toString()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | success = true; | 
|---|
|  |  |  | return jsonObject; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //            String succeed = jsonObject.get("succeed").toString(); | 
|---|
|  |  |  | //        String response = ""; | 
|---|
|  |  |  | //        boolean success = false; | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //            int code = Cools.eq("0",succeed) ? 0 : 1; | 
|---|
|  |  |  | //            if(code != 200){ | 
|---|
|  |  |  | //                throw new CoolException(jsonObject.get("dsc").toString()); | 
|---|
|  |  |  | //        try { | 
|---|
|  |  |  | //            response = new HttpHandler.Builder().setUri(url).setPath(path).setTimeout(30, TimeUnit.SECONDS).setHeaders(headParam).setJson(JSONObject.toJSONString(requestParam)).setHttps(true).build().doPost(); | 
|---|
|  |  |  | //            JSONObject jsonObject = JSON.parseObject(response); | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //            if (Cools.isEmpty(jsonObject.get("code")) || Integer.parseInt(jsonObject.get("code").toString()) != 200) { | 
|---|
|  |  |  | //                log.info("mes接口调用失败,返回信息:" + jsonObject); | 
|---|
|  |  |  | //                //TODO 张超 | 
|---|
|  |  |  | //                throw new CoolException("mes接口调用失败,返回信息:" + jsonObject); | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  | //            success = true; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | log.error(e.getMessage()); | 
|---|
|  |  |  | throw new CoolException(e.getMessage()); | 
|---|
|  |  |  | } finally { | 
|---|
|  |  |  | apiLogService.save( | 
|---|
|  |  |  | namespace, | 
|---|
|  |  |  | url + path, | 
|---|
|  |  |  | appkey, | 
|---|
|  |  |  | ip, | 
|---|
|  |  |  | JSON.toJSONString(JSONObject.toJSONString(requestParam)), | 
|---|
|  |  |  | response, | 
|---|
|  |  |  | success | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //            return jsonObject; | 
|---|
|  |  |  | // | 
|---|
|  |  |  | ////            String succeed = jsonObject.get("succeed").toString(); | 
|---|
|  |  |  | //// | 
|---|
|  |  |  | ////            int code = Cools.eq("0",succeed) ? 0 : 1; | 
|---|
|  |  |  | ////            if(code != 200){ | 
|---|
|  |  |  | ////                throw new CoolException(jsonObject.get("dsc").toString()); | 
|---|
|  |  |  | ////            } | 
|---|
|  |  |  | ////            success = true; | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //        } catch (Exception e) { | 
|---|
|  |  |  | //            log.error(e.getMessage()); | 
|---|
|  |  |  | //            throw new CoolException(e.getMessage()); | 
|---|
|  |  |  | //        } finally { | 
|---|
|  |  |  | //            apiLogService.save(namespace, url + path, appkey, ip, JSON.toJSONString(JSONObject.toJSONString(requestParam)), response, success); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|