From 37f2e4e68c0d55e094981fa478fc198b907f87dc Mon Sep 17 00:00:00 2001
From: liusheng <337615773@qq.com>
Date: 星期六, 20 七月 2024 16:30:13 +0800
Subject: [PATCH] 代码提交
---
smartor/src/main/java/com/smartor/service/impl/ServiceSubtaskAnswerServiceImpl.java | 183 ++++++++++++++++++++++++++++++++++++++++++---
1 files changed, 168 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..bf0c347 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,146 @@
* @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"));
+ } else if (serviceSubTaskAnswerReq.getType() == 2) {
+ allKeys.add(redisCache.getCacheObject(pid + "-" + tid + "-WJscriptCache"));
+ }
+ }
+
+ Long nextScriptno = null;
+ for (String key : allKeys) {
+ String[] split = key.split("-");
+ if (key.contains("-SFscriptCache")) {
+ //鍖呭惈浜�,璇存槑浜嗘槸闅忚闂
+ List<IvrLibaTemplateScriptVO> cacheList = redisCache.getCacheList(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 (ivrLibaTemplateScriptVO.getScriptType().equals("1") || 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(Long.valueOf(taskid));
+ serviceSubtaskAnswer.setPatId(Long.valueOf(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