// Copyright (c) 2026 GeWuYou
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
using GFramework.Core.Rule;
using Mediator;
namespace GFramework.Core.CQRS.Command;
///
/// 抽象命令处理器基类
/// 继承自ContextAwareBase并实现ICommandHandler接口,为具体的命令处理器提供基础功能
///
/// 命令类型
public abstract class AbstractCommandHandler : ContextAwareBase, ICommandHandler
where TCommand : ICommand
{
///
/// 处理指定的命令
/// 由具体的命令处理器子类实现命令处理逻辑
///
/// 要处理的命令对象
/// 取消令牌,用于取消操作
/// 表示异步操作完成的ValueTask,返回Unit类型表示无返回值
public abstract ValueTask Handle(TCommand command, CancellationToken cancellationToken);
}
///
/// 抽象命令处理器基类(带返回值版本)
/// 继承自ContextAwareBase并实现ICommandHandler接口,为具体的命令处理器提供基础功能
/// 支持泛型命令和结果类型,实现CQRS模式中的命令处理
///
/// 命令类型,必须实现ICommand接口
/// 命令执行结果类型
public abstract class AbstractCommandHandler : ContextAwareBase, ICommandHandler
where TCommand : ICommand
{
///
/// 处理指定的命令并返回结果
/// 由具体的命令处理器子类实现命令处理逻辑
///
/// 要处理的命令对象
/// 取消令牌,用于取消操作
/// 表示异步操作完成的ValueTask,包含命令执行结果
public abstract ValueTask Handle(TCommand command, CancellationToken cancellationToken);
}