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