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.LoanerUser;
|
import com.deloitte.system.request.LoanerUserDto;
|
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 LoanerUserService {
|
private String tableName="loaner_user";
|
|
@Autowired
|
private CryptoService cryptoService;
|
|
@Autowired
|
private IdUtils idWorker;
|
|
@Autowired
|
private RedisUtil redisUtil;
|
|
public LoanerUserDto queryForOne(String dataId) {
|
LoanerUser loanerUser =LoanerUser.dao.findById(dataId);
|
if (!ObjectUtil.isEmpty(loanerUser)){
|
LoanerUserDto dto = BeanHelper.copyAs(loanerUser, LoanerUserDto.class);
|
return dto;
|
}
|
return null;
|
}
|
|
public List<LoanerUserDto> insertList(List<LoanerUserDto> loanerUserDtoList, String txId) {
|
List<LoanerUserDto> respList = new ArrayList<>();
|
CacheList<LoanerUserDto> dtoCacheList = new CacheList<>();
|
dtoCacheList.setTableName(tableName);
|
List<LoanerUserDto> dtoItemList = new ArrayList<>();
|
loanerUserDtoList.forEach(e -> {
|
String dataId = idWorker.nextId();
|
LoanerUserDto cacheItem = BeanHelper.copyAs(e, LoanerUserDto.class);
|
cacheItem.setDataId(dataId);
|
dtoItemList.add(cacheItem);
|
LoanerUserDto target = BeanHelper.copyAs(e, LoanerUserDto.class);
|
target.setDataId(dataId);
|
LoanerUserDto dto = cryptoService.encryptModelColumns(e);
|
dto.setDataId(dataId);
|
target.setContactEncrypt(dto.getContact());
|
target.setContactNumberEncrypt(dto.getContactNumber());
|
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<LoanerUserDto> updateList(List<LoanerUserDto> loanerUserDtoList, String txId) {
|
List<LoanerUserDto> respList = new ArrayList<>();
|
CacheList<LoanerUserDto> dtoCacheList = new CacheList<>();
|
dtoCacheList.setTableName(tableName);
|
List<LoanerUserDto> dtoItemList = new ArrayList<>();
|
loanerUserDtoList.forEach(e -> {
|
LoanerUser loanerUser = LoanerUser.dao.findById(e.getDataId());
|
LoanerUserDto cacheItem = BeanHelper.copyAs(e, LoanerUserDto.class);
|
dtoItemList.add(cacheItem);
|
LoanerUserDto dto = BeanHelper.copyAs(BeanHelper.copy(cacheItem,loanerUser),LoanerUserDto.class);
|
LoanerUserDto target = BeanHelper.copyAs(dto, LoanerUserDto.class);
|
dto = cryptoService.encryptModelColumns(dto);
|
target.setContactEncrypt(dto.getContact());
|
target.setContactNumberEncrypt(dto.getContactNumber());
|
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) {
|
LoanerUser loanerUser = LoanerUser.dao.findById(dataId);
|
loanerUser.setIsDelete(1);
|
return loanerUser.saveOrUpdate();
|
}
|
|
public Boolean undeleteOne(String dataId) {
|
LoanerUser loanerUser = LoanerUser.dao.findById(dataId);
|
loanerUser.setIsDelete(0);
|
return loanerUser.saveOrUpdate();
|
}
|
|
|
public List<LoanerUserDto> 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<LoanerUser> loanerUsers = LoanerUser.dao.findList(queryParam.toString());
|
return loanerUsers.stream()
|
.map(loanerUser -> BeanHelper.copyAs(loanerUser, LoanerUserDto.class)).collect(Collectors.toList());
|
|
}
|
|
}
|