| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354 |
- //
- // Copyright 2022 Google LLC
- //
- // 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.
- import Foundation
- internal import GoogleDataTransport
- protocol EventGDTLoggerProtocol: Sendable {
- func logEvent(event: SessionStartEvent, completion: @escaping (Result<Void, Error>) -> Void)
- }
- ///
- /// EventGDTLogger is responsible for
- /// 1) Creating GDT Events and logging them to the GoogleDataTransport SDK
- /// 2) Handling debugging situations (eg. running in Simulator or printing the event to console)
- ///
- final class EventGDTLogger: EventGDTLoggerProtocol {
- let googleDataTransport: GoogleDataTransportProtocol
- let devEventConsoleLogger: EventGDTLoggerProtocol
- init(googleDataTransport: GoogleDataTransportProtocol,
- devEventConsoleLogger: EventGDTLoggerProtocol = DevEventConsoleLogger()) {
- self.googleDataTransport = googleDataTransport
- self.devEventConsoleLogger = devEventConsoleLogger
- }
- /// Logs the event to FireLog, taking into account debugging cases such as running
- /// in simulator.
- func logEvent(event: SessionStartEvent, completion: @escaping (Result<Void, Error>) -> Void) {
- let gdtEvent = googleDataTransport.eventForTransport()
- gdtEvent.dataObject = event
- gdtEvent.qosTier = GDTCOREventQoS.qosDefault
- #if targetEnvironment(simulator)
- Logger.logDebug("Logging events using fast QOS due to running on a simulator")
- gdtEvent.qosTier = GDTCOREventQoS.qoSFast
- #endif // targetEnvironment(simulator)
- devEventConsoleLogger.logEvent(event: event) { _ in }
- googleDataTransport.logGDTEvent(event: gdtEvent, completion: completion)
- }
- }
|