mirror of
https://github.com/GeWuYou/GFramework.git
synced 2026-05-07 00:39:00 +08:00
- 清理 GFramework.Core 与 GFramework.Cqrs 中的大量低风险 Meziantou 警告 - 修复 GFramework.Godot 运行时中的 ConfigureAwait、StringComparison 与参数校验告警 - 调整 Core SourceGenerators 中的字符串比较、文件命名与局部长方法问题 - 拆分部分配置与缓存辅助类型文件以消除 file/type mismatch 告警 - 更新 warning reduction 跟踪与执行记录,保留下一批结构性告警的恢复点
73 lines
2.8 KiB
C#
73 lines
2.8 KiB
C#
// 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.Abstractions.Logging;
|
|
using GFramework.Cqrs.Abstractions.Cqrs;
|
|
|
|
namespace GFramework.Cqrs.Cqrs.Behaviors;
|
|
|
|
/// <summary>
|
|
/// 在 CQRS 请求管道中记录请求开始、完成、取消与失败日志。
|
|
/// </summary>
|
|
/// <typeparam name="TRequest">请求类型。</typeparam>
|
|
/// <typeparam name="TResponse">响应类型。</typeparam>
|
|
/// <remarks>
|
|
/// 该行为已迁移到 <c>GFramework.Cqrs.Cqrs.Behaviors</c> 命名空间,
|
|
/// 实现位于 <c>GFramework.Cqrs</c> 程序集,用于承载 CQRS runtime 细节并与旧层解耦。
|
|
/// </remarks>
|
|
public sealed class LoggingBehavior<TRequest, TResponse> : IPipelineBehavior<TRequest, TResponse>
|
|
where TRequest : IRequest<TResponse>
|
|
{
|
|
private readonly ILogger _logger =
|
|
LoggerFactoryResolver.Provider.CreateLogger(nameof(LoggingBehavior<TRequest, TResponse>));
|
|
|
|
/// <summary>
|
|
/// 执行日志包装后的下一段请求处理逻辑。
|
|
/// </summary>
|
|
/// <param name="message">当前请求消息。</param>
|
|
/// <param name="next">后续处理委托。</param>
|
|
/// <param name="cancellationToken">取消令牌。</param>
|
|
/// <returns>请求处理结果。</returns>
|
|
public async ValueTask<TResponse> Handle(
|
|
TRequest message,
|
|
MessageHandlerDelegate<TRequest, TResponse> next,
|
|
CancellationToken cancellationToken)
|
|
{
|
|
var requestName = typeof(TRequest).Name;
|
|
var start = Stopwatch.GetTimestamp();
|
|
|
|
_logger.Debug($"Handling {requestName}");
|
|
|
|
try
|
|
{
|
|
var response = await next(message, cancellationToken).ConfigureAwait(false);
|
|
|
|
var elapsed = Stopwatch.GetElapsedTime(start);
|
|
_logger.Debug($"Handled {requestName} successfully in {elapsed.TotalMilliseconds} ms");
|
|
|
|
return response;
|
|
}
|
|
catch (OperationCanceledException)
|
|
{
|
|
_logger.Warn($"Handling {requestName} was cancelled");
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
var elapsed = Stopwatch.GetElapsedTime(start);
|
|
_logger.Error($"Error handling {requestName} after {elapsed.TotalMilliseconds} ms", ex);
|
|
throw;
|
|
}
|
|
}
|
|
}
|