From e03adc9fa7d0bc2fbb9c78b67de3c734e5d9a643 Mon Sep 17 00:00:00 2001
From: zhangnaisong <2434969829@qq.com>
Date: 星期六, 22 七月 2023 15:35:03 +0800
Subject: [PATCH] 三一车辆实时位置添加判断null提交
---
ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java | 116 ++++++++++++++++++++++++++++++++++++++++++++++++++++------
1 files changed, 104 insertions(+), 12 deletions(-)
diff --git a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java
index 7808842..1021f23 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java
@@ -8,15 +8,18 @@
import java.util.function.Predicate;
import java.util.stream.Collectors;
+import com.alibaba.fastjson.JSON;
+import com.ruoyi.common.core.domain.entity.SysUser;
import com.ruoyi.common.utils.uuid.IdUtils;
+import com.ruoyi.common.websocket.util.WebSocketUtils;
import com.ruoyi.device.hiksdk.config.MinioClientSingleton;
import com.ruoyi.device.hiksdk.util.minio.MinioUtils;
import com.ruoyi.sy.domain.ArdSyUser;
+import com.ruoyi.sy.gps31.PositionContainer;
import com.ruoyi.sy.mapper.ArdSyUserMapper;
import com.ruoyi.system.domain.SysConfig;
import com.ruoyi.system.mapper.SysConfigMapper;
import com.ruoyi.system.mapper.SysUserMapper;
-import com.ruoyi.system.service.ISysConfigService;
import com.ruoyi.utils.httpclient.SYCarClient;
import io.minio.GetPresignedObjectUrlArgs;
import io.minio.ListObjectsArgs;
@@ -24,7 +27,6 @@
import io.minio.Result;
import io.minio.http.Method;
import io.minio.messages.Item;
-import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.ruoyi.sy.mapper.ArdSyCarMapper;
import com.ruoyi.sy.domain.ArdSyCar;
@@ -32,6 +34,8 @@
import org.springframework.web.multipart.MultipartFile;
import javax.annotation.Resource;
+
+import static com.ruoyi.common.websocket.util.WebSocketUtils.ONLINE_USER_SESSIONS;
/**
* 涓変竴杞﹁締Service涓氬姟灞傚鐞�
@@ -49,6 +53,10 @@
@Resource
private ArdSyUserMapper ardSyUserMapper;
+
+ @Resource
+ private SysUserMapper userMapper;
+
/**
* 鏌ヨ涓変竴杞﹁締
@@ -180,6 +188,59 @@
}
@Override
+ public Map<String, Object> getArdSyCarAll(String userId) {
+ SysConfig config = new SysConfig();
+ config.setConfigKey("syCarPT");
+ List<SysConfig> sysConfigResult = sysConfigMapper.selectConfigList(config);
+ String syURL = "";
+ Map<String,Object> result = new HashMap();
+ if(sysConfigResult.size() == 0){
+ result.put("data","涓変竴杞﹁締url娌℃湁褰曞叆");
+ result.put("code","500");
+ return result;
+ }else{
+ syURL = sysConfigResult.get(0).getConfigValue();
+ ArdSyUser ardSyUserPara = new ArdSyUser();
+ ardSyUserPara.setSysUserId(userId);
+ List<ArdSyUser> ardSyUserList = ardSyUserMapper.selectArdSyUserList(ardSyUserPara);
+ if(ardSyUserList.size() == 0){
+ result.put("data","鐢ㄦ埛鏈寕鎺ヤ笁涓�杞﹁締");
+ result.put("code","500");
+ return result;
+ }else{
+ ArdSyUser ardSyUser = ardSyUserList.get(0);
+ Map<String,Object> LogInResult = SYCarClient.logIn(syURL,ardSyUser.getUserId(), ardSyUser.getPassword());
+ String sessionId = (String) LogInResult.get("sessionId");
+ Map<String,Object> carListMap = SYCarClient.getCarList(syURL,sessionId);
+ if(((String)carListMap.get("rspCode")).equals("1")){
+ List<Map<String,Object>> list = (List<Map<String,Object>>) carListMap.get("list");
+ /*ArdSyCar ardSyCar = new ArdSyCar();
+ List<ArdSyCar> ardSyCarList = ardSyCarMapper.selectArdSyCarList(ardSyCar);
+ List<String> carIdList = new ArrayList();
+ for(ArdSyCar innerArdSyCar : ardSyCarList){
+ carIdList.add(innerArdSyCar.getCarId());
+ }
+
+ List<Map<String,Object>> carList = list.stream().filter(new Predicate<Map<String,Object>>(){
+ @Override
+ public boolean test(Map<String,Object> map) {
+ return !carIdList.contains((String)map.get("carId"));
+ }
+ }).collect(Collectors.toList());
+ result.put("data",carList);*/
+ result.put("data",list);
+ result.put("code","200");
+ return result;
+ }else{
+ result.put("data","涓変竴杞﹁締骞冲彴鍑洪敊");
+ result.put("code","500");
+ return result;
+ }
+ }
+ }
+ }
+
+ @Override
public List<Map<String,String>> getAllCarModel() {
boolean exsit = MinioUtils.exitsBucket("sycar");
if (exsit) {
@@ -219,12 +280,14 @@
@Override
public String uploadCarPicture(String id, MultipartFile carPicture) {
- ArdSyCar ardSyCarr = ardSyCarMapper.selectArdSyCarById(id);
- List<String> objectNames = new ArrayList();
- if(ardSyCarr.getCarPicture() != null || !ardSyCarr.getCarPicture().equals("")){
- String objectName = ardSyCarr.getCarPicture().split("/sycar/")[1];
- objectNames.add(objectName);
- MinioUtils.removeObjects("sycar", objectNames);
+ if(id != null && !id.equals("")){//id涓洪潪蹇呰
+ ArdSyCar ardSyCarr = ardSyCarMapper.selectArdSyCarById(id);
+ List<String> objectNames = new ArrayList();
+ if(ardSyCarr.getCarPicture() != null || !ardSyCarr.getCarPicture().equals("")){
+ String objectName = ardSyCarr.getCarPicture().split("/sycar/")[1];
+ objectNames.add(objectName);
+ MinioUtils.removeObjects("sycar", objectNames);
+ }
}
//鍒ゆ柇鏂囦欢鏄惁涓虹┖
if (null == carPicture || 0 == carPicture.getSize()) {
@@ -259,13 +322,42 @@
.build();
String presignedObjectUrl = MinioClientSingleton.getMinioClient().getPresignedObjectUrl(getPresignedObjectUrlArgs);
String ObjectUrl = presignedObjectUrl.substring(0, presignedObjectUrl.indexOf("?"));
- ArdSyCar ardSyCar = new ArdSyCar();
- ardSyCar.setId(id);
- ardSyCar.setCarPicture(ObjectUrl);
- ardSyCarMapper.updateArdSyCar(ardSyCar);
+ if(id != null && !id.equals("")){//id涓洪潪蹇呰
+ ArdSyCar ardSyCar = new ArdSyCar();
+ ardSyCar.setId(id);
+ ardSyCar.setCarPicture(ObjectUrl);
+ ardSyCarMapper.updateArdSyCar(ardSyCar);
+ }
return ObjectUrl;
} catch (Exception ex) {
return "";
}
}
+
+
+ @Override
+ public List<ArdSyCar> carListById(String id) {
+ return ardSyCarMapper.carListById(id);
+ }
+
+ @Override
+ public Map<String, Object> getArdSyCarAndDeptByCarId(String carId) {
+ Map<String, Object> result = ardSyCarMapper.getArdSyCarAndDeptByCarId(carId);
+ return result;
+ }
+
+ @Override
+ public void sendArdSyCarPosition() {
+ for(String key : ONLINE_USER_SESSIONS.keySet()){
+ SysUser sysUser = userMapper.selectUserById(key);
+ String deptId = String.valueOf(sysUser.getDeptId());
+ Map<String,Map<String,Object>> map = PositionContainer.getDeptPositionMap().get(deptId);
+ List<Map<String,Object>> positionList = (List<Map<String, Object>>) map.values();
+ if(positionList.size() != 0){
+ Map<Integer,Object> data = new HashMap();
+ data.put(30000,positionList);
+ WebSocketUtils.sendMessage(ONLINE_USER_SESSIONS.get(key), JSON.toJSONString(positionList));
+ }
+ }
+ }
}
--
Gitblit v1.9.3