From 693dc9bbd0a7f6d1cc0e82002859a81b75b99eec Mon Sep 17 00:00:00 2001 From: fit2-zhao Date: Wed, 4 Jan 2023 17:28:01 +0800 Subject: [PATCH] =?UTF-8?q?refactor(=E7=B3=BB=E7=BB=9F=E8=AE=BE=E7=BD=AE):?= =?UTF-8?q?=20=E4=BC=98=E5=8C=96=E6=8F=92=E4=BB=B6=E5=8A=A0=E8=BD=BD?= =?UTF-8?q?=E6=9C=BA=E5=88=B6?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../metersphere/service/ApiPluginService.java | 27 +++++++++++++++++-- 1 file changed, 25 insertions(+), 2 deletions(-) diff --git a/system-setting/backend/src/main/java/io/metersphere/service/ApiPluginService.java b/system-setting/backend/src/main/java/io/metersphere/service/ApiPluginService.java index 741951bb95..ba4198a350 100644 --- a/system-setting/backend/src/main/java/io/metersphere/service/ApiPluginService.java +++ b/system-setting/backend/src/main/java/io/metersphere/service/ApiPluginService.java @@ -11,10 +11,12 @@ import io.metersphere.commons.utils.FileUtils; import io.metersphere.commons.utils.LogUtil; import io.metersphere.commons.utils.SessionUtils; import io.metersphere.dto.PluginResourceDTO; +import io.metersphere.plugin.core.api.UiScriptApi; import io.metersphere.plugin.core.ui.PluginResource; import io.metersphere.utils.CommonUtil; import org.apache.commons.collections4.CollectionUtils; import org.apache.commons.lang3.StringUtils; +import org.apache.jorphan.reflect.ClassFinder; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import org.springframework.web.multipart.MultipartFile; @@ -84,7 +86,29 @@ public class ApiPluginService { private List getMethod(String path, String fileName) { List resources = new LinkedList<>(); - this.loadJar(path); + try { + this.loadJar(path); + String jarPath[] = new String[]{path}; + List classes = ClassFinder.findClassesThatExtend(jarPath, new Class[]{UiScriptApi.class}, true); + for (String clazzName : classes) { + UiScriptApi uiScriptApi = Class.forName(clazzName) + .asSubclass(UiScriptApi.class) + .getDeclaredConstructor().newInstance(); + PluginResource pluginObj = uiScriptApi.init(); + if (pluginObj != null) { + PluginResourceDTO pluginResourceDTO = new PluginResourceDTO(); + BeanUtils.copyBean(pluginResourceDTO, pluginObj); + pluginResourceDTO.setEntry(clazzName); + resources.add(pluginResourceDTO); + } + } + } catch (Exception e) { + this.init(fileName, resources); + } + return resources; + } + + private void init(String fileName, List resources) { List> classes = CommonUtil.getSubClass(fileName); try { for (Class aClass : classes) { @@ -101,7 +125,6 @@ public class ApiPluginService { LogUtil.error("初始化脚本异常:" + e.getMessage()); MSException.throwException("调用插件初始化脚本失败"); } - return resources; } private void create(PluginResourceDTO resource, String path, String name, List addPlugins) {