mirror of
https://github.com/GeWuYou/GFramework.git
synced 2026-03-22 18:52:08 +08:00
- 实现了从上下文感知对象获取指定类型服务的功能 - 添加了泛型约束确保服务类型为引用类型 - 集成了空值检查以提高代码健壮性 - 提供了详细的XML文档注释说明 - 扩展了IContextAware接口的功能范围
246 lines
10 KiB
C#
246 lines
10 KiB
C#
using GFramework.Core.Abstractions.command;
|
||
using GFramework.Core.Abstractions.environment;
|
||
using GFramework.Core.Abstractions.events;
|
||
using GFramework.Core.Abstractions.model;
|
||
using GFramework.Core.Abstractions.query;
|
||
using GFramework.Core.Abstractions.rule;
|
||
using GFramework.Core.Abstractions.system;
|
||
using GFramework.Core.Abstractions.utility;
|
||
|
||
namespace GFramework.Core.extensions;
|
||
|
||
/// <summary>
|
||
/// 提供对 IContextAware 接口的扩展方法
|
||
/// </summary>
|
||
public static class ContextAwareExtensions
|
||
{
|
||
/// <summary>
|
||
/// 从上下文感知对象中获取指定类型的服务
|
||
/// </summary>
|
||
/// <typeparam name="TService">要获取的服务类型</typeparam>
|
||
/// <param name="contextAware">实现 IContextAware 接口的上下文感知对象</param>
|
||
/// <returns>指定类型的服务实例,如果未找到则返回 null</returns>
|
||
/// <exception cref="ArgumentNullException">当 contextAware 参数为 null 时抛出</exception>
|
||
public static TService? GetService<TService>(this IContextAware contextAware) where TService : class
|
||
{
|
||
ArgumentNullException.ThrowIfNull(contextAware);
|
||
var context = contextAware.GetContext();
|
||
return context.GetService<TService>();
|
||
}
|
||
|
||
/// <summary>
|
||
/// 获取架构上下文中的指定系统
|
||
/// </summary>
|
||
/// <typeparam name="TSystem">目标系统类型</typeparam>
|
||
/// <param name="contextAware">实现 IContextAware 接口的对象</param>
|
||
/// <returns>指定类型的系统实例</returns>
|
||
/// <exception cref="ArgumentNullException">当 contextAware 为 null 时抛出</exception>
|
||
public static TSystem? GetSystem<TSystem>(this IContextAware contextAware) where TSystem : class, ISystem
|
||
{
|
||
ArgumentNullException.ThrowIfNull(contextAware);
|
||
var context = contextAware.GetContext();
|
||
return context.GetSystem<TSystem>();
|
||
}
|
||
|
||
|
||
/// <summary>
|
||
/// 获取架构上下文中的指定模型
|
||
/// </summary>
|
||
/// <typeparam name="TModel">目标模型类型</typeparam>
|
||
/// <param name="contextAware">实现 IContextAware 接口的对象</param>
|
||
/// <returns>指定类型的模型实例</returns>
|
||
/// <exception cref="ArgumentNullException">当 contextAware 为 null 时抛出</exception>
|
||
public static TModel? GetModel<TModel>(this IContextAware contextAware) where TModel : class, IModel
|
||
{
|
||
ArgumentNullException.ThrowIfNull(contextAware);
|
||
var context = contextAware.GetContext();
|
||
return context.GetModel<TModel>();
|
||
}
|
||
|
||
/// <summary>
|
||
/// 获取架构上下文中的指定工具
|
||
/// </summary>
|
||
/// <typeparam name="TUtility">目标工具类型</typeparam>
|
||
/// <param name="contextAware">实现 IContextAware 接口的对象</param>
|
||
/// <returns>指定类型的工具实例</returns>
|
||
/// <exception cref="ArgumentNullException">当 contextAware 为 null 时抛出</exception>
|
||
public static TUtility? GetUtility<TUtility>(this IContextAware contextAware) where TUtility : class, IUtility
|
||
{
|
||
ArgumentNullException.ThrowIfNull(contextAware);
|
||
var context = contextAware.GetContext();
|
||
return context.GetUtility<TUtility>();
|
||
}
|
||
|
||
/// <summary>
|
||
/// 发送一个查询请求
|
||
/// </summary>
|
||
/// <typeparam name="TResult">查询结果类型</typeparam>
|
||
/// <param name="contextAware">实现 IContextAware 接口的对象</param>
|
||
/// <param name="query">要发送的查询</param>
|
||
/// <returns>查询结果</returns>
|
||
/// <exception cref="ArgumentNullException">当 contextAware 或 query 为 null 时抛出</exception>
|
||
public static TResult SendQuery<TResult>(this IContextAware contextAware, IQuery<TResult> query)
|
||
{
|
||
ArgumentNullException.ThrowIfNull(contextAware);
|
||
ArgumentNullException.ThrowIfNull(query);
|
||
|
||
var context = contextAware.GetContext();
|
||
return context.SendQuery(query);
|
||
}
|
||
|
||
/// <summary>
|
||
/// 发送并异步执行一个无返回值的命令
|
||
/// </summary>
|
||
/// <param name="contextAware">实现 IContextAware 接口的对象</param>
|
||
/// <param name="command">要发送的命令</param>
|
||
/// <exception cref="ArgumentNullException">当 contextAware 或 command 为 null 时抛出</exception>
|
||
public static async Task SendCommandAsync(this IContextAware contextAware, IAsyncCommand command)
|
||
{
|
||
ArgumentNullException.ThrowIfNull(contextAware);
|
||
ArgumentNullException.ThrowIfNull(command);
|
||
|
||
var context = contextAware.GetContext();
|
||
await context.SendCommandAsync(command);
|
||
}
|
||
|
||
/// <summary>
|
||
/// 发送并异步执行一个带返回值的命令
|
||
/// </summary>
|
||
/// <typeparam name="TResult">命令执行结果类型</typeparam>
|
||
/// <param name="contextAware">实现 IContextAware 接口的对象</param>
|
||
/// <param name="command">要发送的命令</param>
|
||
/// <returns>命令执行结果</returns>
|
||
/// <exception cref="ArgumentNullException">当 contextAware 或 command 为 null 时抛出</exception>
|
||
public static async Task<TResult> SendCommandAsync<TResult>(this IContextAware contextAware,
|
||
IAsyncCommand<TResult> command)
|
||
{
|
||
ArgumentNullException.ThrowIfNull(contextAware);
|
||
ArgumentNullException.ThrowIfNull(command);
|
||
|
||
var context = contextAware.GetContext();
|
||
return await context.SendCommandAsync(command);
|
||
}
|
||
|
||
|
||
/// <summary>
|
||
/// 发送一个事件
|
||
/// </summary>
|
||
/// <typeparam name="TEvent">事件类型</typeparam>
|
||
/// <param name="contextAware">实现 IContextAware 接口的对象</param>
|
||
/// <exception cref="ArgumentNullException">当 contextAware 为 null 时抛出</exception>
|
||
public static void SendEvent<TEvent>(this IContextAware contextAware) where TEvent : new()
|
||
{
|
||
ArgumentNullException.ThrowIfNull(contextAware);
|
||
var context = contextAware.GetContext();
|
||
context.SendEvent<TEvent>();
|
||
}
|
||
|
||
/// <summary>
|
||
/// 发送一个具体的事件实例
|
||
/// </summary>
|
||
/// <typeparam name="TEvent">事件类型</typeparam>
|
||
/// <param name="contextAware">实现 IContextAware 接口的对象</param>
|
||
/// <param name="e">事件实例</param>
|
||
/// <exception cref="ArgumentNullException">当 contextAware 或 e 为 null 时抛出</exception>
|
||
public static void SendEvent<TEvent>(this IContextAware contextAware, TEvent e) where TEvent : class
|
||
{
|
||
ArgumentNullException.ThrowIfNull(contextAware);
|
||
ArgumentNullException.ThrowIfNull(e);
|
||
|
||
var context = contextAware.GetContext();
|
||
context.SendEvent(e);
|
||
}
|
||
|
||
/// <summary>
|
||
/// 发送一个事件
|
||
/// </summary>
|
||
/// <typeparam name="TResult">命令执行结果类型</typeparam>
|
||
/// <param name="contextAware">实现 IContextAware 接口的对象</param>
|
||
/// <param name="command">要发送的命令</param>
|
||
/// <returns>命令执行结果</returns>
|
||
/// <exception cref="ArgumentNullException">当 contextAware 或 command 为 null 时抛出</exception>
|
||
public static TResult SendCommand<TResult>(this IContextAware contextAware, ICommand<TResult> command)
|
||
{
|
||
ArgumentNullException.ThrowIfNull(contextAware);
|
||
ArgumentNullException.ThrowIfNull(command);
|
||
|
||
var context = contextAware.GetContext();
|
||
return context.SendCommand(command);
|
||
}
|
||
|
||
/// <summary>
|
||
/// 发送一个无返回结果的命令
|
||
/// </summary>
|
||
/// <param name="contextAware">实现 IContextAware 接口的对象</param>
|
||
/// <param name="command">要发送的命令</param>
|
||
/// <exception cref="ArgumentNullException">当 contextAware 或 command 为 null 时抛出</exception>
|
||
public static void SendCommand(this IContextAware contextAware, ICommand command)
|
||
{
|
||
ArgumentNullException.ThrowIfNull(contextAware);
|
||
ArgumentNullException.ThrowIfNull(command);
|
||
|
||
var context = contextAware.GetContext();
|
||
context.SendCommand(command);
|
||
}
|
||
|
||
|
||
/// <summary>
|
||
/// 注册事件处理器
|
||
/// </summary>
|
||
/// <typeparam name="TEvent">事件类型</typeparam>
|
||
/// <param name="contextAware">实现 IContextAware 接口的对象</param>
|
||
/// <param name="handler">事件处理委托</param>
|
||
/// <returns>事件注销接口</returns>
|
||
public static IUnRegister RegisterEvent<TEvent>(this IContextAware contextAware, Action<TEvent> handler)
|
||
{
|
||
ArgumentNullException.ThrowIfNull(contextAware);
|
||
ArgumentNullException.ThrowIfNull(handler);
|
||
|
||
var context = contextAware.GetContext();
|
||
return context.RegisterEvent(handler);
|
||
}
|
||
|
||
/// <summary>
|
||
/// 取消对某类型事件的监听
|
||
/// </summary>
|
||
/// <typeparam name="TEvent">事件类型</typeparam>
|
||
/// <param name="contextAware">实现 IContextAware 接口的对象</param>
|
||
/// <param name="onEvent">之前绑定的事件处理器</param>
|
||
public static void UnRegisterEvent<TEvent>(this IContextAware contextAware, Action<TEvent> onEvent)
|
||
{
|
||
ArgumentNullException.ThrowIfNull(contextAware);
|
||
ArgumentNullException.ThrowIfNull(onEvent);
|
||
|
||
// 获取上下文对象并取消事件注册
|
||
var context = contextAware.GetContext();
|
||
context.UnRegisterEvent(onEvent);
|
||
}
|
||
|
||
|
||
/// <summary>
|
||
/// 获取指定类型的环境对象
|
||
/// </summary>
|
||
/// <typeparam name="T">要获取的环境对象类型</typeparam>
|
||
/// <param name="contextAware">上下文感知对象</param>
|
||
/// <returns>指定类型的环境对象,如果无法转换则返回null</returns>
|
||
public static T? GetEnvironment<T>(this IContextAware contextAware) where T : class
|
||
{
|
||
ArgumentNullException.ThrowIfNull(contextAware);
|
||
// 获取上下文对象并返回其环境
|
||
var context = contextAware.GetContext();
|
||
return context.GetEnvironment() as T;
|
||
}
|
||
|
||
/// <summary>
|
||
/// 获取环境对象
|
||
/// </summary>
|
||
/// <param name="contextAware">上下文感知对象</param>
|
||
/// <returns>环境对象</returns>
|
||
public static IEnvironment GetEnvironment(this IContextAware contextAware)
|
||
{
|
||
ArgumentNullException.ThrowIfNull(contextAware);
|
||
// 获取上下文对象并返回其环境
|
||
var context = contextAware.GetContext();
|
||
return context.GetEnvironment();
|
||
}
|
||
} |