流程定义

WikeFlow2.0演示地址:http://workflow2.wikesoft.com


 流程定义的作用

定义一个流程,并指定该流程的唯一Key值 。通过流程定义的Key值 ,在创建实例的时候,通过指定Key值 ,能找到创建的是什么流程。如何创建流程,请查看《如何创建流程》


  如何关联你的业务

流程定义要指定业务程序集和业务类名(命名空间.类名,该类要实现IWorkFlowService),

该业务类要实现两部分功能

1、该业务类自己本身的业务功能(增、删、改、查或其它业务操作);

2、IWorkFlowService的六个接口的实现,这六个接口可以完成业务系统和工作流的交互功能。

当流程执行相关操作的时候,流程引擎自动调用业务类实现的IWorkFlowService方法,达到你的业务代码与WikeFlow2的系统交互功能。IWorkFlowService接口说明,请查看《关于IWorkFlowService》

演示用例的请假申请的业务程序集是WikeSoft.Enterprise,业务类名是WikeSoft.Enterprise.AppServices.HolidayApplyService

请假申请业务类HolidayApplyService代码截图如下图:

示例:HolidayService实现IWorkFlowServer的BeforeExecNextEvent接口

代码解释:

1、当申请人提交,将状态修改为审核中

2、驳回到申请人,将状态修改为未审核

3、流程结束,将状态修改为已审核

4、动作标记(ActionSign):是执行该动作的一个标记,通过该标记,你的业务系统能知道流程执行的什么操作,你的业务系统要处理什么逻辑。


        /// <summary>
        /// 流程节点审批前事件
        /// </summary>
        /// <param name="invokeMember">参数</param>
        /// <returns>WorkFlowMessage,如果Code= Fail,会中断流程引擎</returns>
        public WorkFlowMessage BeforeExecNextEvent(InvokeMember invokeMember)
        {
            WorkFlowMessage workFlowMessage = new InstanceMessage();
            try
            {
                using (var context = new WikeDbContext())
                {
                    var data = context.Holidays.FirstOrDefault(c => c.INSTANCEID == invokeMember.InstanceId);
                    if (data != null)
                    {
                        if (invokeMember.ActionSign == "start")
                        {
                            data.AUDITSTATE = "审核中";
                        }
                        if (invokeMember.ActionSign == "reject_to_start")
                        {
                            data.AUDITSTATE = "未审核";
                        }
                        if (invokeMember.ActionSign == "finish")
                        {
                            data.AUDITSTATE = "已审核 ";
                        }
                        context.Holidays.AddOrUpdate(data);
                        context.SaveChanges();
                    }

                }
            }
            catch (Exception ex)
            {
                workFlowMessage.Code = CodeEum.Fail;
                workFlowMessage.Message = ex.Message;

            }

            return workFlowMessage;
        }