我正在使用Activiti 5.12
。根据提供的,在其用户指南中,RESTAPI获取流程实例的详细信息:GET /process-instance/{process InstanceId}
它的反应是这样的:
{
"id": "2",
"processDefinitionId": "financialReport:1",
"businessKey": "55",
"startTime": "2010-10-13T14:54:26.750+02:00",
"startActivityId": "startFinancialAnalysis",
"startUserId": "kermit",
"completed": false,
"tasks": [
{
"taskId": "3",
"taskName": "Analyze report",
"owner": null,
"assignee": "Kermit",
"startTime": "2010-10-13T14:53:26.750+02:00",
"completed": false
}
],
"activities": [
{
"activityId": "4",
"activityName": "Get report",
"activityType": "ServiceTask",
"startTime": "2010-10-13T14:53:25.950+02:00",
"completed": true,
"duration": 200
}
],
"variables": [
{
"variableName": "reportName",
"variableValue": "classified.pdf"
}
],
"historyVariables": [
{
"variableName": "reportName",
"variableValue": "classified.pdf",
"variableType": "String",
"revision": 1,
"time": "2010-10-13T14:53:26.750+02:00"
}
]
}
还提供了一个相同的JAVAAPI,即:ProcessEngines. getProcessEngine(configuredProcessEngine Name).get历史服务().create历史ProcessInstanceQuery().ProcInstanceId("solValue").singleResult()
这JavaAPI不起作用,因为返回类型历史进程实例
没有获取任务列表的方法。
我的目标是获取流程实例的当前状态,即它当前处于哪个任务。
RESTAPI列出了进程实例执行的所有任务,列表中的最后一个任务是它当前正在执行的任务,因为它的属性完成
是false
。
我想实现同样的从java代码。
你能帮帮我吗?任何其他达到目标的方法对我来说都没问题。
您可以使用历史服务
的另一个查询API:
List<HistoricTaskIntance> taskList = getHistoryService()
.createHistoricTaskInstanceQuery()
.processInstanceId(processInstanceId)
.list()
当前任务状态可以由历史TaskInstance. getEndTime()
定义,它将为打开的任务返回null
。
我尝试过这种方法。
SELECT NAME_ FROM act_hi_taskinst where PROC_INST_ID_= 1000 and END_TIME_ IS NULL;"
act_hi_taskinst
包含每个实例的历史任务。
如果带有实例ID的过程完成,那么您将不会得到任何结果,因此您可以在继续之前检查该条件。
我已经运行了这段SQL语句来获取所需的任务名称。
@Mike给出的答案也符合目标。即使在这里,你也必须检查过程是否不完整。