using GFramework.Core.Abstractions.query;
using GFramework.Core.Abstractions.rule;
namespace GFramework.Core.extensions;
///
/// 提供对 IContextAware 接口的查询执行扩展方法
///
public static class ContextAwareQueryExtensions
{
///
/// [Mediator] 发送查询的同步版本(不推荐,仅用于兼容性)
///
/// 查询响应类型
/// 实现 IContextAware 接口的对象
/// 要发送的查询对象
/// 查询结果
/// 当 contextAware 或 query 为 null 时抛出
public static TResponse SendQuery(this IContextAware contextAware, Mediator.IQuery query)
{
ArgumentNullException.ThrowIfNull(contextAware);
ArgumentNullException.ThrowIfNull(query);
var context = contextAware.GetContext();
return context.SendQuery(query);
}
///
/// 发送一个查询请求
///
/// 查询结果类型
/// 实现 IContextAware 接口的对象
/// 要发送的查询
/// 查询结果
/// 当 contextAware 或 query 为 null 时抛出
public static TResult SendQuery(this IContextAware contextAware, Abstractions.query.IQuery query)
{
ArgumentNullException.ThrowIfNull(contextAware);
ArgumentNullException.ThrowIfNull(query);
var context = contextAware.GetContext();
return context.SendQuery(query);
}
///
/// [Mediator] 异步发送查询并返回结果
///
/// 查询响应类型
/// 实现 IContextAware 接口的对象
/// 要发送的查询对象
/// 取消令牌,用于取消操作
/// 包含查询结果的ValueTask
/// 当 contextAware 或 query 为 null 时抛出
public static ValueTask SendQueryAsync(this IContextAware contextAware,
Mediator.IQuery query, CancellationToken cancellationToken = default)
{
ArgumentNullException.ThrowIfNull(contextAware);
ArgumentNullException.ThrowIfNull(query);
var context = contextAware.GetContext();
return context.SendQueryAsync(query, cancellationToken);
}
///
/// 异步发送一个查询请求
///
/// 查询结果类型
/// 实现 IContextAware 接口的对象
/// 要发送的异步查询
/// 查询结果
/// 当 contextAware 或 query 为 null 时抛出
public static async Task SendQueryAsync(this IContextAware contextAware,
IAsyncQuery query)
{
ArgumentNullException.ThrowIfNull(contextAware);
ArgumentNullException.ThrowIfNull(query);
var context = contextAware.GetContext();
return await context.SendQueryAsync(query);
}
}