refactor(菜单管理): 优化获取第三方平台接口

This commit is contained in:
WangXu10 2023-10-24 18:24:52 +08:00 committed by 刘瑞斌
parent 66762de503
commit dc017c84c4
3 changed files with 33 additions and 17 deletions

View File

@ -2,12 +2,13 @@ package io.metersphere.project.service;
import io.metersphere.plugin.platform.spi.AbstractPlatformPlugin; import io.metersphere.plugin.platform.spi.AbstractPlatformPlugin;
import io.metersphere.plugin.platform.spi.Platform; import io.metersphere.plugin.platform.spi.Platform;
import io.metersphere.plugin.sdk.spi.MsPlugin;
import io.metersphere.project.domain.FakeErrorExample; import io.metersphere.project.domain.FakeErrorExample;
import io.metersphere.project.domain.ProjectApplication; import io.metersphere.project.domain.ProjectApplication;
import io.metersphere.project.domain.ProjectApplicationExample; import io.metersphere.project.domain.ProjectApplicationExample;
import io.metersphere.project.dto.ModuleDTO; import io.metersphere.project.dto.ModuleDTO;
import io.metersphere.project.job.CleanUpReportJob;
import io.metersphere.project.job.BugSyncJob; import io.metersphere.project.job.BugSyncJob;
import io.metersphere.project.job.CleanUpReportJob;
import io.metersphere.project.mapper.ExtProjectMapper; import io.metersphere.project.mapper.ExtProjectMapper;
import io.metersphere.project.mapper.ExtProjectUserRoleMapper; import io.metersphere.project.mapper.ExtProjectUserRoleMapper;
import io.metersphere.project.mapper.FakeErrorMapper; import io.metersphere.project.mapper.FakeErrorMapper;
@ -24,17 +25,18 @@ import io.metersphere.sdk.util.JSON;
import io.metersphere.system.domain.*; import io.metersphere.system.domain.*;
import io.metersphere.system.log.constants.OperationLogModule; import io.metersphere.system.log.constants.OperationLogModule;
import io.metersphere.system.log.constants.OperationLogType; import io.metersphere.system.log.constants.OperationLogType;
import io.metersphere.system.mapper.ExtPluginMapper;
import io.metersphere.system.mapper.PluginMapper; import io.metersphere.system.mapper.PluginMapper;
import io.metersphere.system.mapper.ServiceIntegrationMapper; import io.metersphere.system.mapper.ServiceIntegrationMapper;
import io.metersphere.system.sechedule.ScheduleService; import io.metersphere.system.sechedule.ScheduleService;
import io.metersphere.system.service.PlatformPluginService; import io.metersphere.system.service.PlatformPluginService;
import io.metersphere.system.service.PluginLoadService; import io.metersphere.system.service.PluginLoadService;
import io.metersphere.system.service.ServiceIntegrationService;
import io.metersphere.system.utils.ServiceUtils; import io.metersphere.system.utils.ServiceUtils;
import jakarta.annotation.Resource; import jakarta.annotation.Resource;
import org.apache.commons.collections.CollectionUtils; import org.apache.commons.collections.CollectionUtils;
import org.apache.commons.lang3.BooleanUtils; import org.apache.commons.lang3.BooleanUtils;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
import org.pf4j.PluginWrapper;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional; import org.springframework.transaction.annotation.Transactional;
@ -57,8 +59,6 @@ public class ProjectApplicationService {
@Resource @Resource
private ServiceIntegrationMapper serviceIntegrationMapper; private ServiceIntegrationMapper serviceIntegrationMapper;
@Resource
private ExtPluginMapper extPluginMapper;
@Resource @Resource
private PluginMapper pluginMapper; private PluginMapper pluginMapper;
@ -75,6 +75,9 @@ public class ProjectApplicationService {
@Resource @Resource
private FakeErrorMapper fakeErrorMapper; private FakeErrorMapper fakeErrorMapper;
@Resource
private ServiceIntegrationService serviceIntegrationService;
/** /**
* 更新配置信息 * 更新配置信息
* *
@ -184,15 +187,28 @@ public class ProjectApplicationService {
* @return * @return
*/ */
public List<OptionDTO> getPlatformOptions(String organizationId) { public List<OptionDTO> getPlatformOptions(String organizationId) {
ServiceIntegrationExample example = new ServiceIntegrationExample(); Set<String> orgPluginIds = platformPluginService.getOrgEnabledPlatformPlugins(organizationId)
example.createCriteria().andOrganizationIdEqualTo(organizationId).andEnableEqualTo(true); .stream()
List<ServiceIntegration> serviceIntegrations = serviceIntegrationMapper.selectByExample(example); .map(Plugin::getId)
.collect(Collectors.toSet());
// 查询服务集成中启用并且支持第三方模板的插件
List<ServiceIntegration> plusins = serviceIntegrationService.getServiceIntegrationByOrgId(organizationId)
.stream()
.filter(serviceIntegration -> {
return serviceIntegration.getEnable() // 服务集成开启
&& orgPluginIds.contains(serviceIntegration.getPluginId()); // 该服务集成对应的插件有权限
}).collect(Collectors.toList());
List<OptionDTO> options = new ArrayList<>(); List<OptionDTO> options = new ArrayList<>();
if (CollectionUtils.isNotEmpty(serviceIntegrations)) { plusins.forEach(serviceIntegration -> {
List<String> pluginIds = serviceIntegrations.stream().map(ServiceIntegration::getPluginId).collect(Collectors.toList()); PluginWrapper pluginWrapper = pluginLoadService.getPluginWrapper(serviceIntegration.getPluginId());
options = extPluginMapper.selectPluginOptions(pluginIds); MsPlugin plugin = (MsPlugin) pluginWrapper.getPlugin();
return options; if (plugin instanceof AbstractPlatformPlugin) {
} OptionDTO optionDTO = new OptionDTO();
optionDTO.setName(plugin.getName());
optionDTO.setId(pluginWrapper.getPluginId());
options.add(optionDTO);
}
});
return options; return options;
} }

View File

@ -63,7 +63,6 @@ public class ProjectApplicationControllerTests extends BaseTest {
//测试计划 - 清理报告配置 //测试计划 - 清理报告配置
@Test @Test
@Order(1) @Order(1)
@Sql(scripts = {"/dml/init_project_application_test.sql"}, config = @SqlConfig(encoding = "utf-8", transactionMode = SqlConfig.TransactionMode.ISOLATED))
public void testTestPlanClean() throws Exception { public void testTestPlanClean() throws Exception {
this.testGetTestPlan(); this.testGetTestPlan();
//新增 //新增
@ -358,7 +357,8 @@ public class ProjectApplicationControllerTests extends BaseTest {
//用例管理 - 获取平台下拉列表 //用例管理 - 获取平台下拉列表
@Test @Test
@Order(25) @Order(40)
@Sql(scripts = {"/dml/init_project_application_test.sql"}, config = @SqlConfig(encoding = "utf-8", transactionMode = SqlConfig.TransactionMode.ISOLATED))
public void testGetPlatform() throws Exception { public void testGetPlatform() throws Exception {
this.requestGetWithOkAndReturn(GET_PLATFORM_URL + "/100002"); this.requestGetWithOkAndReturn(GET_PLATFORM_URL + "/100002");
MvcResult mvcResult = this.requestGetWithOkAndReturn(GET_PLATFORM_URL + "/100001"); MvcResult mvcResult = this.requestGetWithOkAndReturn(GET_PLATFORM_URL + "/100001");
@ -439,7 +439,7 @@ public class ProjectApplicationControllerTests extends BaseTest {
//缺陷管理 - 获取平台下拉列表 //缺陷管理 - 获取平台下拉列表
@Test @Test
@Order(31) @Order(41)
public void testGetBugPlatform() throws Exception { public void testGetBugPlatform() throws Exception {
this.requestGetWithOkAndReturn(GET_BUG_PLATFORM_URL + "/100002"); this.requestGetWithOkAndReturn(GET_BUG_PLATFORM_URL + "/100002");
MvcResult mvcResult = this.requestGetWithOkAndReturn(GET_BUG_PLATFORM_URL + "/100001"); MvcResult mvcResult = this.requestGetWithOkAndReturn(GET_BUG_PLATFORM_URL + "/100001");
@ -643,7 +643,7 @@ public class ProjectApplicationControllerTests extends BaseTest {
configs.put("jiraKey", "Test"); configs.put("jiraKey", "Test");
configs.put("jiraIssueTypeId", "10086"); configs.put("jiraIssueTypeId", "10086");
configs.put("jiraStoryTypeId", "10010"); configs.put("jiraStoryTypeId", "10010");
assertErrorCode(this.requestPost(CHECK_PROJECT_KEY_URL + "/" + plugin.getId(), configs), NOT_FOUND); assertErrorCode(this.requestPost(CHECK_PROJECT_KEY_URL + "/" + "test", configs), NOT_FOUND);
JiraIntegrationConfig integrationConfig = new JiraIntegrationConfig(); JiraIntegrationConfig integrationConfig = new JiraIntegrationConfig();
integrationConfig.setAddress(String.format("http://%s:%s", mockServerHost, mockServerHostPort)); integrationConfig.setAddress(String.format("http://%s:%s", mockServerHost, mockServerHostPort));
Map<String, Object> integrationConfigMap = JSON.parseMap(JSON.toJSONString(integrationConfig)); Map<String, Object> integrationConfigMap = JSON.parseMap(JSON.toJSONString(integrationConfig));

View File

@ -1,5 +1,5 @@
-- 模拟数据 -- 模拟数据
INSERT INTO `service_integration`(`id`, `plugin_id`, `enable`, `configuration`, `organization_id`) VALUES ('1', '952262969139212', b'1', '1111', '100001'); INSERT INTO `service_integration`(`id`, `plugin_id`, `enable`, `configuration`, `organization_id`) VALUES ('1', 'jira', b'1', '1111', '100002');
-- 模拟用户 -- 模拟用户