package com.zy.acs.conveyor.core.operation.handler;
|
|
import com.alibaba.fastjson.JSON;
|
import com.zy.acs.common.utils.News;
|
import com.zy.acs.common.utils.RedisSupport;
|
import com.zy.acs.conveyor.core.constant.RedisConveyorConstant;
|
import com.zy.acs.conveyor.core.enums.ConveyorStateType;
|
import com.zy.acs.conveyor.core.model.StaProtocol;
|
import com.zy.acs.conveyor.core.operation.OperationHandler;
|
import com.zy.acs.conveyor.core.properties.CtuOperationConfig;
|
import com.zy.acs.conveyor.core.properties.DevpSlave;
|
import com.zy.acs.conveyor.core.properties.SlaveProperties;
|
import com.zy.acs.conveyor.core.service.StationService;
|
import com.zy.acs.conveyor.entity.Job;
|
import com.zy.acs.conveyor.service.JobService;
|
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.Map;
|
|
/**
|
* 模拟用户按按钮
|
*/
|
@Slf4j
|
@Component
|
public class StartUpOperationHandler implements OperationHandler {
|
|
@Autowired
|
private SlaveProperties slaveProperties;
|
|
|
@Autowired
|
private JobService jobService;
|
|
|
@Autowired
|
private StationService stationService;
|
|
private final RedisSupport redis = RedisSupport.defaultRedisSupport;
|
|
|
@Override
|
public ConveyorStateType getType() {
|
return ConveyorStateType.STARTUP;
|
}
|
|
@Override
|
public synchronized void execute(CtuOperationConfig config) {
|
|
try {
|
// 根据输送线plc遍历
|
for (DevpSlave devp : slaveProperties.getDevp()) {
|
// 遍历入库口
|
for (DevpSlave.Sta inSta : devp.getInSta()) {
|
// 根据输送线plc遍历
|
Map<Integer, StaProtocol> stationMap = stationService.getStationMap(devp.getId());
|
StaProtocol staProtocol = stationMap.get(inSta.getSourceStaNo());
|
if (staProtocol == null) {
|
continue;
|
} else {
|
staProtocol = staProtocol.clone();
|
}
|
// 判断是否满足条件
|
if (!staProtocol.isStartup() || !staProtocol.isAutoing() || !staProtocol.isLoading()) {
|
if (!staProtocol.isStartup()) {
|
News.error("{}:站点:{},未启动入库", config.getMark(), staProtocol.getSiteId());
|
continue;
|
}
|
if (!staProtocol.isAutoing()) {
|
News.error("{}:站点:{},非自动", config.getMark(), staProtocol.getSiteId());
|
continue;
|
}
|
if (!staProtocol.isLoading()) {
|
News.error("{}:站点:{},无物", config.getMark(), staProtocol.getSiteId());
|
continue;
|
}
|
|
}
|
Job jobByJobNo = jobService.getJobByJobNo(staProtocol.getWorkNo());
|
if (jobByJobNo == null) {
|
News.error("{}:站点:{},找不到任务", config.getMark(), staProtocol.getSiteId());
|
continue;
|
}
|
if (jobByJobNo.getJobSts() != ConveyorStateType.OUTBOUND.getStatus()) {
|
if (jobByJobNo.getJobSts() == ConveyorStateType.STARTUP.getStatus()){
|
continue;
|
}
|
News.error("{}:站点:{},任务状态不对,{}", config.getMark(), staProtocol.getSiteId(), JSON.toJSON(jobByJobNo));
|
continue;
|
}
|
staProtocol.setStaNo(inSta.getStaNo());
|
redis.push(RedisConveyorConstant.CONVEYOR_TASK_FLAG, staProtocol);
|
|
jobByJobNo.setJobSts(ConveyorStateType.STARTUP.getStatus());
|
if (!jobService.updateById(jobByJobNo)) {
|
News.info("{},启动入库:{},{}", config.getMark(), staProtocol.getWorkNo(), staProtocol.getStaNo());
|
}
|
}
|
}
|
} catch (Exception e) {
|
e.printStackTrace();
|
TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
|
}
|
}
|
}
|