diff --git a/backend/src/main/java/io/metersphere/api/controller/ApiTestEnvironmentController.java b/backend/src/main/java/io/metersphere/api/controller/ApiTestEnvironmentController.java index 23ffaa1a8c..887c2149c9 100644 --- a/backend/src/main/java/io/metersphere/api/controller/ApiTestEnvironmentController.java +++ b/backend/src/main/java/io/metersphere/api/controller/ApiTestEnvironmentController.java @@ -1,5 +1,7 @@ package io.metersphere.api.controller; +import com.alibaba.fastjson.JSONArray; +import com.alibaba.fastjson.JSONObject; import com.github.pagehelper.Page; import com.github.pagehelper.PageHelper; import io.metersphere.api.dto.ApiTestEnvironmentDTO; @@ -9,9 +11,12 @@ import io.metersphere.api.service.CommandService; import io.metersphere.base.domain.ApiTestEnvironmentWithBLOBs; import io.metersphere.commons.constants.OperLogConstants; import io.metersphere.commons.constants.OperLogModule; +import io.metersphere.commons.exception.MSException; +import io.metersphere.commons.utils.LogUtil; import io.metersphere.commons.utils.PageUtils; import io.metersphere.commons.utils.Pager; import io.metersphere.controller.request.EnvironmentRequest; +import io.metersphere.i18n.Translator; import io.metersphere.log.annotation.MsAuditLog; import org.springframework.web.bind.annotation.*; import org.springframework.web.multipart.MultipartFile; @@ -61,15 +66,44 @@ public class ApiTestEnvironmentController { @PostMapping("/add") @MsAuditLog(module = OperLogModule.PROJECT_ENVIRONMENT_SETTING, type = OperLogConstants.CREATE, content = "#msClass.getLogDetails(#apiTestEnvironmentWithBLOBs.id)", msClass = ApiTestEnvironmentService.class) public String create(@RequestPart("request") ApiTestEnvironmentDTO apiTestEnvironmentWithBLOBs, @RequestPart(value = "files", required = false) List sslFiles) { + checkParams(apiTestEnvironmentWithBLOBs); return apiTestEnvironmentService.add(apiTestEnvironmentWithBLOBs, sslFiles); } @PostMapping(value = "/update") @MsAuditLog(module = OperLogModule.PROJECT_ENVIRONMENT_SETTING, type = OperLogConstants.UPDATE, beforeEvent = "#msClass.getLogDetails(#apiTestEnvironment.id)", content = "#msClass.getLogDetails(#apiTestEnvironment.id)", msClass = ApiTestEnvironmentService.class) public void update(@RequestPart("request") ApiTestEnvironmentDTO apiTestEnvironment, @RequestPart(value = "files", required = false) List sslFiles) { + checkParams(apiTestEnvironment); apiTestEnvironmentService.update(apiTestEnvironment, sslFiles); } + private void checkParams(ApiTestEnvironmentDTO apiTestEnvironment) { + try { + JSONObject json = JSONObject.parseObject(apiTestEnvironment.getConfig()); + JSONObject commonConfig = json.getJSONObject("commonConfig"); + JSONArray databaseConfigs = json.getJSONArray("databaseConfigs"); + + Object requestTimeout = commonConfig.get("requestTimeout"); + Object responseTimeout = commonConfig.get("responseTimeout"); + if (commonConfig != null && (requestTimeout != null || responseTimeout != null) && ((int) requestTimeout < 1 || + (int) responseTimeout < 1)) { + MSException.throwException(Translator.get("invalid_parameter")); + } + if (databaseConfigs.size() > 0) { + for (Object databaseConfig : databaseConfigs) { + JSONObject database = (JSONObject) databaseConfig; + Object poolMax = database.get("poolMax"); + Object timeout = database.get("timeout"); + if (database != null && (poolMax != null || timeout != null) && (int) database.get("poolMax") < 1 || (int) database.get("timeout") < 1) { + MSException.throwException(Translator.get("invalid_parameter")); + } + } + } + } catch (Exception e) { + LogUtil.error(e); + } + } + @GetMapping("/delete/{id}") @MsAuditLog(module = OperLogModule.PROJECT_ENVIRONMENT_SETTING, type = OperLogConstants.DELETE, beforeEvent = "#msClass.getLogDetails(#id)", msClass = ApiTestEnvironmentService.class) public void delete(@PathVariable String id) { diff --git a/frontend/src/business/components/api/test/components/environment/EnvironmentCommonConfig.vue b/frontend/src/business/components/api/test/components/environment/EnvironmentCommonConfig.vue index fa3d852155..4dbff648b8 100644 --- a/frontend/src/business/components/api/test/components/environment/EnvironmentCommonConfig.vue +++ b/frontend/src/business/components/api/test/components/environment/EnvironmentCommonConfig.vue @@ -8,12 +8,16 @@ {{ $t('api_test.environment.request_timeout') }}: + v-model="commonConfig.requestTimeout" + onKeypress="return (/[\d]/.test(String.fromCharCode(event.keyCode)))" + :precision="0"> {{ $t('api_test.environment.globalVariable') }} {{ $t('api_test.environment.response_timeout') }}: + v-model="commonConfig.responseTimeout" + onKeypress="return (/[\d]/.test(String.fromCharCode(event.keyCode)))" + :precision="0"> {{ $t('api_test.environment.globalVariable') }} diff --git a/frontend/src/business/components/api/test/components/request/database/DatabaseFrom.vue b/frontend/src/business/components/api/test/components/request/database/DatabaseFrom.vue index eabdfac4e3..85fdf9c0cd 100644 --- a/frontend/src/business/components/api/test/components/request/database/DatabaseFrom.vue +++ b/frontend/src/business/components/api/test/components/request/database/DatabaseFrom.vue @@ -32,12 +32,18 @@ - + - + diff --git a/frontend/src/business/components/api/test/components/request/tcp/TcpConfig.vue b/frontend/src/business/components/api/test/components/request/tcp/TcpConfig.vue index 64175f2816..a468fc1d43 100644 --- a/frontend/src/business/components/api/test/components/request/tcp/TcpConfig.vue +++ b/frontend/src/business/components/api/test/components/request/tcp/TcpConfig.vue @@ -24,12 +24,16 @@ - + - +