From 1cff3842cca26d770bdba4f8fd2143742342b093 Mon Sep 17 00:00:00 2001 From: liusheng <337615773@qq.com> Date: 星期一, 22 七月 2024 17:40:12 +0800 Subject: [PATCH] 代码提交 --- smartor/src/main/java/com/smartor/service/impl/ServiceSubtaskAnswerServiceImpl.java | 186 ++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 171 insertions(+), 15 deletions(-) diff --git a/smartor/src/main/java/com/smartor/service/impl/ServiceSubtaskAnswerServiceImpl.java b/smartor/src/main/java/com/smartor/service/impl/ServiceSubtaskAnswerServiceImpl.java index cc6b26f..908e483 100644 --- a/smartor/src/main/java/com/smartor/service/impl/ServiceSubtaskAnswerServiceImpl.java +++ b/smartor/src/main/java/com/smartor/service/impl/ServiceSubtaskAnswerServiceImpl.java @@ -1,13 +1,24 @@ package com.smartor.service.impl; +import com.ruoyi.common.core.redis.RedisCache; import com.ruoyi.common.utils.DateUtils; -import com.smartor.domain.ServiceSubtaskAnswer; +import com.ruoyi.common.utils.RSAPublicKeyExample; +import com.ruoyi.common.utils.StringUtils; +import com.smartor.domain.*; import com.smartor.mapper.ServiceSubtaskAnswerMapper; +import com.smartor.mapper.ServiceSubtaskMapper; import com.smartor.service.IServiceSubtaskAnswerService; +import lombok.extern.slf4j.Slf4j; +import org.apache.commons.collections4.CollectionUtils; +import org.apache.commons.lang3.ObjectUtils; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Service; +import java.util.Date; +import java.util.HashSet; import java.util.List; +import java.util.Set; /** * 浠诲姟闂嵎闂閫夐」Service涓氬姟灞傚鐞� @@ -15,11 +26,20 @@ * @author ruoyi * @date 2024-07-18 */ +@Slf4j @Service -public class ServiceSubtaskAnswerServiceImpl implements IServiceSubtaskAnswerService -{ +public class ServiceSubtaskAnswerServiceImpl implements IServiceSubtaskAnswerService { @Autowired private ServiceSubtaskAnswerMapper serviceSubtaskAnswerMapper; + + @Autowired + private ServiceSubtaskMapper serviceSubtaskMapper; + + @Autowired + private RedisCache redisCache; + + @Value("${pri_key}") + private String pri_key; /** * 鏌ヨ浠诲姟闂嵎闂閫夐」 @@ -28,8 +48,7 @@ * @return 浠诲姟闂嵎闂閫夐」 */ @Override - public ServiceSubtaskAnswer selectServiceSubtaskAnswerById(Long id) - { + public ServiceSubtaskAnswer selectServiceSubtaskAnswerById(Long id) { return serviceSubtaskAnswerMapper.selectServiceSubtaskAnswerById(id); } @@ -40,8 +59,7 @@ * @return 浠诲姟闂嵎闂閫夐」 */ @Override - public List<ServiceSubtaskAnswer> selectServiceSubtaskAnswerList(ServiceSubtaskAnswer serviceSubtaskAnswer) - { + public List<ServiceSubtaskAnswer> selectServiceSubtaskAnswerList(ServiceSubtaskAnswer serviceSubtaskAnswer) { return serviceSubtaskAnswerMapper.selectServiceSubtaskAnswerList(serviceSubtaskAnswer); } @@ -52,8 +70,7 @@ * @return 缁撴灉 */ @Override - public int insertServiceSubtaskAnswer(ServiceSubtaskAnswer serviceSubtaskAnswer) - { + public int insertServiceSubtaskAnswer(ServiceSubtaskAnswer serviceSubtaskAnswer) { serviceSubtaskAnswer.setCreateTime(DateUtils.getNowDate()); return serviceSubtaskAnswerMapper.insertServiceSubtaskAnswer(serviceSubtaskAnswer); } @@ -65,8 +82,7 @@ * @return 缁撴灉 */ @Override - public int updateServiceSubtaskAnswer(ServiceSubtaskAnswer serviceSubtaskAnswer) - { + public int updateServiceSubtaskAnswer(ServiceSubtaskAnswer serviceSubtaskAnswer) { serviceSubtaskAnswer.setUpdateTime(DateUtils.getNowDate()); return serviceSubtaskAnswerMapper.updateServiceSubtaskAnswer(serviceSubtaskAnswer); } @@ -78,8 +94,7 @@ * @return 缁撴灉 */ @Override - public int deleteServiceSubtaskAnswerByIds(Long[] ids) - { + public int deleteServiceSubtaskAnswerByIds(Long[] ids) { return serviceSubtaskAnswerMapper.deleteServiceSubtaskAnswerByIds(ids); } @@ -90,8 +105,149 @@ * @return 缁撴灉 */ @Override - public int deleteServiceSubtaskAnswerById(Long id) - { + public int deleteServiceSubtaskAnswerById(Long id) { return serviceSubtaskAnswerMapper.deleteServiceSubtaskAnswerById(id); } + + @Override + public Integer saveQuestionAnswer(ServiceSubTaskAnswerReq serviceSubTaskAnswerReq) { + Set<String> allKeys = redisCache.getAllKeys(); + if (ObjectUtils.isNotEmpty(serviceSubTaskAnswerReq)) { + //闇�瑕佺珛鍗虫墽琛� + RSAPublicKeyExample rsaPublicKeyExample = new RSAPublicKeyExample(); + Long tid = Long.valueOf(rsaPublicKeyExample.decryptedData(serviceSubTaskAnswerReq.getParam1(), pri_key)); + Long pid = Long.valueOf(rsaPublicKeyExample.decryptedData(serviceSubTaskAnswerReq.getParam2(), pri_key)); + + allKeys = new HashSet<>(); + if (serviceSubTaskAnswerReq.getType() == 1) { +// allKeys.add(redisCache.getCacheObject(pid + "-" + tid + "-SFscriptCache")); + allKeys.add(pid + "-" + tid + "-SFscriptCache"); + } else if (serviceSubTaskAnswerReq.getType() == 2) { +// allKeys.add(redisCache.getCacheObject(pid + "-" + tid + "-WJscriptCache")); + allKeys.add(pid + "-" + tid + "-WJscriptCache"); + } + } + + Long nextScriptno = null; + for (String key : allKeys) { + String[] split = key.split("-"); + if (key.contains("-SFscriptCache")) { + //鍖呭惈浜�,璇存槑浜嗘槸闅忚闂 + List<IvrLibaTemplateScriptVO> cacheList = redisCache.getCacheObject(key); + for (int i = 0; i < cacheList.size(); i++) { + if (i == 0) { + // 璇存槑鏄涓�棰� + IvrLibaTemplateScriptVO ivrLibaTemplateScriptVO = cacheList.get(0); + //灏嗙涓�棰樼殑淇℃伅鏀惧埌琛ㄤ腑 + setSFInfo(ivrLibaTemplateScriptVO, Long.valueOf(split[1]), Long.valueOf(split[0])); + nextScriptno = cacheList.get(0).getNextScriptno(); + } else { + //涓嶆槸绗� 涓� 棰� + for (IvrLibaTemplateScriptVO ivrLibaTemplateScriptVO : cacheList) { + if (ivrLibaTemplateScriptVO.getId() == nextScriptno) { + setSFInfo(ivrLibaTemplateScriptVO, Long.valueOf(split[1]), Long.valueOf(split[0])); + nextScriptno = ivrLibaTemplateScriptVO.getNextScriptno(); + } + } + } + } + } else if (key.contains("-WJscriptCache")) { + List<SvyLibTemplateScriptVO> cacheList = redisCache.getCacheList(key); + for (int i = 0; i < cacheList.size(); i++) { + if (i == 0) { + // 璇存槑鏄涓�棰� + //灏嗙涓�棰樼殑淇℃伅鏀惧埌琛ㄤ腑 + setWJInfo(cacheList.get(0), Long.valueOf(split[1]), Long.valueOf(split[0])); + nextScriptno = Long.valueOf(cacheList.get(0).getNextScriptno()); + } else { + for (SvyLibTemplateScriptVO svyLibTemplateScriptVO : cacheList) { + if (svyLibTemplateScriptVO.getId() == nextScriptno) { + //灏嗙涓�棰樼殑淇℃伅鏀惧埌琛ㄤ腑 + setWJInfo(svyLibTemplateScriptVO, Long.valueOf(split[1]), Long.valueOf(split[0])); + nextScriptno = Long.valueOf(cacheList.get(0).getNextScriptno()); + } + + } + } + } + } + //灏嗚key鍜寁alue浠巖edis涓紝鍒犻櫎 + redisCache.deleteObject(key); + } + return 1; + } + + /** + * 灏嗛棶棰樹繚瀛樺埌缂撳瓨涓� + * + * @param serviceSubTaskCacheReq + * @return + */ + @Override + public Integer saveQuestionCache(ServiceSubTaskCacheReq serviceSubTaskCacheReq) { + RSAPublicKeyExample rsaPublicKeyExample = new RSAPublicKeyExample(); + Long tid = Long.valueOf(rsaPublicKeyExample.decryptedData(serviceSubTaskCacheReq.getParam1(), pri_key)); + Long pid = Long.valueOf(rsaPublicKeyExample.decryptedData(serviceSubTaskCacheReq.getParam2(), pri_key)); + if (CollectionUtils.isNotEmpty(serviceSubTaskCacheReq.getIvrLibaTemplateScriptVOList())) { + //闅忚 + redisCache.setCacheObject(pid + "-" + tid + "-SFscriptCache", serviceSubTaskCacheReq.getIvrLibaTemplateScriptVOList()); + } else if (CollectionUtils.isNotEmpty(serviceSubTaskCacheReq.getSvyLibTemplateScriptVOList())) { + //闂嵎 + redisCache.setCacheObject(pid + "-" + tid + "-WJscriptCache", serviceSubTaskCacheReq.getSvyLibTemplateScriptVOList()); + } + return 1; + } + + + private void setSFInfo(IvrLibaTemplateScriptVO ivrLibaTemplateScriptVO, Long taskid, Long patid) { + ServiceSubtaskAnswer serviceSubtaskAnswer = null; + String dx = ""; + if (StringUtils.isNotEmpty(ivrLibaTemplateScriptVO.getScriptType()) && ivrLibaTemplateScriptVO.getScriptType().equals("1") || StringUtils.isNotEmpty(ivrLibaTemplateScriptVO.getScriptType()) && ivrLibaTemplateScriptVO.getScriptType().equals("2")) { + //1銆�2涓哄崟閫夋垨澶氶�� + for (IvrLibaTemplateTargetoption ivrLibaTemplateTargetoption : ivrLibaTemplateScriptVO.getIvrLibaScriptTargetoptionList()) { + //鑾峰彇鐢ㄦ埛閫変腑鐨勯�夐」鍙� + dx = dx + "," + ivrLibaTemplateTargetoption.getOptionNo().toString(); + } + } else { + //闈炲崟澶氶�� + if (CollectionUtils.isNotEmpty(ivrLibaTemplateScriptVO.getIvrLibaScriptTargetoptionList())) { + dx = ivrLibaTemplateScriptVO.getIvrLibaScriptTargetoptionList().get(0).getAppenddesc(); + } + } + serviceSubtaskAnswer.setTaskid(taskid); + serviceSubtaskAnswer.setPatId(patid); + serviceSubtaskAnswer.setScriptid(ivrLibaTemplateScriptVO.getId()); + serviceSubtaskAnswer.setScriptType(Long.valueOf(ivrLibaTemplateScriptVO.getScriptType())); + serviceSubtaskAnswer.setAnswer(dx.substring(1)); + serviceSubtaskAnswer.setComment(null); + serviceSubtaskAnswer.setCreateTime(new Date()); + serviceSubtaskAnswer.setUpdateTime(new Date()); + serviceSubtaskAnswerMapper.insertServiceSubtaskAnswer(serviceSubtaskAnswer); + } + + private void setWJInfo(SvyLibTemplateScriptVO svyLibTemplateScriptVO, Long taskid, Long patid) { + ServiceSubtaskAnswer serviceSubtaskAnswer = null; + String dx = ""; + if (svyLibTemplateScriptVO.getScriptType().equals("1") || svyLibTemplateScriptVO.getScriptType().equals("2")) { + //1銆�2涓哄崟閫夋垨澶氶�� + for (SvyLibTemplateTargetoption svyLibTemplateTargetoption : svyLibTemplateScriptVO.getSvyLibTemplateTargetoptions()) { + //鑾峰彇鐢ㄦ埛閫変腑鐨勯�夐」鍙� + dx = dx + "," + svyLibTemplateTargetoption.getOptionNo().toString(); + } + } else { + //闈炲崟澶氶�� + if (CollectionUtils.isNotEmpty(svyLibTemplateScriptVO.getSvyLibTemplateTargetoptions())) { + dx = svyLibTemplateScriptVO.getSvyLibTemplateTargetoptions().get(0).getAppenddesc(); + } + } + serviceSubtaskAnswer.setTaskid(Long.valueOf(taskid)); + serviceSubtaskAnswer.setPatId(Long.valueOf(patid)); + serviceSubtaskAnswer.setScriptid(svyLibTemplateScriptVO.getId()); + serviceSubtaskAnswer.setScriptType(Long.valueOf(svyLibTemplateScriptVO.getScriptType())); + serviceSubtaskAnswer.setAnswer(dx.substring(1)); + serviceSubtaskAnswer.setComment(null); + serviceSubtaskAnswer.setCreateTime(new Date()); + serviceSubtaskAnswer.setUpdateTime(new Date()); + serviceSubtaskAnswerMapper.insertServiceSubtaskAnswer(serviceSubtaskAnswer); + } } -- Gitblit v1.9.3