From 9317385bd9356684f7eb790fa6e8b28be6a3550a Mon Sep 17 00:00:00 2001 From: CaiHQ Date: Tue, 8 Nov 2022 17:37:53 +0800 Subject: [PATCH] add auto type convert in ArgSchema --- build.gradle | 10 +++++----- .../org/bdware/sc/boundry/JavaScriptEntry.java | 4 +--- .../sc/boundry/ScriptReturnException.java | 15 +++------------ .../org/bdware/sc/engine/DesktopEngine.java | 9 ++++++++- .../bdware/sc/engine/hook/ArgSchemaHandler.java | 17 ++++++++++++++--- .../bdware/sc/engine/hook/ObjToJsonHandler.java | 4 ---- src/main/resources/log4j2.properties | 4 ++-- 7 files changed, 33 insertions(+), 30 deletions(-) diff --git a/build.gradle b/build.gradle index ac96fec..f8c490a 100644 --- a/build.gradle +++ b/build.gradle @@ -6,7 +6,7 @@ plugins { } group = "org.bdware.sc" -version = "1.6.7" +version = "1.6.91" repositories { mavenCentral() mavenLocal() @@ -42,8 +42,8 @@ dependencies { implementation 'org.jsoup:jsoup:1.14.2' implementation 'com.sun.mail:javax.mail:1.6.2' implementation 'com.squareup.okhttp3:okhttp:4.9.1' - implementation 'org.bdware.bdcontract:sdk-java:1.0.0' - implementation 'org.bdware.doip:doip-audit-tool:1.0.8' + implementation 'org.bdware.bdcontract:sdk-java:1.0.2' + implementation 'org.bdware.doip:doip-audit-tool:1.1.3' implementation fileTree(dir: 'lib', include: '*.jar') testImplementation 'junit:junit:4.13.2' } @@ -61,8 +61,8 @@ jar { // uncomment this when publish, //while develop at local use "false" configurations.runtimeClasspath.filter { - it.getAbsolutePath().contains("/lib/") - // false + // it.getAbsolutePath().contains("/lib/") + false }.collect { it.isDirectory() ? it : zipTree(it) } diff --git a/src/main/java/org/bdware/sc/boundry/JavaScriptEntry.java b/src/main/java/org/bdware/sc/boundry/JavaScriptEntry.java index dafa882..a3f5159 100644 --- a/src/main/java/org/bdware/sc/boundry/JavaScriptEntry.java +++ b/src/main/java/org/bdware/sc/boundry/JavaScriptEntry.java @@ -1,7 +1,6 @@ package org.bdware.sc.boundry; import com.google.gson.JsonObject; -import groovy.util.ScriptException; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.bdware.sc.ContractProcess; @@ -19,7 +18,6 @@ import org.bdware.sc.util.HashUtil; import org.bdware.sc.util.JsonUtil; import org.zz.gmhelper.SM2KeyPair; import wrp.jdk.nashorn.api.scripting.NashornScriptEngine; -import wrp.jdk.nashorn.api.scripting.ScriptObjectMirror; import wrp.jdk.nashorn.internal.objects.Global; import wrp.jdk.nashorn.internal.runtime.PropertyMap; import wrp.jdk.nashorn.internal.runtime.ScriptFunction; @@ -391,10 +389,10 @@ public class JavaScriptEntry { * @author Kaidong Wu */ public static String subscribe(String topic, ScriptFunction fun) { - subscribe(topic, fun, false); if (topic_handlers.containsKey(topic)) { ContractProcess.instance.unSubscribe(topic_handlers.get(topic).getName()); } + subscribe(topic, fun, false); topic_handlers.put(topic, fun); return topic; } diff --git a/src/main/java/org/bdware/sc/boundry/ScriptReturnException.java b/src/main/java/org/bdware/sc/boundry/ScriptReturnException.java index 2fddbf2..8ac97fe 100644 --- a/src/main/java/org/bdware/sc/boundry/ScriptReturnException.java +++ b/src/main/java/org/bdware/sc/boundry/ScriptReturnException.java @@ -4,18 +4,9 @@ import com.google.gson.JsonElement; import com.google.gson.JsonObject; public class ScriptReturnException extends IllegalStateException { -// public String message1; -// public int code; public JsonObject message; - public ScriptReturnException(JsonElement jsonElement) { - message=jsonElement.getAsJsonObject(); -// message=jo.get("msg").getAsString(); -// code=jo.get("code").getAsInt(); - } -// @Override -// public String getMessage() { -// return this.message1; -// -// } + public ScriptReturnException(JsonElement jsonElement) { + message = jsonElement.getAsJsonObject(); + } } diff --git a/src/main/java/org/bdware/sc/engine/DesktopEngine.java b/src/main/java/org/bdware/sc/engine/DesktopEngine.java index 5a8ff55..49f067d 100644 --- a/src/main/java/org/bdware/sc/engine/DesktopEngine.java +++ b/src/main/java/org/bdware/sc/engine/DesktopEngine.java @@ -271,7 +271,6 @@ public class DesktopEngine extends JSEngine { ScriptEngine.FILENAME, fun.getFileName(), ScriptContext.ENGINE_SCOPE); - LOGGER.info("loadFun:" + str); compileFunction(fun, str, isInsnLimit); } catch (ScriptException e) { return wrapperException(e, fun); @@ -427,7 +426,14 @@ public class DesktopEngine extends JSEngine { Method getGeneric = ScriptFunctionData.class.getDeclaredMethod("getGenericInvoker", ScriptObject.class); getGeneric.setAccessible(true); MethodHandle methodHandle = (MethodHandle) getGeneric.invoke(scriptFunctioNData, scope); + if (methodHandle.getClass() != Class.forName("java.lang.invoke.DirectMethodHandle")) { + Field argL0 = methodHandle.getClass().getDeclaredField("argL0"); + argL0.setAccessible(true); + methodHandle = (MethodHandle) argL0.get(methodHandle); + + } Field memberNameField = methodHandle.getClass().getDeclaredField("member"); + memberNameField.setAccessible(true); Object memberName = memberNameField.get(methodHandle); Field clazz = memberName.getClass().getDeclaredField("clazz"); @@ -437,6 +443,7 @@ public class DesktopEngine extends JSEngine { functionNode.compiledClazz = clazz2; //functionNode==null --> event functions } catch (Exception e) { + e.printStackTrace(); } finally { if (globalChanged) Context.setGlobal(oldGlobal); diff --git a/src/main/java/org/bdware/sc/engine/hook/ArgSchemaHandler.java b/src/main/java/org/bdware/sc/engine/hook/ArgSchemaHandler.java index ce40c43..868f54b 100644 --- a/src/main/java/org/bdware/sc/engine/hook/ArgSchemaHandler.java +++ b/src/main/java/org/bdware/sc/engine/hook/ArgSchemaHandler.java @@ -20,7 +20,6 @@ public class ArgSchemaHandler implements AnnotationHook { public ArgSchemaHandler(AnnotationNode annoNode) { a = annoNode; String arg = a.getArgs().get(0); - // if (arg.startsWith("/")){ // ;//ContractProcess.instance.engine.getResources().loadAsString(arg); // }else { @@ -39,8 +38,20 @@ public class ArgSchemaHandler implements AnnotationHook { ArgSchemaVisitor visitor; if (je.isJsonObject()) visitor = new ArgSchemaVisitor(input.getArg().getAsJsonObject()); - else - visitor = new ArgSchemaVisitor(JsonParser.parseString(input.getArg().getAsString())); + else { + try { + JsonElement obj = JsonParser.parseString(input.getArg().getAsString()); + visitor = new ArgSchemaVisitor(obj); + //IMPORTANT automatically convert arg type here + input.setArg(obj); + } catch (Exception e) { + e.printStackTrace(); + JsonObject jo = new JsonObject(); + jo.addProperty("msg", "[Illegal Type] argument should be JSON"); + jo.addProperty("code", 1004); + throw new ScriptReturnException(jo); + } + } if (je.toString().isEmpty() && !a.getArgs().get(0).equals("")) { JsonObject jo = new JsonObject(); jo.addProperty("msg", "[Empty argument] argument should not be empty"); diff --git a/src/main/java/org/bdware/sc/engine/hook/ObjToJsonHandler.java b/src/main/java/org/bdware/sc/engine/hook/ObjToJsonHandler.java index c1af666..aac3341 100644 --- a/src/main/java/org/bdware/sc/engine/hook/ObjToJsonHandler.java +++ b/src/main/java/org/bdware/sc/engine/hook/ObjToJsonHandler.java @@ -1,13 +1,9 @@ package org.bdware.sc.engine.hook; -import com.google.gson.JsonElement; -import com.google.gson.JsonNull; -import com.google.gson.JsonPrimitive; import org.bdware.sc.JSEngine; import org.bdware.sc.bean.ContractRequest; import org.bdware.sc.engine.JSONTool; import org.bdware.sc.node.AnnotationHook; -import wrp.jdk.nashorn.api.scripting.ScriptObjectMirror; public class ObjToJsonHandler implements AnnotationHook { @Override diff --git a/src/main/resources/log4j2.properties b/src/main/resources/log4j2.properties index e129d9d..559088e 100644 --- a/src/main/resources/log4j2.properties +++ b/src/main/resources/log4j2.properties @@ -5,6 +5,6 @@ appender.console.name=STDOUT appender.console.layout.type=PatternLayout appender.console.layout.pattern=%highlight{[%-5p] %d{HH:mm:ss.SSS} %m (%F:%L)[%M]%n}{FATAL=Bright Red,ERROR=Red,WARN=Yellow,INFO=Green,DEBUG=Blue,TRACE=White} -rootLogger.level=error +rootLogger.level=info rootLogger.appenderRef.stdout.ref=STDOUT -rootLogger.appenderRef.stdout.level=error +rootLogger.appenderRef.stdout.level=info