Files
real-e-party-iOS/YuMi/E-P/Common/EPConfigManager.swift
edwinQQQ 681b011c99 refactor: 更新 AppDelegate 和模块导入以简化配置管理
主要变更:
1. 移除不必要的模块导入,简化 AppDelegate 中的代码结构。
2. 引入新的 EPConfigManager 和 EPNIMManager,统一配置管理和 NIMSDK 初始化逻辑。
3. 更新相关方法以使用 block 回调,提升代码的可读性和维护性。
4. 新增 EPClientAPIBridge 和相关配置文件,增强项目的模块化。

此更新旨在提升代码的可维护性,减少冗余实现,确保配置管理的一致性。
2025-10-20 18:07:44 +08:00

134 lines
4.2 KiB
Swift
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

//
// EPConfigManager.swift
// YuMi
//
// Cold boot configuration manager for client/init and client/config flows
//
import Foundation
@objc final class EPConfigManager: NSObject {
@objc static let shared = EPConfigManager()
// MARK: - State
@objc private(set) var isInitReady: Bool = false
@objc private(set) var isConfigReady: Bool = false
@objc private(set) var isUsingPersistedInit: Bool = false
//
@objc private(set) var initModelRaw: [String: Any]? = nil
@objc private(set) var configModelRaw: [String: Any]? = nil
//
@objc private(set) var clientDataModel: ClientDataModel? = nil
private var hasStarted = false
//
private var successCallback: (() -> Void)?
private var failureCallback: ((String) -> Void)?
// MARK: - Public API
@objc(startColdBootWithOnSuccess:onFailure:)
func startColdBoot(
onSuccess: @escaping () -> Void,
onFailure: @escaping (String) -> Void
) {
guard !hasStarted else {
//
if isInitReady && isConfigReady {
onSuccess()
} else if !isInitReady {
onFailure("配置初始化失败")
}
return
}
hasStarted = true
//
self.successCallback = onSuccess
self.failureCallback = onFailure
runClientInitWithRetry(maxRetry: 5, interval: 1.0)
}
// MARK: - Flow
private func runClientInitWithRetry(maxRetry: Int, interval: TimeInterval) {
attemptClientInit(remaining: maxRetry, interval: interval)
}
private func attemptClientInit(remaining: Int, interval: TimeInterval) {
EPConfigAPI.clientInit { [weak self] data, code, msg in
guard let self = self else { return }
if code == 200, let dict = data {
self.onInitSuccess(dict)
self.runClientConfig()
} else if remaining > 0 {
DispatchQueue.main.asyncAfter(deadline: .now() + interval) {
self.attemptClientInit(remaining: remaining - 1, interval: interval)
}
} else {
self.onInitExhausted()
}
}
}
private func onInitSuccess(_ dict: [String: Any]) {
// 1.
let model = ClientDataModel.model(withJSON: dict)
self.clientDataModel = model
// 2. ClientConfig
ClientConfig.share().configInfo = model
// 3.
_ = EPConfigStorage.saveInit(dict)
// 4.
isUsingPersistedInit = false
initModelRaw = dict
isInitReady = true
// 5. client/config
runClientConfig()
}
private func onInitExhausted() {
if let persistedDict = EPConfigStorage.loadInit() as? [String: Any] {
// 使
let model = ClientDataModel.model(withJSON: persistedDict)
self.clientDataModel = model
ClientConfig.share().configInfo = model
isUsingPersistedInit = true
initModelRaw = persistedDict
isInitReady = true
//
runClientConfig()
} else {
//
failureCallback?("网络异常,请稍后重新启动应用")
}
}
private func runClientConfig() {
EPConfigAPI.clientConfig { [weak self] data, code, msg in
guard let self = self else { return }
if code == 200 {
// client/config
self.isConfigReady = true
self.successCallback?()
} else {
// client/config init
self.isConfigReady = true
self.successCallback?()
}
}
}
}
// Notification