|
@@ -2,6 +2,7 @@ package com.om.service.impl;
|
|
|
|
|
|
import cn.hutool.core.bean.BeanUtil;
|
|
|
import cn.hutool.core.util.PageUtil;
|
|
|
+import cn.hutool.json.JSONUtil;
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
|
import com.obs.services.model.TemporarySignatureRequest;
|
|
@@ -11,6 +12,7 @@ import com.om.entity.vo.DiagnosisVersionSearchVO;
|
|
|
import com.om.entity.vo.DiagnosisVersionVO;
|
|
|
import com.om.entity.vo.DignosisPageVO;
|
|
|
import com.om.exception.BadReqException;
|
|
|
+import com.om.exception.BizException;
|
|
|
import com.om.mapper.DiagnosisVersionDescribeMapper;
|
|
|
import com.om.mapper.DiagnosisVersionInfoMapper;
|
|
|
import com.om.service.*;
|
|
@@ -30,6 +32,7 @@ import java.time.ZoneOffset;
|
|
|
import java.time.format.DateTimeFormatter;
|
|
|
import java.util.ArrayList;
|
|
|
import java.util.List;
|
|
|
+import java.util.stream.Collectors;
|
|
|
|
|
|
/**
|
|
|
* <p>
|
|
@@ -60,6 +63,9 @@ public class DiagnosisVersionInfoServiceImpl extends ServiceImpl<DiagnosisVersio
|
|
|
@Resource
|
|
|
private HuaweiObsUtil obsUtil;
|
|
|
|
|
|
+ @Resource
|
|
|
+ private PushUtil pushUtil;
|
|
|
+
|
|
|
@Override
|
|
|
@Transactional
|
|
|
public Result add(DiagnosisVersionVO diagnosisVersionVO) {
|
|
@@ -240,7 +246,13 @@ public class DiagnosisVersionInfoServiceImpl extends ServiceImpl<DiagnosisVersio
|
|
|
String[] s = new String[diagClients.size()];
|
|
|
|
|
|
for (int j = 0; j < diagClients.size(); j++) {
|
|
|
- s[j] = diagClients.get(j).getClientName();
|
|
|
+ Client client = clientService.lambdaQuery()
|
|
|
+ .eq(Client::getNumber, diagClients.get(j).getClientNum())
|
|
|
+ .one();
|
|
|
+ if (BeanUtil.isEmpty(client)){
|
|
|
+ throw new BadReqException("该客户端编号"+diagClients.get(j).getClientNum()+"不存在");
|
|
|
+ }
|
|
|
+ s[j] = client.getName();
|
|
|
}
|
|
|
//传入客户端num
|
|
|
versionVO.setClientNames(s);
|
|
@@ -388,6 +400,71 @@ public class DiagnosisVersionInfoServiceImpl extends ServiceImpl<DiagnosisVersio
|
|
|
return Result.ok(voList);
|
|
|
}
|
|
|
|
|
|
+ @Override
|
|
|
+ public Result pushDiagnosis(Integer id) {
|
|
|
+ DiagnosisVersionInfo diagnosisVersionInfo = this.getById(id);
|
|
|
+ if (BeanUtil.isEmpty(diagnosisVersionInfo)) {
|
|
|
+ throw new BadReqException("该诊断程序不存在");
|
|
|
+ }
|
|
|
+
|
|
|
+ PushInfo pushInfo = new PushInfo();
|
|
|
+ pushInfo.setPushInfoType(2);
|
|
|
+ VehicleInfo vehicleInfo = new VehicleInfo();
|
|
|
+
|
|
|
+ BeanUtil.copyProperties(diagnosisVersionInfo, vehicleInfo);
|
|
|
+ Brand brand = brandService.lambdaQuery()
|
|
|
+ .eq(Brand::getBrandCode,diagnosisVersionInfo.getBrandCode())
|
|
|
+ .one();
|
|
|
+ if (BeanUtil.isEmpty(brand)) {
|
|
|
+ throw new BadReqException("该品牌"+diagnosisVersionInfo.getBrandCode()+"不存在");
|
|
|
+ }
|
|
|
+ vehicleInfo.setBrandName(brand.getBrandCn());
|
|
|
+ vehicleInfo.setBrandNameEn(brand.getBrandEn());
|
|
|
+ vehicleInfo.setSortLetter(diagnosisVersionInfo.getDiagnosisName().substring(0,1));
|
|
|
+ vehicleInfo.setUrl(diagnosisVersionInfo.getSavePath());
|
|
|
+ List<Describe> describeList = new ArrayList<>();
|
|
|
+ List<DiagnosisVersionDescribe> diagnosisVersionDescribes = describeService.lambdaQuery()
|
|
|
+ .eq(DiagnosisVersionDescribe::getDiagnosisId, diagnosisVersionInfo.getId())
|
|
|
+ .list();
|
|
|
+ if (!diagnosisVersionDescribes.isEmpty()) {
|
|
|
+ for (DiagnosisVersionDescribe diagnosisVersionDescribe : diagnosisVersionDescribes) {
|
|
|
+ Describe describe = new Describe();
|
|
|
+ describe.setDescription(diagnosisVersionDescribe.getDescription());
|
|
|
+ describe.setLanguage(diagnosisVersionDescribe.getLanguage());
|
|
|
+ describeList.add(describe);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ vehicleInfo.setDescribeList(describeList);
|
|
|
+
|
|
|
+
|
|
|
+ List<DiagClients> diagClients = diagClientsService.lambdaQuery()
|
|
|
+ .eq(DiagClients::getDiagId, diagnosisVersionInfo.getId())
|
|
|
+ .list();
|
|
|
+
|
|
|
+ if (!diagClients.isEmpty()) {
|
|
|
+ List<String> clientNums = diagClients.stream().map(c -> c.getClientNum()).collect(Collectors.toList());
|
|
|
+ String[] tokens = new String[clientNums.size()];
|
|
|
+ for (String clientNum : clientNums) {
|
|
|
+ int i = 0;
|
|
|
+ Client client = clientService.lambdaQuery()
|
|
|
+ .eq(Client::getNumber, clientNum)
|
|
|
+ .one();
|
|
|
+ if (BeanUtil.isNotEmpty(client)) {
|
|
|
+ tokens[i] = client.getDeviceToken();
|
|
|
+ i++;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ //调用工具类
|
|
|
+ pushInfo.setJson(JSONUtil.parseObj(vehicleInfo));
|
|
|
+ try {
|
|
|
+ pushUtil.sendAndroidListcastJSON(tokens,pushInfo);
|
|
|
+ } catch (Exception e) {
|
|
|
+ throw new BizException("推送失败!!!");
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return Result.ok();
|
|
|
+ }
|
|
|
+
|
|
|
@Override
|
|
|
public Result getDesc(DiagnosisVersionVO diagnosisVersionVO) {
|
|
|
return null;
|