Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
浙江兰德纵横网络技术股份有限公司
o2oa
提交
24432380
o2oa
项目概览
浙江兰德纵横网络技术股份有限公司
/
o2oa
通知
332
Star
10
Fork
6
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
o2oa
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
24432380
编写于
3月 22, 2024
作者:
O
o2null
2
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
修复脚本执行中无法正常赋值对象.
上级
7ea8f323
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
50 addition
and
3 deletion
+50
-3
o2server/x_base_core_project/src/main/java/com/x/base/core/project/scripting/GraalvmScriptingFactory.java
.../base/core/project/scripting/GraalvmScriptingFactory.java
+21
-1
o2server/x_processplatform_core_entity/src/main/java/com/x/processplatform/core/entity/content/Data.java
.../java/com/x/processplatform/core/entity/content/Data.java
+7
-0
o2server/x_processplatform_core_entity/src/test/java/test/com/x/processplatform/core/entity/TestClient.java
...va/test/com/x/processplatform/core/entity/TestClient.java
+21
-0
o2server/x_processplatform_service_processing/src/main/java/com/x/processplatform/service/processing/Processing.java
.../com/x/processplatform/service/processing/Processing.java
+0
-1
o2server/x_processplatform_service_processing/src/main/java/com/x/processplatform/service/processing/processor/invoke/InvokeProcessor.java
.../service/processing/processor/invoke/InvokeProcessor.java
+1
-1
未找到文件。
o2server/x_base_core_project/src/main/java/com/x/base/core/project/scripting/GraalvmScriptingFactory.java
浏览文件 @
24432380
package
com.x.base.core.project.scripting
;
import
java.lang.reflect.InvocationTargetException
;
import
java.lang.reflect.Type
;
import
java.util.ArrayList
;
import
java.util.HashMap
;
import
java.util.HashSet
;
import
java.util.LinkedHashMap
;
import
java.util.List
;
import
java.util.Map
;
import
java.util.Map.Entry
;
import
java.util.Objects
;
import
java.util.Optional
;
...
...
@@ -16,6 +19,7 @@ import java.util.function.Function;
import
java.util.stream.Collectors
;
import
java.util.stream.Stream
;
import
org.apache.commons.beanutils.MethodUtils
;
import
org.apache.commons.lang3.BooleanUtils
;
import
org.apache.commons.lang3.StringUtils
;
import
org.graalvm.polyglot.Context
;
...
...
@@ -77,11 +81,27 @@ public class GraalvmScriptingFactory {
try
(
Context
context
=
Context
.
newBuilder
().
engine
(
ENGINE
).
allowHostClassLoading
(
true
)
.
allowHostAccess
(
HostAccess
.
ALL
).
allowHostClassLookup
(
GraalvmScriptingFactory:
:
allowClass
).
build
())
{
Value
bind
=
context
.
getBindings
(
LANGUAGE_ID_JS
);
Map
<
String
,
Class
<?>>
dataAssignDataEmbedDataClasses
=
new
HashMap
<>();
if
(
null
!=
bindings
)
{
dataAssignDataEmbedDataClasses
=
Stream
.
of
(
BINDING_NAME_EMBEDDATA
,
BINDING_NAME_DATA
)
.
filter
(
bindings:
:
containsKey
).
filter
(
o
->
Objects
.
nonNull
(
bindings
.
get
(
o
)))
.
collect
(
Collectors
.
toMap
(
Function
.
identity
(),
o
->
bindings
.
get
(
o
).
getClass
()));
bindings
.
entrySet
().
forEach
(
en
->
bind
.
putMember
(
en
.
getKey
(),
en
.
getValue
()));
}
context
.
eval
(
getcommonScriptSource
());
return
promise
(
context
,
context
.
eval
(
source
));
Value
value
=
context
.
eval
(
source
);
if
((
null
!=
bindings
)
&&
(!
dataAssignDataEmbedDataClasses
.
isEmpty
()))
{
dataAssignDataEmbedDataClasses
.
entrySet
().
forEach
(
o
->
{
Value
v
=
bind
.
getMember
(
o
.
getKey
().
substring
(
o
.
getKey
().
indexOf
(
"_"
)
+
1
));
try
{
MethodUtils
.
invokeExactMethod
(
bindings
.
get
(
o
.
getKey
()),
"replaceContent"
,
bind
.
getMember
(
"JSON"
).
invokeMember
(
"stringify"
,
v
).
asString
());
}
catch
(
NoSuchMethodException
|
IllegalAccessException
|
InvocationTargetException
e
)
{
LOGGER
.
error
(
e
);
}
});
}
return
promise
(
context
,
value
);
}
}
...
...
o2server/x_processplatform_core_entity/src/main/java/com/x/processplatform/core/entity/content/Data.java
浏览文件 @
24432380
...
...
@@ -4,6 +4,7 @@ import java.lang.reflect.InvocationTargetException;
import
java.util.ArrayList
;
import
java.util.Date
;
import
java.util.List
;
import
java.util.Map
;
import
java.util.Objects
;
import
org.apache.commons.beanutils.PropertyUtils
;
...
...
@@ -491,6 +492,12 @@ public class Data extends ListOrderedMap<String, Object> {
.
count
()
==
0
;
}
@SuppressWarnings
(
"unchecked"
)
public
void
replaceContent
(
String
json
)
{
this
.
clear
();
this
.
putAll
(
XGsonBuilder
.
instance
().
fromJson
(
json
,
Map
.
class
));
}
@Override
/* 需要重载,前端toString需要这个方法. */
public
String
toString
()
{
...
...
o2server/x_processplatform_core_entity/src/test/java/test/com/x/processplatform/core/entity/TestClient.java
0 → 100644
浏览文件 @
24432380
package
test.com.x.processplatform.core.entity
;
import
java.util.Arrays
;
import
com.x.base.core.project.gson.XGsonBuilder
;
import
com.x.processplatform.core.entity.content.Data
;
public
class
TestClient
{
public
static
void
main
(
String
[]
args
)
{
Data
data
=
new
Data
();
data
.
put
(
"a"
,
Arrays
.
asList
(
"bb"
,
"c"
));
System
.
out
.
println
(
XGsonBuilder
.
toJson
(
data
));
data
.
replaceContent
(
"{\"d\":\"aaa\"}"
);
System
.
out
.
println
(
XGsonBuilder
.
toJson
(
data
));
}
}
o2server/x_processplatform_service_processing/src/main/java/com/x/processplatform/service/processing/Processing.java
浏览文件 @
24432380
...
...
@@ -9,7 +9,6 @@ import org.apache.commons.lang3.StringUtils;
import
com.x.base.core.container.EntityManagerContainer
;
import
com.x.base.core.container.factory.EntityManagerContainerFactory
;
import
com.x.base.core.project.gson.XGsonBuilder
;
import
com.x.base.core.project.tools.ListTools
;
import
com.x.processplatform.core.entity.content.Work
;
import
com.x.processplatform.core.express.ProcessingAttributes
;
...
...
o2server/x_processplatform_service_processing/src/main/java/com/x/processplatform/service/processing/processor/invoke/InvokeProcessor.java
浏览文件 @
24432380
...
...
@@ -480,7 +480,7 @@ public class InvokeProcessor extends AbstractInvokeProcessor {
GraalvmScriptingFactory
.
Bindings
bindings
=
aeiObjects
.
bindings
()
.
putMember
(
GraalvmScriptingFactory
.
BINDING_NAME_JAXRSBODY
,
jaxrsBody
);
GraalvmScriptingFactory
.
eval
(
source
,
bindings
,
jsonElement
->
{
if
(
!
jsonElement
.
isJsonNull
(
))
{
if
(
Objects
.
nonNull
(
jsonElement
)
&&
(!
jsonElement
.
isJsonNull
()
))
{
jaxrsBody
.
set
(
gson
.
toJson
(
jsonElement
));
}
});
...
...
liyi_hz2008
@liyi_hz2008
mentioned in commit
3f5fbcd2
·
3月 22, 2024
mentioned in commit
3f5fbcd2
mentioned in commit 3f5fbcd2d0285468b5a10b4ce5408f3ba9561d9a
开关提交列表
NoSubject
@NoSubject
mentioned in commit
96e70387
·
3月 22, 2024
mentioned in commit
96e70387
mentioned in commit 96e70387cdd569cf174bd03a6a4eb65a013d81d6
开关提交列表
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录