289.7. 使用批准
所有属性都与在带有 批准前缀的 Salesforce REST API 中命名完全相同。
您可以通过设置 Endpoint 的 approval.PropertyName
设置批准属性,这些属性将用作 template swig-5-4mean,表示正文或标头中没有存在的任何属性都将从 Endpoint 配置中获取。或者,您可以通过将 approval
属性分配给 Registry 中 bean 的引用来设置 Endpoint 上的批准模板。
您还可以在传入的消息标头中使用相同的 approval.PropertyName
提供标头值。
最后,正文可以包含一个 AprovalRequest
或 ApprovalRequest
对象的 Iterable
,以作为批处理处理。
请记住,重要的是这三个机制中指定的值的优先级:
- 正文中的值在任何其他之前具有优先权
- 消息标头中的值在模板值前具有优先权
- 如果未指定标头或正文中的其他值,则模板中的值会被设置
例如,要使用标头中的值发送一条用于批准的记录:
给定路由:
from("direct:example1")// .setHeader("approval.ContextId", simple("${body['contextId']}")) .setHeader("approval.NextApproverIds", simple("${body['nextApproverIds']}")) .to("salesforce:approval?"// + "approval.actionType=Submit"// + "&approval.comments=this is a test"// + "&approval.processDefinitionNameOrId=Test_Account_Process"// + "&approval.skipEntryCriteria=true");
您可以发送一条用于批准的记录:
final Map<String, String> body = new HashMap<>(); body.put("contextId", accountIds.iterator().next()); body.put("nextApproverIds", userId); final ApprovalResult result = template.requestBody("direct:example1", body, ApprovalResult.class);