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
}
}