diff --git a/Sources/Confidence/Confidence.swift b/Sources/Confidence/Confidence.swift index e0e4d255..8e5d8896 100644 --- a/Sources/Confidence/Confidence.swift +++ b/Sources/Confidence/Confidence.swift @@ -154,7 +154,8 @@ public class Confidence: ConfidenceEventSender { flagName: key, defaultValue: defaultValue, context: getContext(), - flagApplier: flagApplier + flagApplier: flagApplier, + debugLogger: debugLogger ) } } @@ -397,8 +398,7 @@ extension Confidence { let options = ConfidenceClientOptions( credentials: ConfidenceClientCredentials.clientSecret(secret: clientSecret), region: region, - timeoutIntervalForRequest: timeout, - debugLogger: debugLogger) + timeoutIntervalForRequest: timeout) let metadata = ConfidenceMetadata( name: sdkId, version: "1.0.1") // x-release-please-version diff --git a/Sources/Confidence/ConfidenceClientOptions.swift b/Sources/Confidence/ConfidenceClientOptions.swift index b46c797d..fe64d3bb 100644 --- a/Sources/Confidence/ConfidenceClientOptions.swift +++ b/Sources/Confidence/ConfidenceClientOptions.swift @@ -5,24 +5,17 @@ struct ConfidenceClientOptions { public var region: ConfidenceRegion public var initializationStrategy: InitializationStrategy public var timeoutIntervalForRequest: Double - private let debugLogger: DebugLogger? public init( credentials: ConfidenceClientCredentials, region: ConfidenceRegion? = nil, initializationStrategy: InitializationStrategy = .fetchAndActivate, - timeoutIntervalForRequest: Double, - debugLogger: DebugLogger? = nil + timeoutIntervalForRequest: Double ) { self.credentials = credentials self.region = region ?? .global self.initializationStrategy = initializationStrategy self.timeoutIntervalForRequest = timeoutIntervalForRequest - self.debugLogger = debugLogger - } - - func getLogger() -> DebugLogger? { - return debugLogger } } diff --git a/Sources/Confidence/DebugLogger.swift b/Sources/Confidence/DebugLogger.swift index fe7922c2..b5dbd92f 100644 --- a/Sources/Confidence/DebugLogger.swift +++ b/Sources/Confidence/DebugLogger.swift @@ -6,6 +6,7 @@ internal protocol DebugLogger { func logMessage(message: String, isWarning: Bool) func logFlags(action: String, flag: String) func logContext(action: String, context: ConfidenceStruct) + func logResolveDebugURL(flagName: String, context: ConfidenceStruct) } private extension Logger { @@ -15,6 +16,16 @@ private extension Logger { } internal class DebugLoggerImpl: DebugLogger { + private let encoder = JSONEncoder() + + func logResolveDebugURL(flagName: String, context: ConfidenceStruct) { + let ctxNetworkValue = TypeMapper.convert(structure: context) + if let ctxNetworkData = try? encoder.encode(ctxNetworkValue), + let ctxNetworkString = String(data: ctxNetworkData, encoding: .utf8) { + log(messageLevel: .DEBUG, message: "[Resolve Debug] https://app.confidence.spotify.com/flags/resolver-test?flag=flags/\(flagName)&context=\(ctxNetworkString)") + } + } + private let loggerLevel: LoggerLevel init(loggerLevel: LoggerLevel) { diff --git a/Sources/Confidence/FlagEvaluation.swift b/Sources/Confidence/FlagEvaluation.swift index d64e43ca..611aa26a 100644 --- a/Sources/Confidence/FlagEvaluation.swift +++ b/Sources/Confidence/FlagEvaluation.swift @@ -29,7 +29,8 @@ extension FlagResolution { flagName: String, defaultValue: T, context: ConfidenceStruct, - flagApplier: FlagApplier? = nil + flagApplier: FlagApplier? = nil, + debugLogger: DebugLogger? = nil ) -> Evaluation { do { let parsedKey = try FlagPath.getPath(for: flagName) @@ -44,6 +45,10 @@ extension FlagResolution { ) } + if let debugLogger = debugLogger { + debugLogger.logResolveDebugURL(flagName: parsedKey.flag, context: context) + } + if let evaluation = checkBackendErrors(resolvedFlag: resolvedFlag, defaultValue: defaultValue) { return evaluation } diff --git a/Sources/Confidence/RemoteResolveConfidenceClient.swift b/Sources/Confidence/RemoteResolveConfidenceClient.swift index a9747365..479dead8 100644 --- a/Sources/Confidence/RemoteResolveConfidenceClient.swift +++ b/Sources/Confidence/RemoteResolveConfidenceClient.swift @@ -26,25 +26,14 @@ class RemoteConfidenceResolveClient: ConfidenceResolveClient { // MARK: Resolver public func resolve(flags: [String], ctx: ConfidenceStruct) async throws -> ResolvesResult { - let ctxNetworkValue = TypeMapper.convert(structure: ctx) let request = ResolveFlagsRequest( flags: flags.map { "flags/\($0)" }, - evaluationContext: ctxNetworkValue, + evaluationContext: TypeMapper.convert(structure: ctx), clientSecret: options.credentials.getSecret(), apply: applyOnResolve, sdk: Sdk(id: metadata.name, version: metadata.version) ) - if let debugLogger = options.getLogger() { - let encoder = JSONEncoder() - if let jsonData = try? encoder.encode(ctxNetworkValue), - let jsonCtx = String(data: jsonData, encoding: .utf8) { - debugLogger.logMessage( - message: "[Resolve Debug] https://app.confidence.spotify.com/flags/resolver-test?context=\(jsonCtx)", - isWarning: false) - } - } - do { let result: HttpClientResult = try await self.httpClient.post(path: ":resolve", data: request) diff --git a/Tests/ConfidenceTests/Helpers/DebugLoggerFake.swift b/Tests/ConfidenceTests/Helpers/DebugLoggerFake.swift index db9ddb55..20d24a95 100644 --- a/Tests/ConfidenceTests/Helpers/DebugLoggerFake.swift +++ b/Tests/ConfidenceTests/Helpers/DebugLoggerFake.swift @@ -25,6 +25,10 @@ internal class DebugLoggerFake: DebugLogger { // no-op } + func logResolveDebugURL(flagName: String, context: ConfidenceStruct) { + // no-op + } + func getUploadBatchSuccessCount() -> Int { return uploadBatchSuccessCounter.get() }