Files
serein-flow/Library/Api/IDynamicContext.cs

111 lines
3.5 KiB
C#
Raw Normal View History

using Serein.Library;
using Serein.Library.Utils;
using System;
2024-11-02 16:48:40 +08:00
using System.Collections.Generic;
using System.Threading.Tasks;
namespace Serein.Library.Api
{
/// <summary>
2024-10-11 19:31:34 +08:00
/// 流程上下文,包含运行环境接口,可以通过注册环境事件或调用环境接口,实现在流程运行时更改流程行为。
/// </summary>
public interface IDynamicContext
{
2024-12-21 20:47:31 +08:00
/// <summary>
/// 标识流程
/// </summary>
string Guid {get; }
/// <summary>
2024-10-11 19:31:34 +08:00
/// 运行环境包含IOC容器。
/// </summary>
IFlowEnvironment Env { get; }
/// <summary>
/// 是否正在运行
/// </summary>
RunState RunState { get; }
2024-11-02 16:48:40 +08:00
/// <summary>
2024-10-28 21:52:45 +08:00
/// 下一个要执行的节点类别
/// </summary>
ConnectionInvokeType NextOrientation { get; set; }
/// <summary>
/// 运行时异常信息
/// </summary>
Exception ExceptionOfRuning { get; set; }
/// <summary>
/// 获取节点的运行时参数数据
/// </summary>
/// <param name="nodeModel">节点</param>
/// <param name="index">第几个参数</param>
/// <param name="data">数据</param>
void SetParamsTempData(string nodeModel, int index, object data);
/// <summary>
/// 获取节点的运行时参数数据
/// </summary>
/// <param name="nodeModel">节点</param>
/// <param name="index">第几个参数</param>
/// <param name="data">获取到的参数</param>
bool TryGetParamsTempData(string nodeModel, int index, out object data);
2024-10-28 21:52:45 +08:00
/// <summary>
/// 设置节点的运行时上一节点,用以多线程中隔开不同流程的数据
/// </summary>
/// <param name="currentNodeModel">当前节点</param>
/// <param name="PreviousNode">运行时上一节点</param>
void SetPreviousNode(string currentNodeModel, string PreviousNode);
2024-10-28 21:52:45 +08:00
/// <summary>
/// 获取当前节点的运行时上一节点,用以流程中获取数据
/// </summary>
/// <param name="currentNodeModel"></param>
/// <returns></returns>
string GetPreviousNode(string currentNodeModel);
2024-10-28 21:52:45 +08:00
/// <summary>
/// 获取节点的数据(当前节点需要获取上一节点数据时,需要从 运行时上一节点 的Guid 通过这个方法进行获取
/// </summary>
/// <param name="nodeModel"></param>
/// <returns></returns>
FlowResult GetFlowData(string nodeModel);
2024-10-28 21:52:45 +08:00
/// <summary>
/// 上一节点数据透传到下一节点
/// </summary>
/// <param name="nodeModel"></param>
FlowResult TransmissionData(string nodeModel);
2024-10-28 21:52:45 +08:00
/// <summary>
/// 添加或更新当前节点的数据
/// </summary>
/// <param name="nodeModel"></param>
/// <param name="flowData"></param>
2025-07-07 20:40:24 +08:00
void AddOrUpdateFlowData(string nodeModel, FlowResult flowData);
/// <summary>
/// 添加或更新当前节点的数据
/// </summary>
/// <param name="nodeModel"></param>
/// <param name="data"></param>
void AddOrUpdate(string nodeModel, object data);
/// <summary>
/// 重置流程状态(用于对象池回收)
/// </summary>
void Reset();
/// <summary>
2024-11-02 16:48:40 +08:00
/// 用以提前结束当前上下文流程的运行
/// </summary>
2024-10-27 00:54:10 +08:00
void Exit();
}
}