package com.zy.acs.manager.core.service; import com.alibaba.fastjson.JSON; import com.zy.acs.common.domain.AgvProtocol; import com.zy.acs.common.domain.protocol.*; import com.zy.acs.common.enums.AgvStatusType; import com.zy.acs.common.utils.GsonUtils; import com.zy.acs.common.utils.RedisSupport; import com.zy.acs.framework.common.Cools; import com.zy.acs.manager.core.domain.BackpackDto; import com.zy.acs.manager.manager.entity.AgvDetail; import com.zy.acs.manager.manager.entity.Code; import com.zy.acs.manager.manager.service.*; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.scheduling.annotation.Async; import org.springframework.stereotype.Service; import java.util.ArrayList; import java.util.Date; import java.util.List; /** * Created by vincent on 2023/6/16 */ @Slf4j @Service public class AgvDataLoginService { private final static Boolean PRINT_LOG = Boolean.FALSE; private final RedisSupport redis = RedisSupport.defaultRedisSupport; @Autowired private AgvService agvService; @Autowired private AgvDetailService agvDetailService; @Autowired private CodeService codeService; @Autowired private WebsocketService websocketService; @Autowired private TrafficService trafficService; @Autowired private MapService mapService; @Autowired private ThreadPoolRegulator threadPoolRegulator; @Autowired private JamService jamService; @Autowired private AvoidWaveCalculator avoidWaveCalculator; @Autowired private FaultProcessor faultProcessor; @Async public void dataProcess(AgvProtocol protocol) { Date now = new Date(); IMessageBody msgBody = protocol.getMessageBody(); assert msgBody != null; Long agvId = agvService.getAgvId(protocol.getAgvNo()); if (null == agvId) { log.warn("Agv [{}] 尚未鉴权 !!!", protocol.getAgvNo()); return; } AgvDetail detail = agvDetailService.selectByAgvId(agvId); if (null == detail) { detail = new AgvDetail(); detail.setAgvId(agvId); if (!agvDetailService.save(detail)) { log.error("Agv [{}] 详情更新失败 !!!", protocol.getAgvNo()); return; } } detail.setUpdateTime(now); // 登陆包 if (msgBody instanceof AGV_F0_UP) { AGV_F0_UP agv_f0_up = (AGV_F0_UP) msgBody; this.sync(agv_f0_up, detail); log.info("Agv [{}] 登陆包 ===>> {}", protocol.getAgvNo(), JSON.toJSONString(agv_f0_up)); } // if (!agvDetailService.updateById(detail)) { // log.error("Agv [{}] 详情更新失败 !!!", protocol.getAgvNo()); // } } // 登陆包 private void sync(AGV_F0_UP mesBody, AgvDetail detail) { } }