Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
提交反馈
为 GitLab 提交贡献
登录
切换导航
I
ibzwf
项目
项目
详情
动态
版本
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
ibiz4jteam
ibzwf
提交
4968039a
提交
4968039a
编写于
11月 18, 2022
作者:
zhouweidong
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
1.审批日志接口增加historyTask与waitTask节点,返回已办与待办任务信息。
2.审批日志展示辅助功能操作记录。 3.修复辅助功能名称显示问题。 4.流程实例查询支持快速搜索。
上级
2abaeb3b
变更
3
隐藏空白字符变更
内嵌
并排
正在显示
3 个修改的文件
包含
210 行增加
和
52 行删除
+210
-52
WFProcessInstanceExService.java
...b/core/extensions/service/WFProcessInstanceExService.java
+25
-4
WFCoreService.java
...izlab/core/workflow/extensions/service/WFCoreService.java
+154
-35
WFCoreResource.java
...n/java/cn/ibizlab/api/rest/extensions/WFCoreResource.java
+31
-13
未找到文件。
ibzwf-core/src/main/java/cn/ibizlab/core/extensions/service/WFProcessInstanceExService.java
浏览文件 @
4968039a
...
@@ -31,9 +31,6 @@ public class WFProcessInstanceExService extends WFProcessInstanceServiceImpl {
...
@@ -31,9 +31,6 @@ public class WFProcessInstanceExService extends WFProcessInstanceServiceImpl {
@Autowired
@Autowired
WFCoreService
wfCoreService
;
WFCoreService
wfCoreService
;
@Autowired
private
RuntimeService
runtimeService
;
/**
/**
* [Jump:流程跳转] 行为扩展
* [Jump:流程跳转] 行为扩展
* @param et
* @param et
...
@@ -48,6 +45,30 @@ public class WFProcessInstanceExService extends WFProcessInstanceServiceImpl {
...
@@ -48,6 +45,30 @@ public class WFProcessInstanceExService extends WFProcessInstanceServiceImpl {
throw
new
BadRequestException
(
"未传入流程步骤用户"
);
throw
new
BadRequestException
(
"未传入流程步骤用户"
);
}
}
String
strSystemId
=
null
;
String
strEntityId
=
null
;
String
strBusinessKey
=
null
;
String
strProcessInstanceBusinessKey
=
et
.
getBusinesskey
();
if
(
StringUtils
.
isEmpty
(
strProcessInstanceBusinessKey
)){
throw
new
BadRequestException
(
"未传入业务标识"
);
}
if
(
strProcessInstanceBusinessKey
.
contains
(
":"
)){
String
[]
arrays
=
strProcessInstanceBusinessKey
.
split
(
":"
);
if
(
arrays
.
length
==
3
){
strSystemId
=
arrays
[
0
];
strEntityId
=
arrays
[
1
];
strBusinessKey
=
arrays
[
2
];
if
(
strBusinessKey
.
indexOf
(
":k-"
)>
0
)
strBusinessKey
=
strBusinessKey
.
split
(
":k-"
)[
1
];
}
}
if
(
StringUtils
.
isEmpty
(
strSystemId
)
||
StringUtils
.
isEmpty
(
strEntityId
)
||
StringUtils
.
isEmpty
(
strBusinessKey
)){
throw
new
BadRequestException
(
"未传入流程参数失败"
);
}
//参数格式转换
//参数格式转换
Set
<
String
>
userSets
=
new
LinkedHashSet
();
Set
<
String
>
userSets
=
new
LinkedHashSet
();
JSONArray
.
parseArray
(
users
.
toString
()).
forEach
(
item
->
{
JSONArray
.
parseArray
(
users
.
toString
()).
forEach
(
item
->
{
...
@@ -59,7 +80,7 @@ public class WFProcessInstanceExService extends WFProcessInstanceServiceImpl {
...
@@ -59,7 +80,7 @@ public class WFProcessInstanceExService extends WFProcessInstanceServiceImpl {
});
});
et
.
set
(
"wfusers"
,
String
.
join
(
","
,
userSets
));
et
.
set
(
"wfusers"
,
String
.
join
(
","
,
userSets
));
wfCoreService
.
jump
(
et
);
wfCoreService
.
jump
(
strSystemId
,
strEntityId
,
strBusinessKey
,
et
);
return
et
;
return
et
;
}
}
...
...
ibzwf-core/src/main/java/cn/ibizlab/core/workflow/extensions/service/WFCoreService.java
浏览文件 @
4968039a
...
@@ -35,6 +35,8 @@ import org.flowable.engine.delegate.DelegateExecution;
...
@@ -35,6 +35,8 @@ import org.flowable.engine.delegate.DelegateExecution;
import
org.flowable.engine.history.HistoricActivityInstance
;
import
org.flowable.engine.history.HistoricActivityInstance
;
import
org.flowable.engine.history.HistoricProcessInstance
;
import
org.flowable.engine.history.HistoricProcessInstance
;
import
org.flowable.engine.history.ProcessInstanceHistoryLog
;
import
org.flowable.engine.history.ProcessInstanceHistoryLog
;
import
org.flowable.engine.impl.persistence.entity.CommentEntity
;
import
org.flowable.engine.impl.persistence.entity.CommentEntityImpl
;
import
org.flowable.engine.repository.Deployment
;
import
org.flowable.engine.repository.Deployment
;
import
org.flowable.engine.repository.DeploymentBuilder
;
import
org.flowable.engine.repository.DeploymentBuilder
;
import
org.flowable.engine.repository.ProcessDefinition
;
import
org.flowable.engine.repository.ProcessDefinition
;
...
@@ -365,10 +367,24 @@ public class WFCoreService
...
@@ -365,10 +367,24 @@ public class WFCoreService
return
new
PageImpl
<
WFTask
>(
pages
.
getRecords
(),
context
.
getPageable
(),
pages
.
getTotal
());
return
new
PageImpl
<
WFTask
>(
pages
.
getRecords
(),
context
.
getPageable
(),
pages
.
getTotal
());
}
}
/**
* 查询已激活的流程实例(流程实例)
* @param context
* @return
*/
public
Page
<
WFProcessInstance
>
searchActiveInstance
(
WFProcessInstanceSearchContext
context
){
public
Page
<
WFProcessInstance
>
searchActiveInstance
(
WFProcessInstanceSearchContext
context
){
//构造快速搜索查询条件
QueryWrapper
<
WFProcessInstance
>
queryWrapper
=
new
QueryWrapper
();
String
strQuery
=
context
.
getQuery
();
if
(!
StringUtils
.
isEmpty
(
strQuery
)){
if
(!
StringUtils
.
isEmpty
(
strQuery
)){
queryWrapper
.
and
(
wrapper
->
wrapper
.
like
(
"processDefinitionName"
,
strQuery
).
or
().
like
(
"businessKey"
,
strQuery
).
or
().
like
(
"startUserId"
,
strQuery
));
}
}
com
.
baomidou
.
mybatisplus
.
extension
.
plugins
.
pagination
.
Page
page
=
new
com
.
baomidou
.
mybatisplus
.
extension
.
plugins
.
pagination
.
Page
(
context
.
getPageable
().
getPageNumber
()+
1
,
context
.
getPageable
().
getPageSize
());
com
.
baomidou
.
mybatisplus
.
extension
.
plugins
.
pagination
.
Page
page
=
new
com
.
baomidou
.
mybatisplus
.
extension
.
plugins
.
pagination
.
Page
(
context
.
getPageable
().
getPageNumber
()+
1
,
context
.
getPageable
().
getPageSize
());
com
.
baomidou
.
mybatisplus
.
extension
.
plugins
.
pagination
.
Page
<
WFProcessInstance
>
pages
=
wfCoreMapper
.
searchActiveInstance
(
page
,
context
,
new
QueryWrapper
<>()
);
com
.
baomidou
.
mybatisplus
.
extension
.
plugins
.
pagination
.
Page
<
WFProcessInstance
>
pages
=
wfCoreMapper
.
searchActiveInstance
(
page
,
context
,
queryWrapper
);
return
new
PageImpl
<
WFProcessInstance
>(
pages
.
getRecords
(),
context
.
getPageable
(),
pages
.
getTotal
());
return
new
PageImpl
<
WFProcessInstance
>(
pages
.
getRecords
(),
context
.
getPageable
(),
pages
.
getTotal
());
}
}
...
@@ -781,7 +797,7 @@ public class WFCoreService
...
@@ -781,7 +797,7 @@ public class WFCoreService
if
(
userTaskParams
.
containsKey
(
webFormName
)){
if
(
userTaskParams
.
containsKey
(
webFormName
)){
way
.
set
(
"sequenceFlowFormName"
,
userTaskParams
.
get
(
webFormName
));
way
.
set
(
"sequenceFlowFormName"
,
userTaskParams
.
get
(
webFormName
));
way
.
setSequenceflowname
(
webFormName
);
way
.
setSequenceflowname
(
userTaskParams
.
get
(
webFormName
)
);
}
}
if
(
userTaskParams
.
containsKey
(
mobFormId
))
if
(
userTaskParams
.
containsKey
(
mobFormId
))
...
@@ -789,7 +805,7 @@ public class WFCoreService
...
@@ -789,7 +805,7 @@ public class WFCoreService
if
(
userTaskParams
.
containsKey
(
mobFormName
))
{
if
(
userTaskParams
.
containsKey
(
mobFormName
))
{
way
.
set
(
"sequenceFlowMobFormName"
,
userTaskParams
.
get
(
mobFormName
));
way
.
set
(
"sequenceFlowMobFormName"
,
userTaskParams
.
get
(
mobFormName
));
way
.
setSequenceflowname
(
mobFormName
);
way
.
setSequenceflowname
(
userTaskParams
.
get
(
mobFormName
)
);
}
}
}
}
}
}
...
@@ -913,7 +929,7 @@ public class WFCoreService
...
@@ -913,7 +929,7 @@ public class WFCoreService
if
(
curTask
!=
null
&&
DelegationState
.
PENDING
==
curTask
.
getDelegationState
())
{
if
(
curTask
!=
null
&&
DelegationState
.
PENDING
==
curTask
.
getDelegationState
())
{
if
(
userId
.
equals
(
curTask
.
getAssignee
())){
if
(
userId
.
equals
(
curTask
.
getAssignee
())){
taskService
.
resolveTask
(
taskId
);
taskService
.
resolveTask
(
taskId
);
//saveTask(curTask
);
createHistoryRecord
(
ProcFunction
.
FINISH
,
curTask
,
activedata
);
}
}
else
{
else
{
throw
new
BadRequestAlertException
(
"当前任务正在加签中"
,
""
,
""
);
throw
new
BadRequestAlertException
(
"当前任务正在加签中"
,
""
,
""
);
...
@@ -968,6 +984,8 @@ public class WFCoreService
...
@@ -968,6 +984,8 @@ public class WFCoreService
}
}
}
}
List
<
WFHistory
>
historyTasks
=
new
ArrayList
<>();
List
<
WFUser
>
waitTasks
=
new
ArrayList
<>();
List
<
Comment
>
comments
=
new
ArrayList
<>();
List
<
Comment
>
comments
=
new
ArrayList
<>();
Map
<
String
,
HistoricTaskInstanceEntity
>
tasks
=
new
LinkedHashMap
<>();
Map
<
String
,
HistoricTaskInstanceEntity
>
tasks
=
new
LinkedHashMap
<>();
...
@@ -999,6 +1017,17 @@ public class WFCoreService
...
@@ -999,6 +1017,17 @@ public class WFCoreService
for
(
HistoricData
data
:
historicData
){
for
(
HistoricData
data
:
historicData
){
if
(
data
instanceof
HistoricActivityInstance
){
if
(
data
instanceof
HistoricActivityInstance
){
HistoricActivityInstance
hai
=
(
HistoricActivityInstance
)
data
;
HistoricActivityInstance
hai
=
(
HistoricActivityInstance
)
data
;
//启动流程记录
if
(
hai
.
getActivityType
().
equals
(
"startEvent"
)){
CommentEntity
comment
=
new
CommentEntityImpl
();
comment
.
setId
(
hai
.
getId
());
comment
.
setType
(
"启动流程"
);
comment
.
setFullMessage
(
hai
.
getActivityName
());
comment
.
setTime
(
hai
.
getTime
());
comment
.
setUserId
(
processInstanceHistoryLog
.
getStartUserId
());
comments
.
add
(
comment
);
continue
;
}
if
(!
hai
.
getActivityType
().
equals
(
"userTask"
))
if
(!
hai
.
getActivityType
().
equals
(
"userTask"
))
continue
;
continue
;
if
(!
nodes
.
containsKey
(
hai
.
getActivityId
()))
if
(!
nodes
.
containsKey
(
hai
.
getActivityId
()))
...
@@ -1042,6 +1071,10 @@ public class WFCoreService
...
@@ -1042,6 +1071,10 @@ public class WFCoreService
user
.
setId
(
idlink
.
getUserId
());
user
.
setId
(
idlink
.
getUserId
());
wfUserMap
.
put
(
idlink
.
getUserId
(),
user
);
wfUserMap
.
put
(
idlink
.
getUserId
(),
user
);
((
ArrayList
)
nodes
.
get
(
tasks
.
get
(
taskid
).
getTaskDefinitionKey
()).
get
(
"identityLinks"
)).
add
(
user
);
((
ArrayList
)
nodes
.
get
(
tasks
.
get
(
taskid
).
getTaskDefinitionKey
()).
get
(
"identityLinks"
)).
add
(
user
);
user
.
set
(
"userTaskId"
,
tasks
.
get
(
taskid
).
getTaskDefinitionKey
());
user
.
set
(
"userTaskName"
,
tasks
.
get
(
taskid
).
getName
());
waitTasks
.
add
(
user
);
}
}
}
}
}
}
...
@@ -1053,6 +1086,20 @@ public class WFCoreService
...
@@ -1053,6 +1086,20 @@ public class WFCoreService
for
(
Comment
comment:
comments
)
for
(
Comment
comment:
comments
)
{
{
if
(!
StringUtils
.
isEmpty
(
comment
.
getType
())
&&
"启动流程"
.
equals
(
comment
.
getType
())){
String
userId
=
comment
.
getUserId
();
String
userName
=
!
StringUtils
.
isEmpty
(
userId
)
?
wfUserMap
.
get
(
comment
.
getUserId
()).
getDisplayname
()
:
"未知用户"
;
WFHistory
history
=
new
WFHistory
();
history
.
setId
(
comment
.
getId
());
history
.
setAuthor
(
userId
);
history
.
setAuthorname
(
userName
);
history
.
setTime
(
new
Timestamp
(
comment
.
getTime
().
getTime
()));
history
.
setType
(
comment
.
getType
());
history
.
set
(
"userTaskId"
,
comment
.
getId
());
history
.
set
(
"userTaskName"
,
comment
.
getFullMessage
());
historyTasks
.
add
(
history
);
continue
;
}
if
(
tasks
.
containsKey
(
comment
.
getTaskId
())&&(
nodes
.
containsKey
(
tasks
.
get
(
comment
.
getTaskId
()).
getTaskDefinitionKey
())))
{
if
(
tasks
.
containsKey
(
comment
.
getTaskId
())&&(
nodes
.
containsKey
(
tasks
.
get
(
comment
.
getTaskId
()).
getTaskDefinitionKey
())))
{
if
(
wfUserMap
.
containsKey
(
comment
.
getUserId
()))
{
if
(
wfUserMap
.
containsKey
(
comment
.
getUserId
()))
{
WFHistory
history
=
new
WFHistory
();
WFHistory
history
=
new
WFHistory
();
...
@@ -1066,16 +1113,26 @@ public class WFCoreService
...
@@ -1066,16 +1113,26 @@ public class WFCoreService
//history.setProcessinstanceid(comment.getProcessInstanceId());
//history.setProcessinstanceid(comment.getProcessInstanceId());
//history.setProcessinstancebusinesskey(businessKey);
//history.setProcessinstancebusinesskey(businessKey);
((
ArrayList
)
nodes
.
get
(
tasks
.
get
(
comment
.
getTaskId
()).
getTaskDefinitionKey
()).
get
(
"comments"
)).
add
(
history
);
((
ArrayList
)
nodes
.
get
(
tasks
.
get
(
comment
.
getTaskId
()).
getTaskDefinitionKey
()).
get
(
"comments"
)).
add
(
history
);
history
.
set
(
"userTaskId"
,
tasks
.
get
(
comment
.
getTaskId
()).
getTaskDefinitionKey
());
history
.
set
(
"userTaskName"
,
tasks
.
get
(
comment
.
getTaskId
()).
getName
());
historyTasks
.
add
(
history
);
}
}
}
}
}
}
if
(!
StringUtils
.
isEmpty
(
processInstanceId
)){
wfProcessInstance
.
set
(
"userTasks"
,
filterTaskMap
(
nodes
,
processInstanceId
));
//过滤空节点
}
else
{
Map
<
String
,
WFProcessNode
>
nodes2
=
new
LinkedHashMap
<>();
for
(
String
id
:
processInstanceIds
)
{
for
(
Map
.
Entry
<
String
,
WFProcessNode
>
entry
:
nodes
.
entrySet
()){
wfProcessInstance
.
set
(
"userTasks"
,
filterTaskMap
(
nodes
,
id
));
String
nodeId
=
entry
.
getKey
();
}
WFProcessNode
processNode
=
entry
.
getValue
();
if
(!
ObjectUtils
.
isEmpty
(
processNode
.
get
(
"identityLinks"
))
||
!
ObjectUtils
.
isEmpty
(
processNode
.
get
(
"comments"
)))
nodes2
.
put
(
nodeId
,
processNode
);
}
}
wfProcessInstance
.
set
(
"userTasks"
,
nodes2
.
values
());
wfProcessInstance
.
set
(
"historyTasks"
,
historyTasks
);
wfProcessInstance
.
set
(
"waitTasks"
,
waitTasks
);
if
(!
StringUtils
.
isEmpty
(
wfProcessInstance
.
getStartuserid
()))
if
(!
StringUtils
.
isEmpty
(
wfProcessInstance
.
getStartuserid
()))
{
{
wfProcessInstance
.
setStartusername
(
wfUserMap
.
get
(
wfProcessInstance
.
getStartuserid
()).
getDisplayname
());
wfProcessInstance
.
setStartusername
(
wfUserMap
.
get
(
wfProcessInstance
.
getStartuserid
()).
getDisplayname
());
...
@@ -1720,8 +1777,9 @@ public class WFCoreService
...
@@ -1720,8 +1777,9 @@ public class WFCoreService
* @param taskId
* @param taskId
* @param taskWay
* @param taskWay
*/
*/
public
boolean
beforeSign
(
String
system
,
String
appname
,
public
boolean
beforeSign
(
String
system
,
String
appname
,
String
entity
,
String
businessKey
,
WFTaskWay
taskWay
)
{
String
entity
,
String
businessKey
,
String
taskId
,
WFTaskWay
taskWay
)
{
String
taskId
=
taskWay
.
getTaskid
();
String
userId
=
AuthenticationUser
.
getAuthenticationUser
().
getUserid
();
String
userId
=
AuthenticationUser
.
getAuthenticationUser
().
getUserid
();
if
(
StringUtils
.
isEmpty
(
userId
))
if
(
StringUtils
.
isEmpty
(
userId
))
throw
new
BadRequestAlertException
(
"未传入当前用户"
,
entity
,
businessKey
);
throw
new
BadRequestAlertException
(
"未传入当前用户"
,
entity
,
businessKey
);
...
@@ -1740,8 +1798,12 @@ public class WFCoreService
...
@@ -1740,8 +1798,12 @@ public class WFCoreService
throw
new
BadRequestAlertException
(
String
.
format
(
"未能获取到[%s]运行任务"
,
curTask
.
getId
()),
""
,
""
);
throw
new
BadRequestAlertException
(
String
.
format
(
"未能获取到[%s]运行任务"
,
curTask
.
getId
()),
""
,
""
);
}
}
if
(
DelegationState
.
PENDING
!=
curTask
.
getDelegationState
())
{
if
(
DelegationState
.
PENDING
!=
curTask
.
getDelegationState
())
{
taskService
.
delegateTask
(
taskId
,
String
.
valueOf
(
signUser
));
taskService
.
delegateTask
(
taskId
,
String
.
valueOf
(
signUser
));
//saveTask(curTask);
//记录辅助功能操作记录
activedata
.
put
(
"sequenceflowname"
,
taskWay
.
getSequenceflowname
());
createHistoryRecord
(
ProcFunction
.
ADDSTEPBEFORE
,
curTask
,
activedata
);
}
else
{
}
else
{
throw
new
BadRequestAlertException
(
String
.
format
(
"任务正在加签中,无法进行二次加签"
,
curTask
.
getId
()),
""
,
""
);
throw
new
BadRequestAlertException
(
String
.
format
(
"任务正在加签中,无法进行二次加签"
,
curTask
.
getId
()),
""
,
""
);
}
}
...
@@ -1749,16 +1811,17 @@ public class WFCoreService
...
@@ -1749,16 +1811,17 @@ public class WFCoreService
}
}
/**
/**
*
后加签 (转办)
*
转办
* @param system
* @param system
* @param appname
* @param appname
* @param entity
* @param entity
* @param businessKey
* @param businessKey
* @param taskId
* @param taskWay
* @param taskWay
* @return
*/
*/
public
boolean
reassign
(
String
system
,
String
appname
,
public
boolean
reassign
(
String
system
,
String
appname
,
String
entity
,
String
businessKey
,
WFTaskWay
taskWay
){
String
entity
,
String
businessKey
,
String
taskId
,
WFTaskWay
taskWay
){
String
taskId
=
taskWay
.
getTaskid
();
String
userId
=
AuthenticationUser
.
getAuthenticationUser
().
getUserid
();
String
userId
=
AuthenticationUser
.
getAuthenticationUser
().
getUserid
();
if
(
StringUtils
.
isEmpty
(
userId
))
if
(
StringUtils
.
isEmpty
(
userId
))
throw
new
BadRequestAlertException
(
"未传入当前用户"
,
entity
,
businessKey
);
throw
new
BadRequestAlertException
(
"未传入当前用户"
,
entity
,
businessKey
);
...
@@ -1780,10 +1843,39 @@ public class WFCoreService
...
@@ -1780,10 +1843,39 @@ public class WFCoreService
taskService
.
deleteUserIdentityLink
(
curTask
.
getId
(),
userId
,
"candidate"
);
taskService
.
deleteUserIdentityLink
(
curTask
.
getId
(),
userId
,
"candidate"
);
taskService
.
addUserIdentityLink
(
curTask
.
getId
(),
(
String
)
signUser
,
"candidate"
);
taskService
.
addUserIdentityLink
(
curTask
.
getId
(),
(
String
)
signUser
,
"candidate"
);
//saveTask(curTask);
//记录辅助功能操作记录
activedata
.
put
(
"sequenceflowname"
,
taskWay
.
getSequenceflowname
());
createHistoryRecord
(
ProcFunction
.
REASSIGN
,
curTask
,
activedata
);
return
true
;
return
true
;
}
}
/**
* 存储辅助功能操作记录
* @param procFunction
* @param task
* @param activeData
*/
protected
void
createHistoryRecord
(
ProcFunction
procFunction
,
Task
task
,
Map
activeData
)
{
//用户身份
if
(
StringUtils
.
isEmpty
(
Authentication
.
getAuthenticatedUserId
())){
String
userId
=
AuthenticationUser
.
getAuthenticationUser
().
getUserid
();
Authentication
.
setAuthenticatedUserId
(
userId
);
Authentication
.
setAuthenticationContext
(
createAuthenticationContext
());
}
//优先使用界面的交互连接名称与审批意见
String
strSequenceFlowName
=
getStringValue
(
activeData
.
get
(
"sequenceflowname"
));
String
srfwfmemo
=
getStringValue
(
activeData
.
get
(
"wfmemo"
));
String
strType
=
!
StringUtils
.
isEmpty
(
strSequenceFlowName
)
?
strSequenceFlowName:
procFunction
.
text
;
String
strMessage
=
!
StringUtils
.
isEmpty
(
srfwfmemo
)?
srfwfmemo
:
""
;
//转办记录
taskService
.
addComment
(
task
.
getId
(),
task
.
getProcessInstanceId
(),
strType
,
strMessage
);
}
private
ByteArrayOutputStream
getBpmnFile
(
InputStream
input
)
{
private
ByteArrayOutputStream
getBpmnFile
(
InputStream
input
)
{
try
{
try
{
ByteArrayOutputStream
baos
=
new
ByteArrayOutputStream
();
ByteArrayOutputStream
baos
=
new
ByteArrayOutputStream
();
...
@@ -2220,31 +2312,45 @@ public class WFCoreService
...
@@ -2220,31 +2312,45 @@ public class WFCoreService
* @param taskId 当前需要回退的节点
* @param taskId 当前需要回退的节点
* @return 回退上一个节点
* @return 回退上一个节点
*/
*/
public
boolean
sendBack
(
String
taskId
)
{
public
boolean
sendBack
(
String
system
,
String
appname
,
String
entity
,
String
businessKey
,
String
taskId
,
WFTaskWay
taskWay
)
{
Task
task
=
taskService
.
createTaskQuery
().
taskId
(
taskId
).
singleResult
();
Task
task
=
taskService
.
createTaskQuery
().
taskId
(
taskId
).
singleResult
();
String
taskDefinitionKey
=
task
.
getTaskDefinitionKey
();
String
taskDefinitionKey
=
task
.
getTaskDefinitionKey
();
if
(
taskDefinitionKey
==
null
)
{
if
(
taskDefinitionKey
==
null
)
{
log
.
debug
(
"taskDefinitionKey不存在"
);
throw
new
BadRequestException
(
"taskDefinitionKey不存在"
);
return
false
;
}
}
String
processInstanceId
=
task
.
getProcessInstanceId
();
String
processInstanceId
=
task
.
getProcessInstanceId
();
if
(
processInstanceId
==
null
)
{
if
(
processInstanceId
==
null
)
{
log
.
debug
(
"processInstanceId不存在"
);
throw
new
BadRequestException
(
"processInstanceId不存在"
);
return
false
;
}
}
List
<
HistoricTaskInstance
>
history
=
historyService
.
createHistoricTaskInstanceQuery
()
List
<
HistoricTaskInstance
>
history
=
historyService
.
createHistoricTaskInstanceQuery
()
.
processInstanceId
(
processInstanceId
)
.
processInstanceId
(
processInstanceId
)
.
orderByHistoricTaskInstanceEndTime
()
.
orderByHistoricTaskInstanceEndTime
()
.
desc
()
.
desc
()
.
list
();
.
list
();
if
(
history
.
size
()
>
0
){
HistoricTaskInstance
sourceRef
=
history
.
get
(
0
);
if
(
ObjectUtils
.
isEmpty
(
history
)){
// 执行回退
throw
new
BadRequestException
(
String
.
format
(
"未找到实例[%1$s]历史任务"
,
processInstanceId
));
runtimeService
.
createChangeActivityStateBuilder
()
.
processInstanceId
(
processInstanceId
)
.
moveActivityIdTo
(
taskDefinitionKey
,
sourceRef
.
getTaskDefinitionKey
())
.
changeState
();
}
}
Map
activedata
;
if
(
taskWay
.
get
(
"activedata"
)!=
null
&&
taskWay
.
get
(
"activedata"
)
instanceof
Map
)
activedata
=(
Map
)
taskWay
.
get
(
"activedata"
);
else
activedata
=
new
LinkedHashMap
();
//记录辅助功能操作记录
activedata
.
put
(
"sequenceflowname"
,
taskWay
.
getSequenceflowname
());
createHistoryRecord
(
ProcFunction
.
SENDBACK
,
task
,
activedata
);
HistoricTaskInstance
sourceRef
=
history
.
get
(
0
);
// 执行回退
runtimeService
.
createChangeActivityStateBuilder
()
.
processInstanceId
(
processInstanceId
)
.
moveActivityIdTo
(
taskDefinitionKey
,
sourceRef
.
getTaskDefinitionKey
())
.
changeState
();
return
true
;
return
true
;
}
}
...
@@ -2296,12 +2402,17 @@ public class WFCoreService
...
@@ -2296,12 +2402,17 @@ public class WFCoreService
/**
/**
* 流程撤回
* 流程撤回
* @param taskId
* @param system
* @param appname
* @param entity
* @param businessKey
* @param taskWay
* @param taskWay
* @return
* @return
*/
*/
public
boolean
withDraw
(
String
taskId
,
WFTaskWay
taskWay
)
{
public
boolean
withDraw
(
String
system
,
String
appname
,
String
entity
,
String
businessKey
,
WFTaskWay
taskWay
)
{
String
taskId
=
taskWay
.
getTaskid
();
String
processInstanceId
=
taskWay
.
getProcessinstanceid
();
String
processInstanceId
=
taskWay
.
getProcessinstanceid
();
String
taskDefinitionKey
=
taskWay
.
getTaskdefinitionkey
();
String
taskDefinitionKey
=
taskWay
.
getTaskdefinitionkey
();
...
@@ -2347,7 +2458,7 @@ public class WFCoreService
...
@@ -2347,7 +2458,7 @@ public class WFCoreService
* @param instance
* @param instance
* @return
* @return
*/
*/
public
boolean
jump
(
WFProcessInstance
instance
)
{
public
boolean
jump
(
String
system
,
String
entity
,
String
businessKey
,
WFProcessInstance
instance
)
{
String
processDefinitionId
=
instance
.
getProcessdefinitionid
();
String
processDefinitionId
=
instance
.
getProcessdefinitionid
();
if
(
ObjectUtils
.
isEmpty
(
processDefinitionId
)){
if
(
ObjectUtils
.
isEmpty
(
processDefinitionId
)){
...
@@ -2450,8 +2561,16 @@ public class WFCoreService
...
@@ -2450,8 +2561,16 @@ public class WFCoreService
return
true
;
return
true
;
}
}
public
boolean
sendCopy
(
String
taskId
,
WFTaskWay
taskWay
)
{
public
boolean
sendCopy
(
String
system
,
String
appname
,
String
entity
,
String
businessKey
,
WFTaskWay
taskWay
)
{
throw
new
BadRequestException
(
"暂未实现"
);
throw
new
BadRequestException
(
"暂未实现"
);
}
}
protected
String
getStringValue
(
Object
value
){
if
(
ObjectUtils
.
isEmpty
(
value
)){
return
null
;
}
return
value
.
toString
();
}
}
}
ibzwf-provider/ibzwf-provider-api/src/main/java/cn/ibizlab/api/rest/extensions/WFCoreResource.java
浏览文件 @
4968039a
...
@@ -158,7 +158,7 @@ public class WFCoreResource
...
@@ -158,7 +158,7 @@ public class WFCoreResource
@ApiOperation
(
value
=
"getWayByTaskId"
,
tags
=
{
"WFTaskWay"
},
notes
=
"根据业务主键和当前步骤获取操作路径"
)
@ApiOperation
(
value
=
"getWayByTaskId"
,
tags
=
{
"WFTaskWay"
},
notes
=
"根据业务主键和当前步骤获取操作路径"
)
@RequestMapping
(
method
=
RequestMethod
.
GET
,
value
=
"/{system}-app-{appname}/{entity}/{businessKey}/tasks/{taskId}/ways"
)
@RequestMapping
(
method
=
RequestMethod
.
GET
,
value
=
"/{system}-app-{appname}/{entity}/{businessKey}/tasks/{taskId}/ways"
)
public
ResponseEntity
<
List
<
WFTaskWay
>>
get
t
asklink
(
@PathVariable
(
"system"
)
String
system
,
@PathVariable
(
"appname"
)
String
appname
,
public
ResponseEntity
<
List
<
WFTaskWay
>>
get
T
asklink
(
@PathVariable
(
"system"
)
String
system
,
@PathVariable
(
"appname"
)
String
appname
,
@PathVariable
(
"entity"
)
String
entity
,
@PathVariable
(
"entity"
)
String
entity
,
@PathVariable
(
"businessKey"
)
String
businessKey
,
@PathVariable
(
"taskId"
)
String
taskId
)
{
@PathVariable
(
"businessKey"
)
String
businessKey
,
@PathVariable
(
"taskId"
)
String
taskId
)
{
List
<
WFTaskWay
>
taskWays
=
wfCoreService
.
getTaskLink
(
system
,
appname
,
entity
,
businessKey
,
taskId
);
List
<
WFTaskWay
>
taskWays
=
wfCoreService
.
getTaskLink
(
system
,
appname
,
entity
,
businessKey
,
taskId
);
...
@@ -188,8 +188,11 @@ public class WFCoreResource
...
@@ -188,8 +188,11 @@ public class WFCoreResource
@ApiOperation
(
value
=
"sendback"
,
tags
=
{
"sendback"
},
notes
=
"流程步骤回退"
)
@ApiOperation
(
value
=
"sendback"
,
tags
=
{
"sendback"
},
notes
=
"流程步骤回退"
)
@RequestMapping
(
method
=
RequestMethod
.
POST
,
value
=
"/{system}-app-{appname}/{entity}/{businessKey}/tasks/{taskId}/sendback"
)
@RequestMapping
(
method
=
RequestMethod
.
POST
,
value
=
"/{system}-app-{appname}/{entity}/{businessKey}/tasks/{taskId}/sendback"
)
public
ResponseEntity
<
Boolean
>
sendback
(
@PathVariable
(
"taskId"
)
String
taskId
){
public
ResponseEntity
<
Boolean
>
sendback
(
@PathVariable
(
"system"
)
String
system
,
@PathVariable
(
"appname"
)
String
appname
,
return
ResponseEntity
.
ok
(
wfCoreService
.
sendBack
(
taskId
));
@PathVariable
(
"entity"
)
String
entity
,
@PathVariable
(
"businessKey"
)
String
businessKey
,
@PathVariable
(
"taskId"
)
String
taskId
,
@RequestBody
WFTaskWay
taskWay
){
return
ResponseEntity
.
ok
(
wfCoreService
.
sendBack
(
system
,
appname
,
entity
,
businessKey
,
taskId
,
taskWay
));
}
}
// @ApiOperation(value = "delegatetask", tags = {"delegatetask" }, notes = "委派任务")
// @ApiOperation(value = "delegatetask", tags = {"delegatetask" }, notes = "委派任务")
...
@@ -307,21 +310,30 @@ public class WFCoreResource
...
@@ -307,21 +310,30 @@ public class WFCoreResource
@ApiOperation
(
value
=
"withDraw"
,
tags
=
{
"withDraw"
},
notes
=
"根据实例将流程撤回前一步"
)
@ApiOperation
(
value
=
"withDraw"
,
tags
=
{
"withDraw"
},
notes
=
"根据实例将流程撤回前一步"
)
@RequestMapping
(
method
=
RequestMethod
.
POST
,
value
=
"/{system}-app-{appname}/{entity}/{businessKey}/tasks/{taskId}/withdraw"
)
@RequestMapping
(
method
=
RequestMethod
.
POST
,
value
=
"/{system}-app-{appname}/{entity}/{businessKey}/tasks/{taskId}/withdraw"
)
public
ResponseEntity
<
Boolean
>
withDraw
(
@PathVariable
(
"taskId"
)
String
taskId
,
@RequestBody
WFTaskWay
taskWay
){
public
ResponseEntity
<
Boolean
>
withDraw
(
@PathVariable
(
"system"
)
String
system
,
@PathVariable
(
"appname"
)
String
appname
,
return
ResponseEntity
.
ok
(
wfCoreService
.
withDraw
(
taskId
,
taskWay
));
@PathVariable
(
"entity"
)
String
entity
,
@PathVariable
(
"businessKey"
)
String
businessKey
,
@PathVariable
(
"taskId"
)
String
taskId
,
@RequestBody
WFTaskWay
taskWay
){
taskWay
.
setTaskid
(
taskId
);
return
ResponseEntity
.
ok
(
wfCoreService
.
withDraw
(
system
,
appname
,
entity
,
businessKey
,
taskWay
));
}
}
@ApiOperation
(
value
=
"dataAccessMode"
,
tags
=
{
"流程跳转"
},
notes
=
"流程跳转"
)
@ApiOperation
(
value
=
"dataAccessMode"
,
tags
=
{
"流程跳转"
},
notes
=
"流程跳转"
)
@RequestMapping
(
method
=
RequestMethod
.
POST
,
value
=
"/{system}-{entity}/{businessKey}/process-instances/{processInstanceId}/jump"
)
@RequestMapping
(
method
=
RequestMethod
.
POST
,
value
=
"/{system}-{entity}/{businessKey}/process-instances/{processInstanceId}/jump"
)
public
ResponseEntity
<
Boolean
>
jump
(
@PathVariable
(
"processInstanceId"
)
String
processInstanceId
,
@RequestBody
WFProcessInstance
instance
)
{
public
ResponseEntity
<
Boolean
>
jump
(
@PathVariable
(
"system"
)
String
system
,
@PathVariable
(
"entity"
)
String
entity
,
@PathVariable
(
"businessKey"
)
String
businessKey
,
@PathVariable
(
"processInstanceId"
)
String
processInstanceId
,
@RequestBody
WFProcessInstance
instance
)
{
instance
.
setId
(
processInstanceId
);
instance
.
setId
(
processInstanceId
);
return
ResponseEntity
.
status
(
HttpStatus
.
OK
).
body
(
wfCoreService
.
jump
(
instance
));
return
ResponseEntity
.
status
(
HttpStatus
.
OK
).
body
(
wfCoreService
.
jump
(
system
,
entity
,
businessKey
,
instance
));
}
}
@ApiOperation
(
value
=
"restartwf"
,
tags
=
{
"重启流程"
},
notes
=
"重启流程"
)
@ApiOperation
(
value
=
"restartwf"
,
tags
=
{
"重启流程"
},
notes
=
"重启流程"
)
@RequestMapping
(
method
=
RequestMethod
.
POST
,
value
=
"/{system}-{entity}/{businessKey}/process-instances/{processInstanceId}/restart"
)
@RequestMapping
(
method
=
RequestMethod
.
POST
,
value
=
"/{system}-{entity}/{businessKey}/process-instances/{processInstanceId}/restart"
)
public
ResponseEntity
<
Boolean
>
restart
(
@PathVariable
(
"system"
)
String
system
,
@PathVariable
(
"entity"
)
String
entity
,
@PathVariable
(
"businessKey"
)
String
businessKey
,
public
ResponseEntity
<
Boolean
>
restart
(
@PathVariable
(
"system"
)
String
system
,
@PathVariable
(
"processInstanceId"
)
String
processInstanceId
,
@RequestBody
WFProcessInstance
instance
)
{
@PathVariable
(
"entity"
)
String
entity
,
@PathVariable
(
"businessKey"
)
String
businessKey
,
@PathVariable
(
"processInstanceId"
)
String
processInstanceId
,
@RequestBody
WFProcessInstance
instance
)
{
instance
.
setId
(
processInstanceId
);
instance
.
setId
(
processInstanceId
);
return
ResponseEntity
.
status
(
HttpStatus
.
OK
).
body
(
wfCoreService
.
restart
(
system
,
entity
,
businessKey
,
instance
));
return
ResponseEntity
.
status
(
HttpStatus
.
OK
).
body
(
wfCoreService
.
restart
(
system
,
entity
,
businessKey
,
instance
));
}
}
...
@@ -332,7 +344,8 @@ public class WFCoreResource
...
@@ -332,7 +344,8 @@ public class WFCoreResource
@PathVariable
(
"entity"
)
String
entity
,
@PathVariable
(
"entity"
)
String
entity
,
@PathVariable
(
"businessKey"
)
String
businessKey
,
@PathVariable
(
"taskId"
)
String
taskId
,
@PathVariable
(
"businessKey"
)
String
businessKey
,
@PathVariable
(
"taskId"
)
String
taskId
,
@RequestBody
WFTaskWay
taskWay
)
{
@RequestBody
WFTaskWay
taskWay
)
{
return
ResponseEntity
.
status
(
HttpStatus
.
OK
).
body
(
wfCoreService
.
beforeSign
(
system
,
appname
,
entity
,
businessKey
,
taskId
,
taskWay
));
taskWay
.
setTaskid
(
taskId
);
return
ResponseEntity
.
status
(
HttpStatus
.
OK
).
body
(
wfCoreService
.
beforeSign
(
system
,
appname
,
entity
,
businessKey
,
taskWay
));
}
}
@ApiOperation
(
value
=
"转办任务"
,
tags
=
{
"工作流转办任务"
},
notes
=
"转办任务"
)
@ApiOperation
(
value
=
"转办任务"
,
tags
=
{
"工作流转办任务"
},
notes
=
"转办任务"
)
...
@@ -341,13 +354,18 @@ public class WFCoreResource
...
@@ -341,13 +354,18 @@ public class WFCoreResource
@PathVariable
(
"entity"
)
String
entity
,
@PathVariable
(
"entity"
)
String
entity
,
@PathVariable
(
"businessKey"
)
String
businessKey
,
@PathVariable
(
"taskId"
)
String
taskId
,
@PathVariable
(
"businessKey"
)
String
businessKey
,
@PathVariable
(
"taskId"
)
String
taskId
,
@RequestBody
WFTaskWay
taskWay
)
{
@RequestBody
WFTaskWay
taskWay
)
{
return
ResponseEntity
.
status
(
HttpStatus
.
OK
).
body
(
wfCoreService
.
reassign
(
system
,
appname
,
entity
,
businessKey
,
taskId
,
taskWay
));
taskWay
.
setTaskid
(
taskId
);
return
ResponseEntity
.
status
(
HttpStatus
.
OK
).
body
(
wfCoreService
.
reassign
(
system
,
appname
,
entity
,
businessKey
,
taskWay
));
}
}
@ApiOperation
(
value
=
"将文件抄送给选定人员"
,
tags
=
{
"将文件抄送给选定人员"
}
,
notes
=
"将文件抄送给选定人员"
)
@ApiOperation
(
value
=
"将文件抄送给选定人员"
,
tags
=
{
"将文件抄送给选定人员"
}
,
notes
=
"将文件抄送给选定人员"
)
@RequestMapping
(
method
=
RequestMethod
.
POST
,
value
=
"/{system}-app-{appname}/{entity}/{businessKey}/tasks/{taskId}/sendcopy"
)
@RequestMapping
(
method
=
RequestMethod
.
POST
,
value
=
"/{system}-app-{appname}/{entity}/{businessKey}/tasks/{taskId}/sendcopy"
)
public
ResponseEntity
<
Boolean
>
sendCopy
(
@PathVariable
(
"taskId"
)
String
taskId
,
@RequestBody
WFTaskWay
taskWay
)
{
public
ResponseEntity
<
Boolean
>
sendCopy
(
@PathVariable
(
"system"
)
String
system
,
@PathVariable
(
"appname"
)
String
appname
,
return
ResponseEntity
.
status
(
HttpStatus
.
OK
).
body
(
wfCoreService
.
sendCopy
(
taskId
,
taskWay
));
@PathVariable
(
"entity"
)
String
entity
,
@PathVariable
(
"businessKey"
)
String
businessKey
,
@PathVariable
(
"taskId"
)
String
taskId
,
@RequestBody
WFTaskWay
taskWay
)
{
taskWay
.
setTaskid
(
taskId
);
return
ResponseEntity
.
status
(
HttpStatus
.
OK
).
body
(
wfCoreService
.
sendCopy
(
system
,
appname
,
entity
,
businessKey
,
taskWay
));
}
}
...
...
编辑
预览
Markdown
格式
0%
请重试
or
添加新附件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
先完成此消息的编辑!
取消
想要评论请
注册
或
登录