Flowable源码注释(五十二)事件解析处理器(上)

本文介绍了Flowable流程引擎中事件解析处理器的实现,包括补偿事件、消息事件和信号事件的定义解析处理器。这些处理器在解析BPMN模型时,为不同类型的事件设置行为,如中间抛出补偿事件、边界事件等。同时,还提到了发送事件服务任务的处理器。源码分析有助于理解Flowable引擎如何处理各类事件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Flowable源码地址:https://github.com/flowable/flowable-engine

Flowable-6.7.2 源码注释地址:https://github.com/solojin/flowable-6.7.2-annotated

事件解析处理器,包路径:org.flowable.engine.impl.bpmn.parser.handler

CompensateEventDefinitionParseHandler 补偿事件定义解析处理器

/**
 * 补偿事件定义解析处理器
 *
 * @author Joram Barrez
 * @author Tijs Rademakers
 */
public class CompensateEventDefinitionParseHandler extends AbstractBpmnParseHandler<CompensateEventDefinition> {

    @Override
    public Class<? extends BaseElement> getHandledType() {
        return CompensateEventDefinition.class;
    }

    @Override
    protected void executeParse(BpmnParse bpmnParse, CompensateEventDefinition eventDefinition) {

        if (bpmnParse.getCurrentFlowElement() instanceof ThrowEvent) {
            ThrowEvent throwEvent = (ThrowEvent) bpmnParse.getCurrentFlowElement();
            throwEvent.setBehavior(bpmnParse.getActivityBehaviorFactory().createIntermediateThrowCompensationEventActivityBehavior(
                    throwEvent, eventDefinition));

        } else if (bpmnParse.getCurrentFlowElement() instanceof BoundaryEvent) {
            BoundaryEvent boundaryEvent = (BoundaryEvent) bpmnParse.getCurrentFlowElement();
            boundaryEvent.setBehavior(bpmnParse.getActivityBehaviorFactory().createBoundaryCompensateEventActivityBehavior(boundaryEvent,
                    eventDefinition, boundaryEvent.isCancelActivity()));

        } else {

            // What to do?

        }

    }

}

MessageEventDefinitionParseHandler 消息事件定义解析处理器

/**
 * 消息事件定义解析处理器
 *
 * @author Joram Barrez
 * @author Tijs Rademakers
 */
public class MessageEventDefinitionParseHandler extends AbstractBpmnParseHandler<MessageEventDefinition> {

    @Override
    public Class<? extends BaseElement> getHandledType() {
        return MessageEventDefinition.class;
    }

    @Override
    protected void executeParse(BpmnParse bpmnParse, MessageEventDefinition messageDefinition) {
        BpmnModel bpmnModel = bpmnParse.getBpmnModel();
        String messageRef = messageDefinition.getMessageRef();
        if (bpmnModel.containsMessageId(messageRef)) {
            Message message = bpmnModel.getMessage(messageRef);
            messageDefinition.setMessageRef(message.getName());

            for(List<ExtensionElement> extensionElementList : message.getExtensionElements().values()) {
                for(ExtensionElement extensionElement : extensionElementList) {
                    messageDefinition.addExtensionElement(extensionElement);
                }
            }
        }

        if (bpmnParse.getCurrentFlowElement() instanceof IntermediateCatchEvent) {
            IntermediateCatchEvent intermediateCatchEvent = (IntermediateCatchEvent) bpmnParse.getCurrentFlowElement();
            intermediateCatchEvent.setBehavior(bpmnParse.getActivityBehaviorFactory().createIntermediateCatchMessageEventActivityBehavior(intermediateCatchEvent, messageDefinition));

        } else if (bpmnParse.getCurrentFlowElement() instanceof BoundaryEvent) {
            BoundaryEvent boundaryEvent = (BoundaryEvent) bpmnParse.getCurrentFlowElement();
            boundaryEvent.setBehavior(bpmnParse.getActivityBehaviorFactory().createBoundaryMessageEventActivityBehavior(boundaryEvent, messageDefinition, boundaryEvent.isCancelActivity()));
        }

        else {
            // What to do here?
        }

    }

}

SignalEventDefinitionParseHandler 信号事件定义解析处理器

/**
 * 信号事件定义解析处理器
 *
 * @author Joram Barrez
 * @author Tijs Rademakers
 */
public class SignalEventDefinitionParseHandler extends AbstractBpmnParseHandler<SignalEventDefinition> {

    @Override
    public Class<? extends BaseElement> getHandledType() {
        return SignalEventDefinition.class;
    }

    @Override
    protected void executeParse(BpmnParse bpmnParse, SignalEventDefinition signalDefinition) {

        Signal signal = null;
        if (bpmnParse.getBpmnModel().containsSignalId(signalDefinition.getSignalRef())) {
            signal = bpmnParse.getBpmnModel().getSignal(signalDefinition.getSignalRef());
        }

        if (bpmnParse.getCurrentFlowElement() instanceof IntermediateCatchEvent) {
            IntermediateCatchEvent intermediateCatchEvent = (IntermediateCatchEvent) bpmnParse.getCurrentFlowElement();
            intermediateCatchEvent.setBehavior(bpmnParse.getActivityBehaviorFactory().createIntermediateCatchSignalEventActivityBehavior(intermediateCatchEvent, signalDefinition, signal));

        } else if (bpmnParse.getCurrentFlowElement() instanceof BoundaryEvent) {
            BoundaryEvent boundaryEvent = (BoundaryEvent) bpmnParse.getCurrentFlowElement();
            boundaryEvent.setBehavior(bpmnParse.getActivityBehaviorFactory().createBoundarySignalEventActivityBehavior(boundaryEvent, signalDefinition, signal, boundaryEvent.isCancelActivity()));
        }
    }
}

SendEventServiceTaskParseHandler 发送事件解析处理器

/**
 * 发送事件解析处理器
 *
 * @author Tijs Rademakers
 */
public class SendEventServiceTaskParseHandler extends AbstractActivityBpmnParseHandler<SendEventServiceTask> {

    @Override
    public Class<? extends BaseElement> getHandledType() {
        return SendEventServiceTask.class;
    }

    @Override
    protected void executeParse(BpmnParse bpmnParse, SendEventServiceTask sendEventServiceTask) {
        sendEventServiceTask.setBehavior(bpmnParse.getActivityBehaviorFactory().createSendEventTaskBehavior(sendEventServiceTask));
    }

}

BoundaryEventParseHandler 边界事件解析处理器

/**
 * 边界事件解析处理器
 *
 * @author Joram Barrez
 * @author Tijs Rademakers
 */
public class BoundaryEventParseHandler extends AbstractFlowNodeBpmnParseHandler<BoundaryEvent> {

    private static final Logger LOGGER = LoggerFactory.getLogger(BoundaryEventParseHandler.class);

    @Override
    public Class<? extends BaseElement> getHandledType() {
        return BoundaryEvent.class;
    }

    @Override
    protected void executeParse(BpmnParse bpmnParse, BoundaryEvent boundaryEvent) {

        if (boundaryEvent.getAttachedToRef() == null) {
            // 边界事件中的引用无效。确保引用的活动与边界事件{}定义在同一范围内
            LOGGER.warn("Invalid reference in boundary event. Make sure that the referenced activity is defined in the same scope as the boundary event {}", boundaryEvent.getId());
            return;
        }

        EventDefinition eventDefinition = null;
        if (boundaryEvent.getEventDefinitions().size() > 0) {
            eventDefinition = boundaryEvent.getEventDefinitions().get(0);
        }

        if (eventDefinition instanceof TimerEventDefinition || 
                eventDefinition instanceof ErrorEventDefinition || 
                eventDefinition instanceof SignalEventDefinition || 
                eventDefinition instanceof CancelEventDefinition || 
                eventDefinition instanceof ConditionalEventDefinition || 
                eventDefinition instanceof MessageEventDefinition || 
                eventDefinition instanceof EscalationEventDefinition || 
                eventDefinition instanceof CompensateEventDefinition ||
                eventDefinition instanceof VariableListenerEventDefinition) {

            bpmnParse.getBpmnParserHandlers().parseElement(bpmnParse, eventDefinition);
            return;
            
        } else if (!boundaryEvent.getExtensionElements().isEmpty()) {
            List<ExtensionElement> eventTypeExtensionElements = boundaryEvent.getExtensionElements().get(BpmnXMLConstants.ELEMENT_EVENT_TYPE);
            if (eventTypeExtensionElements != null && !eventTypeExtensionElements.isEmpty()) {
                String eventTypeValue = eventTypeExtensionElements.get(0).getElementText();
                if (StringUtils.isNotEmpty(eventTypeValue)) {
                    boundaryEvent.setBehavior(bpmnParse.getActivityBehaviorFactory().createBoundaryEventRegistryEventActivityBehavior(
                                    boundaryEvent, eventTypeValue, boundaryEvent.isCancelActivity()));
                    return;
                }
            }

        } 
        
        // 应该已经在部署时由process validator获取,所以这只是为了确定
        LOGGER.warn("Unsupported boundary event type for boundary event {}", boundaryEvent.getId());
    }

}
Flowable是一个开源的工作流引擎,用于实现公文流转等各种业务流程。具体而言,Flowable提供了一套完整的流程模型、管理和执行的功能。在Flowable中,公文流转可以通过以下几个步骤实现: 1. 定义流程模型:使用Flowable的模型设计器,可以创建和定义公文流转的流程模型。这个模型包括了公文流转的各个环节、参与者和流程规则等信息。 2. 部署流程:将流程模型部署到Flowable引擎中,使其可以被执行。部署可以通过Flowable的API或者图形界面进行操作。 3. 启动流程实例:根据已定义的流程模型,可以通过Flowable的API启动一个新的流程实例。每个流程实例对应一个具体的公文流转实例。 4. 执行流程任务:在流程实例启动后,根据流程模型的定义,系统会生成一系列待办任务。这些任务可以被分配给相应的参与者,参与者可以在Flowable的用户界面或者接口中完成任务。 5. 流程控制和决策:Flowable提供了灵活的流程控制和决策能力,可以根据业务需求自定义流程规则和条件。 6. 监控和管理:Flowable提供了丰富的监控和管理功能,可以实时查看流程实例的状态、任务进展和性能指标等信息。 通过以上步骤,Flowable可以实现公文流转的全过程管理和执行。具体的实现细节可以参考Flowable源码以及相关文档和示例。<span class="em">1</span><span class="em">2</span> #### 引用[.reference_title] - *1* *2* [Flowable源码注释(四十八)流程解析处理器](https://blog.csdn.net/JinYJ2014/article/details/123055277)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值