GFramework/GFramework.Core/Utility/AbstractContextUtility.cs
gewuyou ff553977e3 chore(license): 补齐 Apache-2.0 文件头治理
- 新增许可证文件头检查与修复脚本

- 补充维护者手动修复 PR 工作流和 CI 校验

- 更新贡献指南中的文件头说明

- 补齐仓库维护源码和配置文件的许可证声明
2026-05-03 19:39:49 +08:00

61 lines
1.7 KiB
C#

// Copyright (c) 2025-2026 GeWuYou
// SPDX-License-Identifier: Apache-2.0
using GFramework.Core.Abstractions.Logging;
using GFramework.Core.Abstractions.Utility;
using GFramework.Core.Logging;
using GFramework.Core.Rule;
namespace GFramework.Core.Utility;
/// <summary>
/// 抽象上下文工具类,提供上下文相关的通用功能实现
/// 继承自ContextAwareBase并实现IContextUtility接口
/// </summary>
public abstract class AbstractContextUtility : ContextAwareBase, IContextUtility
{
/// <summary>
/// 日志记录器
/// </summary>
protected ILogger Logger = null !;
/// <summary>
/// 初始化上下文工具类
/// </summary>
public void Initialize()
{
var name = GetType().Name;
// 获取上下文中的日志记录器
Logger = LoggerFactoryResolver.Provider.CreateLogger(name);
Logger.Debug($"Initializing Context Utility: {name}");
// 执行子类实现的初始化逻辑
OnInit();
// 记录初始化完成信息
Logger.Info($"Context Utility initialized: {name}");
}
/// <summary>
/// 销毁上下文工具类实例
/// </summary>
public void Destroy()
{
var name = GetType().Name;
Logger.Debug($"Destroying Context Utility: {name}");
OnDestroy();
Logger.Info($"Context Utility destroyed: {name}");
}
/// <summary>
/// 抽象初始化方法,由子类实现具体的初始化逻辑
/// </summary>
protected abstract void OnInit();
/// <summary>
/// 虚拟销毁方法,可由子类重写以实现自定义销毁逻辑
/// </summary>
protected virtual void OnDestroy()
{
}
}