jBPM jPDL 用户开发手册 3.2.3 - 第17章

17 邮件支持

本章描述了jBPM jPDL中随包发行的邮件支持。

17.1. jPDL中的邮件

从流程中发送邮件有四种指定的方式。

17.1.1. 邮件动作

邮件动作能够用来发送邮件而不是在流程图中显示一个节点。

允许你在在流程的任何地方来指定动作,你可以像这样指定一个邮件动作:

<mail actors="#{president}" subject="readmylips" text="nomoretaxes" />

Subjecttext属性也能作为一个元素来指定,像这样:

<mail actors="#{president}" >

  <subject>readmylips</subject>

  <text>nomoretaxes</text>

</mail>

每个域都可以包含JSF那样的表达式。例如:

<mail to='#{initiator}' subject='websale' text='your websale of #{quantity} #{item} was approved' />

更多的关于表达式的信息,查看21.3 表达式部分

有两个属性用来指定收集人:actorstoto属性应该解析成一个分号分隔的邮件地址列表。actors属性应该解析成一个分号分隔的actorId的列表。那些actorId将使用地址解析来解析成邮件地址。

<mail to='[email protected]' subject='urgent' text='the mailserver is down :-)' />

更多的关于如何指定收件人的信息,查看17.3 指定收件人部分

邮件可以定义成模板而且在流程中你可以重写模板的属性,如:

<mail template='sillystatement' actors="#{president}" />

更多的关于模板的信息,查看17.4 邮件模板部分

17.1.2. 邮件节点

就跟邮件动作(mail actions)一样,邮件发送也能被建模成节点。那样的话,运行时行为是相同的,但是邮件将在流程图中显示成一个节点。

邮件节点所支持的属性和元素同邮件动作完全相同。

<mail-node name="send email" to="#{president}" subject="readmylips" text="nomoretaxes">

  <transition to="the next node" />

</mail-node>

邮件节点完全应该有一个离开转换。

17.1.3. 任务分派邮件

当任务获得被分配的参与者时通知邮件能够发送。在一个任务上使用notify="yes"属性,如:

<task-node name='a'>

  <task name='laundry' swimlane="grandma" notify='yes' />

  <transition to='b' />

</task-node>

设置notifyyestrueon将导致jBPM给分配到任务上的参与者发送邮件。邮件是基于模板(查看17.4 邮件模板部分)并且包含一个到web应用的任务页面的链接。

17.1.4. 任务提醒邮件

同使用分派(assignments)一样,邮件(emails)能够作为任务提醒被发送。jPDL 中的reminder元素基于定时器。最常用的属性是duedaterepeat。唯一的不同是没有动作(action)指定。

<task-node name='a'>

  <task name='laundry' swimlane="grandma" notify='yes'>

    <reminder duedate="2 business days" repeat="2 business hours"/>

  </task>

  <transition to='b' />

</task-node>

 

17.2. 邮件表达式

torecipientssubjecttext能够被包含像JSF的表达式。更多的关于表达式的信息,查看21.3表达式部分。

表达式中的变量:swimlanes process变量、transient变量beans被配置jbpm.cfg.xml中。

这些表达式能够同本章后面解释的地址解析进行组合。例如:假设在你的流程中有一个swimlanepresident,然后看下面的邮件规范:

<mail actors="#{president}" subject="readmylips" text="nomoretaxes" />

那将为特定的流程执行发送邮件到扮演president的那个人。

17.3. 指定收件人

17.3.1. 多个收件人

actorsto域中,多个收件人可以使用分号(;)或冒号(:)来进行分隔。

17.3.2. 密送邮件

有时除正常的收件人外你还想发送邮件到一个BCC目标。当前,有两个支持的方法:第一你可以在流程定义中指定一个bccActorsbcc属性(根据actorsto)。

<mail to='#{initiator}' bcc='[email protected]' subject='websale' text='your websale of #{quantity} #{item} was approved' />

第二个方法是总是发送一个BCC邮件到你在中心配置(jbpm.cfg.xml)中的一个属性中配置的某个位置上:

<jbpm-configuration>

  ...

  <string name="jbpm.mail.bcc.address" value="[email protected]" />

</jbpm-configuration>

 

17.3.3. 地址解析

在所有的jBPM中,actorsactorId's引用。这是一个作为流程参与人标识符的字符串。一个地址解析翻译actorId's成为邮件地址。

如果你想应用地址解析使用属性actors而如果你要直接指定邮件地址而不想应用地址解析使用属性to

一个地址解析器应该实现下列的接口:

public interface AddressResolver extends Serializable {

  Object resolveAddress(String actorId);

}

一个地址解析器应该返回3个类型中的1个:字符串(String)、字符串集合(Collection of String)或字符串数组(array of String)。

所有字符串应该为给定的 actorId代表邮件地址。

地址解析器实现应该是使用名字jbpm.mail.address.resolver配置在jbpm.cfg.xml中的bean。如:

<jbpm-configuration>

  ...

  <bean name='jbpm.mail.address.resolver' class='org.jbpm.identity.mail.IdentityAddressResolver' singleton='true' />

</jbpm-configuration>

 

jBPM的身份构件包括一个地址解析器。那个地址解析器将查找给定actorIdUser。如果用户存在,那个用户的邮件被返回,否则为null。更多关于身份构件信息能够在12.11 身份构件中找到。

17.4. 邮件模板

代替在processdefinition.xml中指定邮件,邮件能够指定模板文件中。当一个模板被使用时,processdefinition.xml文件中的每个域仍然能够被覆盖。邮件模板应该在XML文件中像这样来指定:

<mail-templates>

 

  <variable name="BaseTaskListURL" value="http://localhost:8080/jbpm/task?id=" />

 

  <mail-template name='task-assign'>

    <actors>#{taskInstance.actorId}</actors>

    <subject>Task '#{taskInstance.name}'</subject>

    <text><![CDATA[Hi,

Task '#{taskInstance.name}' has been assigned to you.

Go for it: #{BaseTaskListURL}#{taskInstance.id}

Thanks.

---powered by JBoss jBPM---]]></text>

  </mail-template>

 

  <mail-template name='task-reminder'>

    <actors>#{taskInstance.actorId}</actors>

    <subject>Task '#{taskInstance.name}' !</subject>

    <text><![CDATA[Hey,

Don't forget about #{BaseTaskListURL}#{taskInstance.id}

Get going !

---powered by JBoss jBPM---]]></text>

  </mail-template>

 

</mail-templates>

像你在这个例子(BaseTaskListURL)中看到的一样,extra变量能够定义在邮件模板中,它在表达式中是有效的。

包含模板的资源应该在jbpm.cfg.xml中像这样进行配置:

<jbpm-configuration>

  ...

  <string name="resource.mail.templates" value="jbpm.mail.templates.xml" />

</jbpm-configuration>

17.5. 邮件服务器配置

最简单的配置邮件服务器的方法在jbpm.cfg.xml文件中使用jbpm.mail.smtp.host这个配置属性,如:

<jbpm-configuration>

  ...

  <string name="jbpm.mail.smtp.host" value="localhost" />

</jbpm-configuration>

作为选择,当更多的属性需要被指定时,应该用关键字' resource.mail.properties '给定资源引用的属性文件,如:

<jbpm-configuration>

  ...

  <string name='resource.mail.properties' value='jbpm.mail.properties' />

</jbpm-configuration>

17.6. From地址配置

jPDL邮件中From地址的缺省值使用的是jbpm@noreply。邮件的from地址可以在jBPM的配置文件jbpm.xfg.xml中使用关键字'jbpm.mail.from.address'来配置,如:

<jbpm-configuration>

  ...

  <string name='jbpm.mail.from.address' value='[email protected]' />

</jbpm-configuration>

17.7. 自定义邮件支持

jBPM中所有的邮件支持是以一个类为中央的:org.jbpm.mail.Mail,这是一个ActionHandler实现。无论何时邮件在流程xml中指定,都将代理到邮件类。它可能继承自Mail类然后再为你的特殊需求定制某些功能。为了配置你的类使用邮件代理,在jbpm.cfg.xml文件中像这样来指定'jbpm.mail.class.name'配置字符串:

<jbpm-configuration>

  ...

  <string name='jbpm.mail.class.name' value='com.your.specific.CustomMail' />

</jbpm-configuration>

 定制的mail类在解析期间被读取并且动作将在引用配置了(或缺省的)邮件类名的流程中被配置。所以如果你改变这个属性,所有已经部署的流程将仍然引用旧的邮件名。但他们将能够通过使用一条简单的update语句很容易地被更新到jbpm数据库。

17.8. 邮件服务器

如果你需要一个易于安装的邮件服务器,那么就检出JBossMail Server Apache James吧。

 

:-s

你可能感兴趣的:(xml,应用服务器,jboss,jbpm,JSF)