2025-07-27 23:34:01 +08:00
|
|
|
|
using Serein.Library;
|
2025-05-31 12:15:01 +08:00
|
|
|
|
using Serein.Library.Api;
|
|
|
|
|
|
|
|
|
|
|
|
namespace Serein.NodeFlow.Model
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 节点基类
|
|
|
|
|
|
/// </summary>
|
2025-07-27 23:34:01 +08:00
|
|
|
|
public abstract partial class NodeModelBase : ISereinFlow
|
2025-05-31 12:15:01 +08:00
|
|
|
|
{
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 实体节点创建完成后调用的方法,调用时间早于 LoadInfo() 方法
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
public virtual void OnCreating()
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 保存自定义信息
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
|
public virtual NodeInfo SaveCustomData(NodeInfo nodeInfo)
|
|
|
|
|
|
{
|
|
|
|
|
|
return nodeInfo;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 加载自定义数据
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="nodeInfo"></param>
|
|
|
|
|
|
public virtual void LoadCustomData(NodeInfo nodeInfo)
|
|
|
|
|
|
{
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 执行节点对应的方法
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="context">流程上下文</param>
|
|
|
|
|
|
/// <param name="token"></param>
|
|
|
|
|
|
/// <param name="args">自定义参数</param>
|
|
|
|
|
|
/// <returns>节点传回数据对象</returns>
|
2025-07-23 16:20:41 +08:00
|
|
|
|
public virtual async Task<FlowResult> ExecutingAsync(IFlowContext context, CancellationToken token)
|
2025-05-31 12:15:01 +08:00
|
|
|
|
{
|
|
|
|
|
|
// 执行触发检查是否需要中断
|
|
|
|
|
|
if (DebugSetting.IsInterrupt)
|
|
|
|
|
|
{
|
2025-07-04 21:31:07 +08:00
|
|
|
|
context.Env.FlowControl.TriggerInterrupt(Guid, "", InterruptTriggerEventArgs.InterruptTriggerType.Monitor); // 通知运行环境该节点中断了
|
2025-05-31 12:15:01 +08:00
|
|
|
|
await DebugSetting.GetInterruptTask.Invoke();
|
|
|
|
|
|
SereinEnv.WriteLine(InfoType.INFO, $"[{this.MethodDetails?.MethodName}]中断已取消,开始执行后继分支");
|
|
|
|
|
|
if (token.IsCancellationRequested) { return null; }
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2025-07-26 19:36:54 +08:00
|
|
|
|
MethodDetails? md = MethodDetails;
|
2025-05-31 12:15:01 +08:00
|
|
|
|
if (md is null)
|
|
|
|
|
|
{
|
2025-07-26 19:36:54 +08:00
|
|
|
|
throw new Exception($"节点{Guid}不存在方法信息,请检查是否需要重写节点的ExecutingAsync");
|
2025-05-31 12:15:01 +08:00
|
|
|
|
}
|
|
|
|
|
|
if (!context.Env.TryGetDelegateDetails(md.AssemblyName, md.MethodName, out var dd)) // 流程运行到某个节点
|
|
|
|
|
|
{
|
|
|
|
|
|
throw new Exception($"节点{this.Guid}不存在对应委托");
|
|
|
|
|
|
}
|
2025-07-26 19:36:54 +08:00
|
|
|
|
|
2025-07-09 21:49:26 +08:00
|
|
|
|
if (md.IsStatic)
|
2025-05-31 12:15:01 +08:00
|
|
|
|
{
|
2025-07-09 21:49:26 +08:00
|
|
|
|
object[] args = await this.GetParametersAsync(context, token);
|
|
|
|
|
|
var result = await dd.InvokeAsync(null, args);
|
|
|
|
|
|
var flowReslt = new FlowResult(this.Guid, context, result);
|
|
|
|
|
|
return flowReslt;
|
2025-05-31 12:15:01 +08:00
|
|
|
|
}
|
2025-07-09 21:49:26 +08:00
|
|
|
|
else
|
|
|
|
|
|
{
|
2025-07-18 22:45:06 +08:00
|
|
|
|
var instance = Env.FlowControl.IOC.Get(md.ActingInstanceType);
|
2025-07-09 21:49:26 +08:00
|
|
|
|
if (instance is null)
|
|
|
|
|
|
{
|
2025-07-18 22:45:06 +08:00
|
|
|
|
Env.FlowControl.IOC.Register(md.ActingInstanceType).Build();
|
|
|
|
|
|
instance = Env.FlowControl.IOC.Get(md.ActingInstanceType);
|
2025-07-09 21:49:26 +08:00
|
|
|
|
}
|
|
|
|
|
|
object[] args = await this.GetParametersAsync(context, token);
|
|
|
|
|
|
var result = await dd.InvokeAsync(instance, args);
|
|
|
|
|
|
var flowReslt = new FlowResult(this.Guid, context, result);
|
|
|
|
|
|
return flowReslt;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2025-05-31 12:15:01 +08:00
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2025-07-09 21:49:26 +08:00
|
|
|
|
|
2025-05-31 12:15:01 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|