From 4109495b9c51a4bbd8b0a7c3c69093909d2e33e1 Mon Sep 17 00:00:00 2001
From: Pu Zhibing <393733352@qq.com>
Date: 星期一, 07 四月 2025 18:55:05 +0800
Subject: [PATCH] 修改接口bug

---
 ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/WarnServiceImpl.java |  151 ++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 150 insertions(+), 1 deletions(-)

diff --git a/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/WarnServiceImpl.java b/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/WarnServiceImpl.java
index 4bd54e6..2b0bff9 100644
--- a/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/WarnServiceImpl.java
+++ b/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/WarnServiceImpl.java
@@ -1,16 +1,35 @@
 package com.ruoyi.system.service.impl;
 
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.ruoyi.common.core.web.page.PageInfo;
+import com.ruoyi.dataInterchange.api.feignClient.UPWarnMsgAdptInfoClient;
+import com.ruoyi.dataInterchange.api.model.enums.WarnType;
+import com.ruoyi.dataInterchange.api.vo.UPWarnMsgAdptInfoVo;
+import com.ruoyi.system.api.model.Car;
+import com.ruoyi.system.api.model.Driver;
+import com.ruoyi.system.api.model.Enterprise;
 import com.ruoyi.system.api.model.Warn;
 import com.ruoyi.system.mapper.WarnMapper;
 import com.ruoyi.system.query.CarWarnListReq;
 import com.ruoyi.system.query.CarWarnListResp;
+import com.ruoyi.system.service.ICarService;
+import com.ruoyi.system.service.IDriverService;
+import com.ruoyi.system.service.IEnterpriseService;
 import com.ruoyi.system.service.IWarnService;
+import com.ruoyi.system.util.GDMapGeocodingUtil;
 import org.springframework.stereotype.Service;
 
+import javax.annotation.Resource;
+import java.math.BigDecimal;
+import java.time.Instant;
+import java.time.LocalDateTime;
+import java.time.ZoneOffset;
+import java.time.format.DateTimeFormatter;
+import java.util.ArrayList;
 import java.util.List;
 import java.util.Map;
+import java.util.Optional;
 
 
 /**
@@ -19,6 +38,116 @@
  */
 @Service
 public class WarnServiceImpl extends ServiceImpl<WarnMapper, Warn> implements IWarnService {
+	
+	@Resource
+	private UPWarnMsgAdptInfoClient upWarnMsgAdptInfoClient;
+	
+	@Resource
+	private IEnterpriseService enterpriseService;
+	
+	@Resource
+	private IDriverService driverService;
+	
+	@Resource
+	private ICarService carService;
+	
+	
+	/**
+	 * 存储新的报警数据
+	 */
+	@Override
+	public void taskSaveNewWarn() {
+		Warn warn = this.getOne(new LambdaQueryWrapper<Warn>().orderByDesc(Warn::getCreateTime).last(" limit 1"));
+		Long createTime = -1L;
+		if (null != warn) {
+			createTime = warn.getCreateTime().toEpochSecond(ZoneOffset.ofHours(8));
+		}
+		List<UPWarnMsgAdptInfoVo> list = upWarnMsgAdptInfoClient.findByCreateTimeAfter(createTime).getData();
+		if (null == list || list.isEmpty()) {
+			return;
+		}
+		List<Enterprise> list1 = enterpriseService.list();
+		List<Driver> driverList = driverService.list(new LambdaQueryWrapper<Driver>().eq(Driver::getStatus, 1));
+		List<Car> carList = carService.list();
+		List<Warn> warns = new ArrayList<>();
+		for (UPWarnMsgAdptInfoVo vo : list) {
+			warn = new Warn();
+			Optional<Car> carOptional = carList.stream().filter(s -> s.getVehicleNumber().equals(vo.getVehicleNo())).findFirst();
+			if (carOptional.isPresent()) {
+				warn.setCarId(carOptional.get().getId());
+			}
+			Optional<Driver> optional = driverList.stream().filter(s -> s.getVehicleNumber().equals(vo.getVehicleNo())).findFirst();
+			if (optional.isPresent()) {
+				warn.setDriverId(optional.get().getId());
+			}
+			Enterprise enterprise = list1.stream().filter(s -> s.getCode().equals(vo.getInferiorPlatformId().toString())).findFirst().get();
+			warn.setEnterpriseId(enterprise.getId());
+			warn.setStartTime(LocalDateTime.ofInstant(Instant.ofEpochMilli(vo.getCreateTime() * 1000), ZoneOffset.ofHours(8)).format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
+			warn.setEndTime(LocalDateTime.ofInstant(Instant.ofEpochMilli(vo.getCreateTime() * 1000), ZoneOffset.ofHours(8)).format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
+			warn.setWarnType(WarnType.getWarnTypeName(vo.getWarnType()));
+			warn.setWarnNumber(1);
+			warn.setSpeed(new BigDecimal(vo.getSpeed()));
+			warn.setLongitude(new BigDecimal(vo.getLongitude()).divide(new BigDecimal(1000000)).toString());
+			warn.setLatitude(new BigDecimal(vo.getLatitude()).divide(new BigDecimal(1000000)).toString());
+			Map<String, String> geocode = null;
+			try {
+				geocode = GDMapGeocodingUtil.geocode(warn.getLongitude(), warn.getLatitude());
+			} catch (Exception e) {
+				throw new RuntimeException(e);
+			}
+			warn.setAddress(geocode.get("address"));
+			switch (vo.getResult()) {
+				case 0x00:
+					warn.setTreatmentState("处理中");
+					break;
+				case 0x01:
+					warn.setTreatmentState("已处理完毕");
+					break;
+				case 0x02:
+					warn.setTreatmentState("不作处理");
+					break;
+				case 0x03:
+					warn.setTreatmentState("将来处理");
+					break;
+			}
+			warn.setCreateTime(LocalDateTime.now());
+			warn.setObjectId(vo.getInfoId());
+			warns.add(warn);
+		}
+		if (warns.size() > 0) {
+			this.saveBatch(warns);
+		}
+	}
+	
+	
+	/**
+	 * 定时任务修改预警信息处理结果
+	 */
+	@Override
+	public void taskUpdateWarnStatus() {
+		List<Warn> warnList = this.list(new LambdaQueryWrapper<Warn>().eq(Warn::getTreatmentState, "处理中"));
+		for (Warn warn : warnList) {
+			UPWarnMsgAdptInfoVo vo = upWarnMsgAdptInfoClient.findByInfoId(warn.getObjectId()).getData();
+			if (null != vo && null != warn && vo.getResult() != 0x00) {
+				switch (vo.getResult()) {
+					case 0x00:
+						warn.setTreatmentState("处理中");
+						break;
+					case 0x01:
+						warn.setTreatmentState("已处理完毕");
+						break;
+					case 0x02:
+						warn.setTreatmentState("不作处理");
+						break;
+					case 0x03:
+						warn.setTreatmentState("将来处理");
+						break;
+				}
+				this.updateById(warn);
+			}
+		}
+		
+	}
 	
 	
 	/**
@@ -41,6 +170,26 @@
 	 */
 	@Override
 	public List<Map<String, Object>> getWarnGroupCount() {
-		return this.baseMapper.getWarnGroupCount();
+		List<Map<String, Object>> list = this.baseMapper.getWarnGroup10Count();
+		List<String> collect = new ArrayList<>();
+		for (Map<String, Object> map : list) {
+			collect.add(map.get("warnType").toString());
+		}
+		if (!collect.isEmpty()) {
+			List<Map<String, Object>> warnGroupCount = this.baseMapper.getWarnGroupCount(collect);
+			list.addAll(warnGroupCount);
+		}
+		return list;
+	}
+	
+	
+	/**
+	 * 获取预警汇总前10排行榜
+	 *
+	 * @return
+	 */
+	@Override
+	public List<Map<String, Object>> getWarnGroupCountTop10() {
+		return this.baseMapper.getWarnGroupCountTop10();
 	}
 }

--
Gitblit v1.7.1