|
@@ -8,15 +8,15 @@ import api.common.pojo.po.scene.SceneComplexityPO;
|
|
|
import api.common.pojo.po.scene.SceneEvaluationOperatePO;
|
|
|
import api.common.pojo.po.scene.SceneEvaluationRulePO;
|
|
|
import api.common.pojo.po.scene.SceneRiskPO;
|
|
|
-import api.common.util.LogUtil;
|
|
|
-import api.common.util.StringUtil;
|
|
|
-import api.common.util.TimeUtil;
|
|
|
+import api.common.pojo.po.system.SceneEvaluationRuleScriptPO;
|
|
|
+import api.common.util.*;
|
|
|
import com.alibaba.druid.util.StringUtils;
|
|
|
import com.css.simulation.resource.server.infra.db.mysql.mapper.SceneComplexityMapper;
|
|
|
import com.css.simulation.resource.server.infra.db.mysql.mapper.SceneEvaluationRuleMapper;
|
|
|
import com.css.simulation.resource.server.infra.db.mysql.mapper.ScenePackageMapper;
|
|
|
import com.css.simulation.resource.server.infra.db.mysql.mapper.SceneRiskMapper;
|
|
|
import com.css.simulation.resource.server.infra.feign.service.FileDownService;
|
|
|
+import com.css.simulation.resource.server.infra.feign.service.SceneService;
|
|
|
import com.css.simulation.resource.server.infra.runnable.SceneEvaluationComputeRunnable;
|
|
|
import com.css.simulation.resource.server.infra.threadpool.ThreadPool;
|
|
|
import com.css.simulation.resource.server.infra.util.AuthUtil;
|
|
@@ -33,6 +33,9 @@ import java.util.Map;
|
|
|
import java.util.function.Function;
|
|
|
import java.util.stream.Collectors;
|
|
|
|
|
|
+import static api.common.pojo.constants.DictConstants.SCENE_IMPORT_STATUS_1;
|
|
|
+import static api.common.pojo.constants.DictConstants.SCENE_IMPORT_STATUS_2;
|
|
|
+
|
|
|
@Slf4j
|
|
|
@Service
|
|
|
public class SceneEvaluationRuleService {
|
|
@@ -56,6 +59,9 @@ public class SceneEvaluationRuleService {
|
|
|
@Resource
|
|
|
private FileDownService fileDownService;
|
|
|
|
|
|
+ @Resource
|
|
|
+ private SceneService sceneService;
|
|
|
+
|
|
|
@SneakyThrows
|
|
|
public int querySceneEvaluationRuleOnly(String ruleName, String ruleId) {
|
|
|
return sceneEvaluationRuleMapper.querySceneEvaluationRuleOnly(ruleName, ruleId);
|
|
@@ -102,6 +108,7 @@ public class SceneEvaluationRuleService {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+ sceneEvaluationRulePO.setStatus(SCENE_IMPORT_STATUS_2);
|
|
|
|
|
|
if (StringUtil.isEmpty(sceneEvaluationRulePO.getRuleId())) {
|
|
|
|
|
@@ -116,54 +123,44 @@ public class SceneEvaluationRuleService {
|
|
|
|
|
|
@SneakyThrows
|
|
|
public ResponseBodyVO<String> uploadPyScriptAndSaveRuleByPath(SceneEvaluationRulePO sceneEvaluationRulePO) {
|
|
|
-
|
|
|
- boolean hasRuleId = StringUtil.isEmpty(sceneEvaluationRulePO.getRuleId());
|
|
|
+ if (ObjectUtil.isNull(sceneEvaluationRulePO)) {
|
|
|
+ return new ResponseBodyVO<>(false, 500, "参数错误!", null);
|
|
|
+ }
|
|
|
+ String sceneType = sceneEvaluationRulePO.getRuleType();
|
|
|
+ if (ObjectUtil.isNull(sceneType) || DictConstants.SCENE_GENERAL.equals(sceneType)) {
|
|
|
+ return new ResponseBodyVO<>(false, 500, "参数错误!", null);
|
|
|
+ }
|
|
|
+ boolean createRule = StringUtil.isEmpty(sceneEvaluationRulePO.getRuleId());
|
|
|
|
|
|
|
|
|
int repeatPyScriptAndSaveRuleCount = querySceneEvaluationRuleOnly(sceneEvaluationRulePO.getRuleName(),
|
|
|
- hasRuleId ? null : sceneEvaluationRulePO.getRuleId());
|
|
|
+ createRule ? null : sceneEvaluationRulePO.getRuleId());
|
|
|
if (repeatPyScriptAndSaveRuleCount > 0) {
|
|
|
return new ResponseBodyVO<>(ResponseBodyVO.Response.CLIENT_FAILURE, "场景规则 " + sceneEvaluationRulePO.getRuleName() + " 已存在,请重新命名。");
|
|
|
}
|
|
|
|
|
|
- if ((hasRuleId) || sceneEvaluationRulePO.getUploadNewFile()) {
|
|
|
+ if ((createRule) || sceneEvaluationRulePO.getUploadNewFile()) {
|
|
|
String roleCode = AuthUtil.getCurrentUserRoleCode();
|
|
|
if (!DictConstants.ROLE_CODE_ADMIN.equals(roleCode) && !DictConstants.ROLE_CODE_SYSADMIN.equals(roleCode)) {
|
|
|
return new ResponseBodyVO<>(ResponseBodyVO.Response.CLIENT_FAILURE, "非管理员禁止上传文件");
|
|
|
}
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
+ sceneEvaluationRulePO.setStatus(SCENE_IMPORT_STATUS_1);
|
|
|
+
|
|
|
+ if (StringUtil.isEmpty(sceneEvaluationRulePO.getRuleId())) {
|
|
|
+
|
|
|
+ saveSceneEvaluationRule(sceneEvaluationRulePO);
|
|
|
+ } else {
|
|
|
+
|
|
|
+ updateSceneEvaluationRule(sceneEvaluationRulePO);
|
|
|
+ }
|
|
|
+
|
|
|
+ SceneEvaluationRuleScriptPO sceneEvaluationRuleScriptPO = new SceneEvaluationRuleScriptPO();
|
|
|
+ sceneEvaluationRuleScriptPO.setRuleId(sceneEvaluationRulePO.getRuleId());
|
|
|
+ sceneEvaluationRuleScriptPO.setLocalPath(sceneEvaluationRulePO.getLocalPath());
|
|
|
+ sceneService.startImportEvaluationScript(sceneEvaluationRuleScriptPO);
|
|
|
+ return new ResponseBodyVO<>(ResponseBodyVO.Response.SUCCESS);
|
|
|
}
|
|
|
+ updateSceneEvaluationRule(sceneEvaluationRulePO);
|
|
|
return new ResponseBodyVO<>(ResponseBodyVO.Response.SUCCESS);
|
|
|
}
|
|
|
|