using Serein.Library.Entity; using Serein.Library.Enums; using Serein.Library.Utils; using System; using System.Collections.Generic; using System.Reflection; using System.Threading.Tasks; using static Serein.Library.Utils.ChannelFlowInterrupt; namespace Serein.Library.Api { #region 环境委托 /// /// 流程运行完成 /// /// public delegate void FlowRunCompleteHandler(FlowEventArgs eventArgs); /// /// 项目加载完成 /// public delegate void ProjectLoadedHandler(ProjectLoadedEventArgs eventArgs); /// /// 加载项目文件时成功加载了DLL文件 /// public delegate void LoadDLLHandler(LoadDLLEventArgs eventArgs); /// /// 运行环境节点连接发生了改变 /// /// /// /// public delegate void NodeConnectChangeHandler(NodeConnectChangeEventArgs eventArgs); /// /// 环境中加载了一个节点 /// /// /// /// public delegate void NodeCreateHandler(NodeCreateEventArgs eventArgs); /// /// 环境中流程起始节点发生了改变 /// /// public delegate void StartNodeChangeHandler(StartNodeChangeEventArgs eventArgs); /// /// 被监视的对象改变事件 /// /// public delegate void MonitorObjectChangeHandler(MonitorObjectEventArgs eventArgs); /// /// 节点中断状态改变事件(开启了中断/取消了中断) /// /// public delegate void NodeInterruptStateChangeHandler(NodeInterruptStateChangeEventArgs eventArgs); /// /// 节点触发中断事件 /// /// public delegate void ExpInterruptTriggerHandler(InterruptTriggerEventArgs eventArgs); #endregion #region 环境事件签名 /// /// 流程事件签名基类 /// public class FlowEventArgs : EventArgs { /// /// 是否完成 /// public bool IsSucceed { get; protected set; } = true; /// /// 错误提示 /// public string ErrorTips { get; protected set; } = string.Empty; } //public class LoadNodeEventArgs : FlowEventArgs //{ // public LoadNodeEventArgs(NodeInfo NodeInfo, MethodDetails MethodDetailss) // { // this.NodeInfo = NodeInfo; // this.MethodDetailss = MethodDetailss; // } // /// // /// 项目文件节点信息参数 // /// // public NodeInfo NodeInfo { get; protected set; } // /// // /// 已加载在环境中的方法描述 // /// // public MethodDetails MethodDetailss { get; protected set; } //} public class ProjectLoadedEventArgs : FlowEventArgs { public ProjectLoadedEventArgs() { } } public class LoadDLLEventArgs : FlowEventArgs { public LoadDLLEventArgs(Assembly Assembly, List MethodDetailss) { this.Assembly = Assembly; this.MethodDetailss = MethodDetailss; } /// /// 已加载了的程序集 /// public Assembly Assembly { get; protected set; } /// /// dll文件中有效的流程方法描述 /// public List MethodDetailss { get; protected set; } } public class NodeConnectChangeEventArgs : FlowEventArgs { /// /// 连接关系改变类型 /// public enum ConnectChangeType { /// /// 创建 /// Create, /// /// 移除 /// Remote, } public NodeConnectChangeEventArgs(string fromNodeGuid, string toNodeGuid, ConnectionType connectionType, ConnectChangeType changeType) { this.FromNodeGuid = fromNodeGuid; this.ToNodeGuid = toNodeGuid; this.ConnectionType = connectionType; this.ChangeType = changeType; } /// /// 连接关系中始节点的Guid /// public string FromNodeGuid { get; protected set; } /// /// 连接关系中目标节点的Guid /// public string ToNodeGuid { get; protected set; } /// /// 连接类型 /// public ConnectionType ConnectionType { get; protected set; } /// /// 表示此次需要在两个节点之间创建连接关系,或是移除连接关系 /// public ConnectChangeType ChangeType { get; protected set; } } public class NodeCreateEventArgs : FlowEventArgs { public NodeCreateEventArgs(object nodeModel, Position position) { this.NodeModel = nodeModel; this.Position = position; } public NodeCreateEventArgs(object nodeModel, bool isAddInRegion, string regeionGuid) { this.NodeModel = nodeModel; this.RegeionGuid = regeionGuid; this.IsAddInRegion = isAddInRegion; } /// /// 节点Model对象,目前需要手动转换对应的类型 /// public object NodeModel { get; private set; } public Position Position { get; private set; } public bool IsAddInRegion { get; private set; } public string RegeionGuid { get; private set; } } /// /// 环境中移除了一个节点 /// /// public delegate void NodeRemoteHandler(NodeRemoteEventArgs eventArgs); public class NodeRemoteEventArgs : FlowEventArgs { public NodeRemoteEventArgs(string nodeGuid) { this.NodeGuid = nodeGuid; } /// /// 被移除节点的Guid /// public string NodeGuid { get; private set; } } public class StartNodeChangeEventArgs : FlowEventArgs { public StartNodeChangeEventArgs(string oldNodeGuid, string newNodeGuid) { this.OldNodeGuid = oldNodeGuid; this.NewNodeGuid = newNodeGuid; ; } /// /// 原来的起始节点Guid /// public string OldNodeGuid { get; private set; } /// /// 新的起始节点Guid /// public string NewNodeGuid { get; private set; } } /// /// 监视的节点数据发生变化 /// public class MonitorObjectEventArgs : FlowEventArgs { public enum ObjSourceType { NodeFlowData, IOCObj, } public MonitorObjectEventArgs(string nodeGuid, object monitorData, ObjSourceType objSourceType) { NodeGuid = nodeGuid; NewData = monitorData; ObjSource = objSourceType; } /// /// 中断的节点Guid /// public string NodeGuid { get; protected set; } public ObjSourceType ObjSource { get; protected set; } /// /// 新的数据 /// public object NewData { get; protected set; } } /// /// 节点中断状态改变事件参数 /// public class NodeInterruptStateChangeEventArgs : FlowEventArgs { public NodeInterruptStateChangeEventArgs(string nodeGuid, InterruptClass @class) { NodeGuid = nodeGuid; Class = @class; } /// /// 中断的节点Guid /// public string NodeGuid { get; protected set; } public InterruptClass Class { get; protected set; } } /// /// 节点触发了中断事件参数 /// public class InterruptTriggerEventArgs : FlowEventArgs { public enum InterruptTriggerType { /// /// 主动监视中断 /// Monitor, /// /// 表达式中断 /// Exp, /// /// 对象监视中断 /// Obj, } public InterruptTriggerEventArgs(string nodeGuid, string expression, InterruptTriggerType type) { this.NodeGuid = nodeGuid; this.Expression = expression; this.Type = type; } /// /// 中断的节点Guid /// public string NodeGuid { get; protected set; } public string Expression { get; protected set; } public InterruptTriggerType Type { get; protected set; } } #endregion /// /// IOC容器发生变化 /// public delegate void IOCMembersChangedHandler(); /// /// 流程事件签名基类 /// public class IOCMembersChangedEventArgs : FlowEventArgs { public enum EventType { /// /// 登记了类型 /// Registered, /// /// 构建了类型 /// Completeuild, } public IOCMembersChangedEventArgs(Type[] types, object[] dependencies, object[] unfinishedDependencies) { this.Types = types; this.Dependencies = dependencies; this.UnfinishedDependencies = unfinishedDependencies; } public Type[] Types { get; protected set; } public object[] Dependencies { get; private set; } public object[] UnfinishedDependencies { get; private set; } } public interface IFlowEnvironment { #region 属性 /// /// IOC容器 /// ISereinIOC IOC { get; } /// /// 环境名称 /// string EnvName { get; } /// /// 是否全局中断 /// bool IsGlobalInterrupt { get; } #endregion #region 事件 /// /// 加载Dll /// event LoadDLLHandler OnDllLoad; /// /// 项目加载完成 /// event ProjectLoadedHandler OnProjectLoaded; /// /// 节点连接属性改变事件 /// event NodeConnectChangeHandler OnNodeConnectChange; /// /// 节点创建事件 /// event NodeCreateHandler OnNodeCreate; /// /// 移除节点事件 /// event NodeRemoteHandler OnNodeRemote; /// /// 起始节点变化事件 /// event StartNodeChangeHandler OnStartNodeChange; /// /// 流程运行完成事件 /// event FlowRunCompleteHandler OnFlowRunComplete; /// /// 被监视的对象改变事件 /// event MonitorObjectChangeHandler OnMonitorObjectChange; /// /// 节点中断状态变化事件 /// event NodeInterruptStateChangeHandler OnNodeInterruptStateChange; /// /// 触发中断 /// event ExpInterruptTriggerHandler OnInterruptTrigger; #endregion #region Workbench /// /// 保存当前项目 /// /// SereinProjectData SaveProject(); /// /// 加载项目文件 /// /// /// void LoadProject(SereinProjectData projectFile, string filePath); /// /// 从文件中加载Dll /// /// void LoadDll(string dllPath); /// /// 清理加载的DLL(待更改) /// void ClearAll(); /// /// 获取方法描述 /// /// /// /// bool TryGetMethodDetails(string methodName, out MethodDetails md); /// /// 开始运行 /// Task StartAsync(); /// /// 从选定的节点开始运行 /// /// /// Task StartFlowInSelectNodeAsync(string startNodeGuid); /// /// 结束运行 /// void Exit(); /// /// 设置流程起点节点 /// /// void SetStartNode(string nodeGuid); /// /// 在两个节点之间创建连接关系 /// /// 起始节点Guid /// 目标节点Guid /// 连接类型 void ConnectNode(string fromNodeGuid, string toNodeGuid, ConnectionType connectionType); /// /// 创建节点/区域/基础控件 /// /// 节点/区域/基础控件 /// 节点绑定的方法说明( void CreateNode(NodeControlType nodeBase, Position position, MethodDetails methodDetails = null); /// /// 移除两个节点之间的连接关系 /// /// 起始节点 /// 目标节点 /// 连接类型 void RemoteConnect(string fromNodeGuid, string toNodeGuid, ConnectionType connectionType); /// /// 移除节点/区域/基础控件 /// /// 待移除的节点Guid void RemoteNode(string nodeGuid); /// /// 设置节点中断级别 /// /// 被中断的节点Guid /// 新的中断级别 /// bool SetNodeInterrupt(string nodeGuid, InterruptClass interruptClass); /// /// 添加作用于某个对象的中断表达式 /// /// /// /// bool AddInterruptExpression(object obj, string expression); /// /// 添加作用于指定节点的中断表达式 /// /// /// /// // bool AddInterruptExpression(string nodeGuid,string expression); // // 设置节点数据监视状态 // // 需要监视的节点Guid // 是否监视 // void SetNodeFLowDataMonitorState(string nodeGuid, bool isMonitor); /// /// 监视指定对象 /// /// 需要监视的对象 /// 是否启用监视 void SetMonitorObjState(object obj, bool isMonitor); /// /// 检查一个对象是否处于监听状态,如果是,则传出与该对象相关的表达式(用于中断),如果不是,则返回false。 /// /// 判断的对象 /// 表达式 /// bool CheckObjMonitorState(object obj, out List exps); /// /// 全局中断 /// /// /// /// Task GetOrCreateGlobalInterruptAsync(); #endregion #region Start /// /// 流程启动器调用,监视数据更新通知 /// /// 更新了数据的节点Guid /// 更新的数据 void MonitorObjectNotification(string nodeGuid, object monitorData, MonitorObjectEventArgs.ObjSourceType sourceType); /// /// 流程启动器调用,节点触发了中断 /// /// 被中断的节点Guid /// 被触发的表达式 /// 中断类型。0主动监视,1表达式 void TriggerInterrupt(string nodeGuid, string expression, InterruptTriggerEventArgs.InterruptTriggerType type); #endregion } }