bool ExecuteBpmOperation(BpmProcessId tBpmProcess, ExecuteBpmOperationArg tArg)
tBpmProcess. Моникёр открытого процесса.
tArg. Параметры выполнения операции.
Операция ExecuteBpmOperation выполняет различные операции при работе с экземплярами выполняющихся процессов.
Для выполнения операции укажите в поле tBpmProcess моникёр открытого процесса. Моникёр может быть получен при выполнении операции OpenBpmProcess. В поле tArg.oper определите выполняемую операцию. Если операция выполняется для экземпляров процессов, то определите поле tArg.instIds. Идентификаторы экземпляров процессов можно получить в результате операции GetProcessInstances. Если операция выполняется для какого-либо шага, то определите поле tArg.guid. GUID'ы шагов можно получить в результате операции GetBpmMonitoringWorkspace. При необходимости можно определить другие необязательные поля.
Результатом выполнения операции будет логическое значение true, если операция завершилась успешно.
Ниже приведён пример остановки выполняющегося экземпляра процесса. В запросе передаётся моникёр открытого процесса и идентификатор выполняющегося экземпляра процесса, а также выполняемая операция. В ответе возвращается признак успешной остановки экземпляра процесса.
{
"ExecuteBpmOperation" :
{
"tBpmProcess" :
{
"id" : "NPHEOHFBGPCDGOAEFHEOFIIANCEEIDGECLDJGGBNCPACAJOB!M!S!BPJKLPJNFBGPCDGOAEEGOFJMAOEDKBLKDEALEJKADCFIEOHNAC"
},
"tArg" :
{
"oper" : "ProcessStop",
"instIds" :
{
"it" : "97976"
},
"comment" : ""
}
}
}
{
"ExecuteBpmOperationResult" : "1"
}
public static bool ExecuteBpmOperation(string moniker, int instId, BProcessMonitoringExecuteOperation operation, string operComment = "")
{
var somClient = new SomPortTypeClient(); // Прокси-объект для выполнения операций
// Параметры выполнения операции
var tExec = new ExecuteBpmOperation()
{
// Формирование моникёра объекта
tBpmProcess = new BpmProcessId() { id = moniker },
tArg = new ExecuteBpmOperationArg()
{
instIds = new int[1] { instId },
oper = operation,
comment = operComment
}
};
// Выполнение операции над запущенным экземпляром процесса
var result = somClient.ExecuteBpmOperation(tExec);
return result;
}
См. также: