Proyectos de Subversion Iphone Microlearning

Rev

Autoría | Ultima modificación | Ver Log |

// Copyright 2020 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/Foundation.h>

#import "FIRTrace.h"

/**
 * This class allows you to configure the Firebase Performance Reporting SDK. It also provides the
 * interfaces to create timers and enable or disable automatic metrics capture.
 *
 * This SDK uses a Firebase Installations ID to identify the app instance and periodically sends
 * data to the Firebase backend. (see `[FIRInstallations installationIDWithCompletion:]`).
 * To stop the periodic sync, call `[FIRInstallations deleteWithCompletion:]` and
 * either disable this SDK or set FIRPerformance.dataCollectionEnabled to NO.
 */
NS_EXTENSION_UNAVAILABLE("FirebasePerformance does not support app extensions at this time.")
NS_SWIFT_NAME(Performance)
@interface FIRPerformance : NSObject

/**
 * Controls the capture of performance data. When this value is set to NO, none of the performance
 * data will sent to the server. Default is YES.
 *
 * This setting is persisted, and is applied on future invocations of your application. Once
 * explicitly set, it overrides any settings in your Info.plist.
 */
@property(nonatomic, assign, getter=isDataCollectionEnabled) BOOL dataCollectionEnabled;

/**
 * Controls the instrumentation of the app to capture performance data. Setting this value to NO has
 * immediate effect only if it is done so before calling [FIRApp configure]. Otherwise it takes
 * effect after the app starts again the next time.
 *
 * If set to NO, the app will not be instrumented to collect performance
 * data (in scenarios like app_start, networking monitoring). Default is YES.
 *
 * This setting is persisted, and is applied on future invocations of your application. Once
 * explicitly set, it overrides any settings in your Info.plist.
 */
@property(nonatomic, assign, getter=isInstrumentationEnabled) BOOL instrumentationEnabled;

/** @return The shared instance. */
+ (nonnull instancetype)sharedInstance NS_SWIFT_NAME(sharedInstance());

/**
 * Creates an instance of FIRTrace after creating the shared instance of FIRPerformance. The trace
 * will automatically be started on a successful creation of the instance. The |name| of the trace
 * cannot be an empty string.
 *
 * @param name The name of the Trace.
 * @return The FIRTrace object.
 */
+ (nullable FIRTrace *)startTraceWithName:(nonnull NSString *)name NS_SWIFT_NAME(startTrace(name:));

/**
 * Creates an instance of FIRTrace. This API does not start the trace. To start the trace, use the
 * -start API on the returned |FIRTrace| object. The |name| cannot be an empty string.
 *
 * @param name The name of the Trace.
 * @return The FIRTrace object.
 */
- (nullable FIRTrace *)traceWithName:(nonnull NSString *)name NS_SWIFT_NAME(trace(name:));

@end