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.SafeSignal;
|
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.CtuMainService;
|
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 ClearSingleOperationHandler implements OperationHandler {
|
|
@Autowired
|
private SlaveProperties slaveProperties;
|
|
|
@Autowired
|
private JobService jobService;
|
|
|
@Autowired
|
private StationService stationService;
|
|
@Autowired
|
private CtuMainService ctuMainService;
|
|
|
private final RedisSupport redis = RedisSupport.defaultRedisSupport;
|
|
|
@Override
|
public ConveyorStateType getType() {
|
return ConveyorStateType.CLEARSIGNAL;
|
}
|
|
@Override
|
public synchronized void execute(CtuOperationConfig config) {
|
try {
|
// 根据输送线plc遍历
|
for (DevpSlave devp : slaveProperties.getDevp()) {
|
// 遍历等待ctu取货站
|
for (DevpSlave.Sta takeSta : devp.getTakeSta()) {
|
// 根据输送线plc遍历
|
Map<Integer, StaProtocol> stationMap = stationService.getStationMap(devp.getId());
|
StaProtocol staProtocol = stationMap.get(takeSta.getStaNo());
|
if (staProtocol == null) {
|
continue;
|
} else {
|
staProtocol = staProtocol.clone();
|
}
|
// 判断是否满足条件
|
if (staProtocol.isLoading()) {
|
//News.error("{}:站点:{},有物", config.getMark(), staProtocol.getSiteId());
|
continue;
|
}
|
if (!staProtocol.isAutoing()) {
|
//News.error("{}:站点:{},非自动", config.getMark(), staProtocol.getSiteId());
|
continue;
|
}
|
if (staProtocol.getWorkNo() > 0 && !staProtocol.isLoading()) {
|
Job job = jobService.getJobByJobNo(staProtocol.getWorkNo());
|
if (job == null) {
|
News.error("{}:站点:{},找不到任务", config.getMark(), staProtocol.getSiteId());
|
continue;
|
}
|
if (job.getJobSts() != ConveyorStateType.SENDTASK.getStatus()) {
|
if (job.getJobSts() == ConveyorStateType.CLEARSIGNAL.getStatus()) {
|
continue;
|
}
|
News.error("{}:站点:{},任务状态不对,{}", config.getMark(), staProtocol.getSiteId(), JSON.toJSON(job));
|
continue;
|
}
|
if (ctuMainService.checkComplete(job.getTaskNo())) {
|
staProtocol.setSafeSignal(new SafeSignal(devp.getPutSta().indexOf(takeSta), (short) 1, false));
|
redis.push(RedisConveyorConstant.CONVEYOR_SAFE_FLAG, staProtocol);
|
|
job.setJobSts(ConveyorStateType.CLEARSIGNAL.getStatus());
|
if (!jobService.updateById(job)) {
|
log.info("" + config.getMark() + "站点清空失败:{},{}", takeSta.getStaNo(), staProtocol.getWorkNo());
|
} else {
|
News.info("" + config.getMark() + "站点清空:{},{}", takeSta.getStaNo(), staProtocol.getWorkNo());
|
}
|
} else {
|
log.info("" + config.getMark() + "站点:{},{}", takeSta.getStaNo(), staProtocol.getWorkNo());
|
}
|
}
|
}
|
}
|
} catch (Exception e) {
|
e.printStackTrace();
|
TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
|
}
|
}
|
}
|