From 9a783f3caa7586c018572b45f1c25d2edd3346c3 Mon Sep 17 00:00:00 2001 From: GeWuYou <95328647+GeWuYou@users.noreply.github.com> Date: Sat, 14 Feb 2026 13:39:01 +0800 Subject: [PATCH] =?UTF-8?q?feat(cqrs):=20=E6=B7=BB=E5=8A=A0=E6=B5=81?= =?UTF-8?q?=E5=BC=8F=E5=91=BD=E4=BB=A4=E3=80=81=E6=9F=A5=E8=AF=A2=E5=92=8C?= =?UTF-8?q?=E8=AF=B7=E6=B1=82=E5=A4=84=E7=90=86=E5=99=A8=E5=9F=BA=E7=B1=BB?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - 新增 AbstractStreamCommandHandler 基类支持流式命令处理 - 新增 AbstractStreamQueryHandler 基类支持流式查询处理 - 新增 AbstractStreamRequestHandler 基类支持流式请求处理 - 所有基类继承 ContextAwareBase 并实现对应的流式处理器接口 - 提供统一的异步可枚举响应序列处理机制 - 支持取消令牌用于控制流式操作的执行过程 --- .../command/AbstractStreamCommandHandler.cs | 38 +++++++++++++++++++ .../cqrs/query/AbstractStreamQueryHandler.cs | 38 +++++++++++++++++++ .../request/AbstractStreamRequestHandler.cs | 38 +++++++++++++++++++ 3 files changed, 114 insertions(+) create mode 100644 GFramework.Core/cqrs/command/AbstractStreamCommandHandler.cs create mode 100644 GFramework.Core/cqrs/query/AbstractStreamQueryHandler.cs create mode 100644 GFramework.Core/cqrs/request/AbstractStreamRequestHandler.cs diff --git a/GFramework.Core/cqrs/command/AbstractStreamCommandHandler.cs b/GFramework.Core/cqrs/command/AbstractStreamCommandHandler.cs new file mode 100644 index 0000000..c5f3f04 --- /dev/null +++ b/GFramework.Core/cqrs/command/AbstractStreamCommandHandler.cs @@ -0,0 +1,38 @@ +// 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并实现IStreamCommandHandler接口,为具体的流式命令处理器提供基础功能 +/// 支持流式处理命令并产生异步可枚举的响应序列 +/// +/// 流式命令类型,必须实现IStreamCommand接口 +/// 流式命令响应元素类型 +public abstract class AbstractStreamCommandHandler : ContextAwareBase, + IStreamCommandHandler + where TCommand : IStreamCommand +{ + /// + /// 处理流式命令并返回异步可枚举的响应序列 + /// 由具体的流式命令处理器子类实现流式处理逻辑 + /// + /// 要处理的流式命令对象 + /// 取消令牌,用于取消流式处理操作 + /// 异步可枚举的响应序列,每个元素类型为TResponse + public abstract IAsyncEnumerable Handle(TCommand command, CancellationToken cancellationToken); +} \ No newline at end of file diff --git a/GFramework.Core/cqrs/query/AbstractStreamQueryHandler.cs b/GFramework.Core/cqrs/query/AbstractStreamQueryHandler.cs new file mode 100644 index 0000000..a7c4eb0 --- /dev/null +++ b/GFramework.Core/cqrs/query/AbstractStreamQueryHandler.cs @@ -0,0 +1,38 @@ +// 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.query; + +/// +/// 抽象流式查询处理器基类 +/// 继承自ContextAwareBase并实现IStreamQueryHandler接口,为具体的流式查询处理器提供基础功能 +/// 支持流式处理查询并产生异步可枚举的响应序列,适用于大数据量或实时数据查询场景 +/// +/// 流式查询类型,必须实现IStreamQuery接口 +/// 流式查询响应元素类型 +public abstract class AbstractStreamQueryHandler : ContextAwareBase, + IStreamQueryHandler + where TQuery : IStreamQuery +{ + /// + /// 处理流式查询并返回异步可枚举的响应序列 + /// 由具体的流式查询处理器子类实现流式查询处理逻辑 + /// + /// 要处理的流式查询对象 + /// 取消令牌,用于取消流式查询操作 + /// 异步可枚举的响应序列,每个元素类型为TResponse + public abstract IAsyncEnumerable Handle(TQuery query, CancellationToken cancellationToken); +} \ No newline at end of file diff --git a/GFramework.Core/cqrs/request/AbstractStreamRequestHandler.cs b/GFramework.Core/cqrs/request/AbstractStreamRequestHandler.cs new file mode 100644 index 0000000..a6cdd31 --- /dev/null +++ b/GFramework.Core/cqrs/request/AbstractStreamRequestHandler.cs @@ -0,0 +1,38 @@ +// 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.request; + +/// +/// 抽象流式请求处理器基类 +/// 继承自ContextAwareBase并实现IStreamRequestHandler接口,为具体的流式请求处理器提供基础功能 +/// 支持流式处理请求并产生异步可枚举的响应序列,适用于需要逐步返回结果的请求处理场景 +/// +/// 流式请求类型,必须实现IStreamRequest接口 +/// 流式请求响应元素类型 +public abstract class AbstractStreamRequestHandler : ContextAwareBase, + IStreamRequestHandler + where TRequest : IStreamRequest +{ + /// + /// 处理流式请求并返回异步可枚举的响应序列 + /// 由具体的流式请求处理器子类实现流式请求处理逻辑 + /// + /// 要处理的流式请求对象 + /// 取消令牌,用于取消流式请求操作 + /// 异步可枚举的响应序列,每个元素类型为TResponse + public abstract IAsyncEnumerable Handle(TRequest request, CancellationToken cancellationToken); +} \ No newline at end of file