package com.deloitte.system.service;
|
|
import cn.hutool.core.collection.CollUtil;
|
import cn.hutool.core.util.ObjectUtil;
|
import com.alibaba.fastjson.JSONArray;
|
import com.common.core.constant.GlobalConst;
|
import com.common.core.exception.BizException;
|
import com.common.core.service.CryptoService;
|
import com.common.core.utils.BeanHelper;
|
import com.common.core.utils.DesensitiveUtils;
|
import com.common.core.utils.IdUtils;
|
import com.common.redis.util.RedisUtil;
|
import com.deloitte.system.model.CacheList;
|
import com.deloitte.system.model.TSRepair;
|
import com.deloitte.system.request.TSRepairDto;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.stereotype.Service;
|
|
import java.util.ArrayList;
|
import java.util.List;
|
import java.util.stream.Collectors;
|
|
import static com.common.core.constant.GlobalConst.PIPL_UNCONFIRM_INSERT;
|
import static com.common.core.constant.GlobalConst.PIPL_UNCONFIRM_UPDATE;
|
|
|
@Service
|
public class TSRepairService {
|
|
private String tableName = "ts_repair";
|
@Autowired
|
private CryptoService cryptoService;
|
|
@Autowired
|
private IdUtils idWorker;
|
|
@Autowired
|
private RedisUtil redisUtil;
|
|
public TSRepairDto queryForOne(String dataId) {
|
TSRepair tsRepair =TSRepair.dao.findById(dataId);
|
if (!ObjectUtil.isEmpty(tsRepair)){
|
TSRepairDto dto = BeanHelper.copyAs(tsRepair, TSRepairDto.class);
|
return dto;
|
}
|
return null;
|
}
|
|
public List<TSRepairDto> insertList(List<TSRepairDto> tsRepairDtoList, String txId) {
|
List<TSRepairDto> respList = new ArrayList<>();
|
CacheList<TSRepairDto> dtoCacheList = new CacheList<>();
|
dtoCacheList.setTableName(tableName);
|
List<TSRepairDto> dtoItemList = new ArrayList<>();
|
tsRepairDtoList.forEach(e -> {
|
String dataId = idWorker.nextId();
|
TSRepairDto cacheItem = BeanHelper.copyAs(e, TSRepairDto.class);
|
cacheItem.setDataId(dataId);
|
dtoItemList.add(cacheItem);
|
|
TSRepairDto target = BeanHelper.copyAs(e, TSRepairDto.class);
|
target.setDataId(dataId);
|
TSRepairDto dto = cryptoService.encryptModelColumns(e);
|
dto.setDataId(dataId);
|
target.setBusinessAContactEncrypt(dto.getBusinessAContact());
|
target.setBusinessAPhoneEncrypt(dto.getBusinessAPhone());
|
DesensitiveUtils.format(target);
|
respList.add(target);
|
});
|
dtoCacheList.setData(dtoItemList);
|
String insertJsonString = JSONArray.toJSONString(dtoCacheList);
|
String insertKey = PIPL_UNCONFIRM_INSERT + txId;
|
boolean redisFlag = redisUtil.set(insertKey, insertJsonString, GlobalConst.DATA_EXPIRE);
|
if (!redisFlag){
|
throw new BizException("缓存写入失败");
|
}
|
return respList;
|
}
|
|
public List<TSRepairDto> updateList(List<TSRepairDto> tsRepairDtoList, String txId) {
|
List<TSRepairDto> respList = new ArrayList<>();
|
CacheList<TSRepairDto> dtoCacheList = new CacheList<>();
|
dtoCacheList.setTableName(tableName);
|
List<TSRepairDto> dtoItemList = new ArrayList<>();
|
tsRepairDtoList.forEach(e -> {
|
TSRepair tsRepair = TSRepair.dao.findById(e.getDataId());
|
TSRepairDto cacheItem = BeanHelper.copyAs(e, TSRepairDto.class);
|
dtoItemList.add(cacheItem);
|
TSRepairDto dto = BeanHelper.copyAs(BeanHelper.copy(cacheItem,tsRepair),TSRepairDto.class);
|
TSRepairDto target = BeanHelper.copyAs(dto, TSRepairDto.class);
|
dto = cryptoService.encryptModelColumns(dto);
|
target.setBusinessAPhoneEncrypt(dto.getBusinessAPhone());
|
target.setBusinessAContactEncrypt(dto.getBusinessAContact());
|
DesensitiveUtils.format(target);
|
respList.add(target);
|
});
|
dtoCacheList.setData(dtoItemList);
|
String updateJsonString = JSONArray.toJSONString(dtoCacheList);
|
String updateKey = PIPL_UNCONFIRM_UPDATE + txId;
|
boolean redisFlag = redisUtil.set(updateKey, updateJsonString,GlobalConst.DATA_EXPIRE);
|
if (!redisFlag){
|
throw new BizException("缓存写入失败");
|
}
|
return respList;
|
|
}
|
|
public Boolean deleteOne(String dataId) {
|
TSRepair tsRepair = TSRepair.dao.findById(dataId);
|
tsRepair.setIsDelete(1);
|
return tsRepair.saveOrUpdate();
|
}
|
|
public Boolean undeleteOne(String dataId) {
|
TSRepair tsRepair = TSRepair.dao.findById(dataId);
|
tsRepair.setIsDelete(0);
|
return tsRepair.saveOrUpdate();
|
}
|
|
public List<TSRepairDto> search(List<String> idList){
|
if (CollUtil.isEmpty(idList)) {
|
return null;
|
}
|
StringBuilder queryParam = new StringBuilder();
|
queryParam.append("and id in ").append(idList.stream().collect(Collectors.joining(", ", "(", ")")));
|
List<TSRepair> quotesList = TSRepair.dao.findList(queryParam.toString());
|
return quotesList.stream()
|
.map(quotes -> BeanHelper.copyAs(quotes, TSRepairDto.class)).collect(Collectors.toList());
|
|
}
|
}
|