package com.zy.core.operation.handler; import com.zy.asrs.controller.vo.OpenBusSubmitParam; import com.zy.asrs.controller.vo.TaskDto; import com.zy.asrs.entity.Job; import com.zy.asrs.service.CtuMainService; import com.zy.asrs.service.JobService; import com.zy.core.cache.SlaveConnection; import com.zy.core.enums.ConveyorStateType; import com.zy.core.enums.SlaveType; import com.zy.core.model.DevpSlave; import com.zy.core.model.protocol.StaProtocol; import com.zy.core.operation.OperationHandler; import com.zy.core.properties.CtuOperationConfig; import com.zy.core.properties.SlaveProperties; import com.zy.core.thread.SiemensDevpThread; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import org.springframework.transaction.interceptor.TransactionAspectSupport; import java.util.ArrayList; import java.util.Date; import java.util.List; /** * 发送任务给RCS */ @Slf4j @Component public class SendTaskOperationHandler implements OperationHandler { @Autowired private SlaveProperties slaveProperties; @Autowired private JobService jobService; @Autowired private CtuMainService ctuMainService; @Override public ConveyorStateType getType() { return ConveyorStateType.SENDTASK; } @Override public synchronized void execute(CtuOperationConfig config) { try { // 根据输送线plc遍历 for (DevpSlave devp : slaveProperties.getDevp()) { // 遍历入库口 for (DevpSlave.Sta inSta : devp.getInSta()) { // 根据输送线plc遍历 SiemensDevpThread devpThread = (SiemensDevpThread) SlaveConnection.get(SlaveType.Devp, devp.getId()); StaProtocol staProtocol = devpThread.getStation().get(inSta.getTargetSta()); if (staProtocol == null) { continue; } else { staProtocol = staProtocol.clone(); } // 判断是否满足条件 if (!staProtocol.isLoading()) { if (staProtocol.getWorkNo() > 0) { log.error("输送线上有任务号无货,需要人工处理:{}", staProtocol.getSiteId()); } continue; } if (staProtocol.getWorkNo() == 0) { log.error("输送线上有货无任务号,需要人工处理:{}", staProtocol.getSiteId()); continue; } if (staProtocol.isAutoing()) { Job job = jobService.getJobByJobNo(staProtocol.getWorkNo()); if (job != null && job.getJobSts() == ConveyorStateType.INBOUND.getStatus()) { if (ctuMainService.sendTask(process(job))) { job.setJobSts(ConveyorStateType.SENDTASK.getStatus()); job.setRcsTime(new Date()); jobService.updateById(job); log.info("任务发送给RCS成功,WMS任务号:{},输送线工作号:{}", job.getTaskNo(), job.getJobNo()); } else { log.info("任务发送给RCS失败,WMS任务号:{},输送线工作号:{}", job.getTaskNo(), job.getJobNo()); } } } else { log.error("输送线为自动,需要开启:{}", staProtocol.getSiteId()); } } } } catch (Exception e) { e.printStackTrace(); TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); } } /** * 处理任务 * * @param job * @return */ private OpenBusSubmitParam process(Job job) { OpenBusSubmitParam openBusSubmitParam = new OpenBusSubmitParam(); openBusSubmitParam.setBatchNo(job.getBatchNo()); List taskList = new ArrayList<>(); TaskDto taskDto = new TaskDto(); taskDto.setTaskNo(job.getTaskNo()); taskDto.setBatchNo(job.getBatchNo()); taskDto.setOriSta(job.getStaNo()); taskDto.setDestLoc(job.getLoc()); taskDto.setPriority(1); taskList.add(taskDto); openBusSubmitParam.setTasks(taskList); return openBusSubmitParam; } }