|  |  |  | 
|---|
|  |  |  | import com.alibaba.fastjson.JSONObject; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.mapper.EntityWrapper; | 
|---|
|  |  |  | import com.zy.asrs.domain.NotifyDto; | 
|---|
|  |  |  | import com.zy.asrs.entity.DeviceConfig; | 
|---|
|  |  |  | import com.zy.asrs.entity.HttpRequestLog; | 
|---|
|  |  |  | import com.zy.asrs.service.DeviceConfigService; | 
|---|
|  |  |  | import com.zy.asrs.service.HttpRequestLogService; | 
|---|
|  |  |  | import com.zy.asrs.utils.NotifyUtils; | 
|---|
|  |  |  | import com.zy.common.utils.HttpHandler; | 
|---|
|  |  |  | import com.zy.common.utils.RedisUtil; | 
|---|
|  |  |  | import com.zy.core.enums.SlaveType; | 
|---|
|  |  |  | import com.zy.core.model.ForkLiftSlave; | 
|---|
|  |  |  | import com.zy.core.model.ShuttleSlave; | 
|---|
|  |  |  | import com.zy.core.properties.SlaveProperties; | 
|---|
|  |  |  | import com.zy.system.entity.Config; | 
|---|
|  |  |  | import com.zy.system.service.ConfigService; | 
|---|
|  |  |  | import lombok.extern.slf4j.Slf4j; | 
|---|
|  |  |  | 
|---|
|  |  |  | import org.springframework.scheduling.annotation.Scheduled; | 
|---|
|  |  |  | import org.springframework.stereotype.Component; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.util.Date; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Component | 
|---|
|  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private NotifyUtils notifyUtils; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private SlaveProperties slaveProperties; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private ConfigService configService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private HttpRequestLogService httpRequestLogService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private DeviceConfigService deviceConfigService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Scheduled(cron = "0/3 * * * * ? ") | 
|---|
|  |  |  | public synchronized void notifyShuttle(){ | 
|---|
|  |  |  | for (ShuttleSlave slave : slaveProperties.getShuttle()) { | 
|---|
|  |  |  | notifyMsg(String.valueOf(SlaveType.Shuttle), slave.getId()); | 
|---|
|  |  |  | List<DeviceConfig> shuttleList = deviceConfigService.selectList(new EntityWrapper<DeviceConfig>() | 
|---|
|  |  |  | .eq("device_type", String.valueOf(SlaveType.Shuttle))); | 
|---|
|  |  |  | for (DeviceConfig device : shuttleList) { | 
|---|
|  |  |  | notifyMsg(String.valueOf(SlaveType.Shuttle), device.getDeviceNo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Scheduled(cron = "0/3 * * * * ? ") | 
|---|
|  |  |  | public synchronized void notifyForkLift(){ | 
|---|
|  |  |  | for (ForkLiftSlave slave : slaveProperties.getForkLift()) { | 
|---|
|  |  |  | notifyMsg(String.valueOf(SlaveType.ForkLift), slave.getId()); | 
|---|
|  |  |  | List<DeviceConfig> forkLiftList = deviceConfigService.selectList(new EntityWrapper<DeviceConfig>() | 
|---|
|  |  |  | .eq("device_type", String.valueOf(SlaveType.ForkLift))); | 
|---|
|  |  |  | for (DeviceConfig device : forkLiftList) { | 
|---|
|  |  |  | notifyMsg(String.valueOf(SlaveType.ForkLift), device.getDeviceNo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Scheduled(cron = "0/3 * * * * ? ") | 
|---|
|  |  |  | public synchronized void notifyTask(){ | 
|---|
|  |  |  | notifyMsg("task", 1); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private synchronized void notifyMsg(String notifyType, Integer device) { | 
|---|
|  |  |  | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | HttpRequestLog httpRequestLog = new HttpRequestLog(); | 
|---|
|  |  |  | httpRequestLog.setName(notifyUri + notifyUriPath); | 
|---|
|  |  |  | httpRequestLog.setRequest(JSON.toJSONString(notifyDto)); | 
|---|
|  |  |  | httpRequestLog.setCreateTime(new Date()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | //触发通知 | 
|---|
|  |  |  | String response = new HttpHandler.Builder() | 
|---|
|  |  |  | 
|---|
|  |  |  | .setJson(JSON.toJSONString(notifyDto)) | 
|---|
|  |  |  | .build() | 
|---|
|  |  |  | .doPost(); | 
|---|
|  |  |  | httpRequestLog.setResponse(response); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | JSONObject jsonObject = JSON.parseObject(response); | 
|---|
|  |  |  | Integer code = jsonObject.getInteger("code"); | 
|---|
|  |  |  | if(code == 200){ | 
|---|
|  |  |  | //通知成功 | 
|---|
|  |  |  | redisUtil.del(key); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }catch (Exception e){ | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | }finally { | 
|---|
|  |  |  | //保存记录 | 
|---|
|  |  |  | httpRequestLogService.insert(httpRequestLog); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //通知失败 | 
|---|