FPRGDTLogger.m 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. // Copyright 2020 Google LLC
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. #import "FirebasePerformance/Sources/Loggers/FPRGDTLogger.h"
  15. #import "FirebasePerformance/Sources/Loggers/FPRGDTLogger_Private.h"
  16. #import "FirebasePerformance/Sources/Configurations/FPRConfigurations.h"
  17. #import "FirebasePerformance/Sources/Loggers/FPRGDTEvent.h"
  18. #import "FirebasePerformance/Sources/Loggers/FPRGDTLogSampler.h"
  19. #import "FirebasePerformance/Sources/Loggers/FPRGDTRateLimiter.h"
  20. #import <GoogleDataTransport/GoogleDataTransport.h>
  21. #import "FirebasePerformance/Sources/Protogen/nanopb/perf_metric.nanopb.h"
  22. @implementation FPRGDTLogger
  23. - (instancetype)initWithLogSource:(NSInteger)logSource {
  24. if (self = [super init]) {
  25. _logSource = logSource;
  26. _queue = dispatch_queue_create("com.google.FPRGDTLogger", DISPATCH_QUEUE_SERIAL);
  27. _configurations = [FPRConfigurations sharedInstance];
  28. FPRGDTLogSampler *logSampler = [[FPRGDTLogSampler alloc] init];
  29. FPRGDTRateLimiter *rateLimiter = [[FPRGDTRateLimiter alloc] init];
  30. _gdtfllTransport = [[GDTCORTransport alloc] initWithMappingID:@(logSource).stringValue
  31. transformers:@[ logSampler, rateLimiter ]
  32. target:kGDTCORTargetFLL];
  33. _isSimulator = NO;
  34. // If app is running on simulator, environment variable SIMULATOR_UDID exists.
  35. // Otherwise, SIMULATOR_UDID is not provided when app is running on real device.
  36. // For development, developers can dispatch performance events immediately if
  37. // they are running app on simulator, so it can expedite development process.
  38. if ([[[NSProcessInfo processInfo] environment] objectForKey:@"SIMULATOR_UDID"]) {
  39. _isSimulator = YES;
  40. }
  41. _instanceSeed = -1.0; // -1.0 means instanceSeed has not been computed.
  42. }
  43. return self;
  44. }
  45. - (void)logEvent:(firebase_perf_v1_PerfMetric)event {
  46. GDTCORTransport *eventTransporter = self.gdtfllTransport;
  47. dispatch_async(self.queue, ^{
  48. GDTCOREvent *gdtEvent = [eventTransporter eventForTransport];
  49. if (self.isSimulator) {
  50. gdtEvent.qosTier = GDTCOREventQoSFast;
  51. } else {
  52. gdtEvent.qosTier = GDTCOREventQosDefault;
  53. }
  54. gdtEvent.dataObject = [FPRGDTEvent gdtEventForPerfMetric:event];
  55. [eventTransporter sendDataEvent:gdtEvent];
  56. });
  57. }
  58. @end