| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203 |
- // 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>
- /**
- * Configuration flags retrieved from Firebase Remote Configuration.
- */
- @interface FPRRemoteConfigFlags : NSObject
- /**
- * The name of the name space for which the remote config flags are fetched.
- */
- @property(nonatomic, readonly, nonnull) NSString *remoteConfigNamespace;
- #pragma mark - Instance methods
- - (nullable instancetype)init NS_UNAVAILABLE;
- /** Singleton instance of Firebase Remote Configuration flags. */
- + (nullable instancetype)sharedInstance;
- /**
- * Initiate a fetch of the flags from Firebase Remote Configuration and updates the configurations
- * at the end of the fetch.
- *
- * @note This method is throttled to initiate a fetch once in 12 hours. So, calling this method does
- * not guarantee a fetch from Firebase Remote Config.
- */
- - (void)update;
- #pragma mark - General configs.
- /**
- * Returns if performance SDK is enabled.
- * Name in remote config: "fpr_enabled".
- *
- * @param sdkEnabled Default value to be returned if values does not exist in remote config.
- * @return Specifies if SDK should be enabled or not.
- */
- - (BOOL)performanceSDKEnabledWithDefaultValue:(BOOL)sdkEnabled;
- /**
- * Returns set of versions on which SDK is disabled.
- * Name in remote config: "fpr_disabled_ios_versions".
- *
- * @param sdkVersions Default value to be returned if values does not exist in remote config.
- * @return SDK versions list where the SDK has to be disabled.
- */
- - (nullable NSSet<NSString *> *)sdkDisabledVersionsWithDefaultValue:
- (nullable NSSet<NSString *> *)sdkVersions;
- /**
- * Returns the log source against which the events will be recorded.
- * Name in remote config: "fpr_log_source"
- *
- * @param logSource Default value to be returned if values does not exist in remote config.
- * @return Log source towards which the events would be logged.
- */
- - (int)logSourceWithDefaultValue:(int)logSource;
- #pragma mark - Rate limiting related configs.
- /**
- * Returns the time limit for which the event are measured against. Measured in seconds.
- * Name in remote config: "fpr_rl_time_limit_sec"
- *
- * @param durationInSeconds Default value to be returned if values does not exist in remote config.
- * @return Time limit used for rate limiting in seconds.
- */
- - (int)rateLimitTimeDurationWithDefaultValue:(int)durationInSeconds;
- /**
- * Returns the number of trace events that are allowed when the app is in foreground.
- * Name in remote config: "fpr_rl_trace_event_count_fg"
- *
- * @param eventCount Default value to be returned if values does not exist in remote config.
- * @return Trace count limit when the app is in foreground.
- */
- - (int)rateLimitTraceCountInForegroundWithDefaultValue:(int)eventCount;
- /**
- * Returns the number of trace events that are allowed when the app is in background.
- * Name in remote config: "fpr_rl_trace_event_count_bg"
- *
- * @param eventCount Default value to be returned if values does not exist in remote config.
- * @return Trace count limit when the app is in background.
- */
- - (int)rateLimitTraceCountInBackgroundWithDefaultValue:(int)eventCount;
- /**
- * Returns the number of network trace events that are allowed when the app is in foreground.
- * Name in remote config: "fpr_rl_network_request_event_count_fg"
- *
- * @param eventCount Default value to be returned if values does not exist in remote config.
- * @return Network request count limit when the app is in foreground.
- */
- - (int)rateLimitNetworkRequestCountInForegroundWithDefaultValue:(int)eventCount;
- /**
- * Returns the number of network trace events that are allowed when the app is in background.
- * Name in remote config: "fpr_rl_network_request_event_count_bg"
- *
- * @param eventCount Default value to be returned if values does not exist in remote config.
- * @return Network request count limit when the app is in background.
- */
- - (int)rateLimitNetworkRequestCountInBackgroundWithDefaultValue:(int)eventCount;
- #pragma mark - Sampling related configs.
- /**
- * Returns the sampling rate for traces. A value of 1 means all the events must be sent to the
- * backend. A value of 0 means, no data must be sent. Range [0-1]. A value of -1 means the value is
- * not found.
- * Name in remote config: "fpr_vc_trace_sampling_rate"
- *
- * @param samplingRate Default value to be returned if values does not exist in remote config.
- * @return Sampling rate used for the number of traces.
- */
- - (float)traceSamplingRateWithDefaultValue:(float)samplingRate;
- /**
- * Returns the sampling rate for network requests. A value of 1 means all the events must be sent to
- * the backend. A value of 0 means, no data must be sent. Range [0-1]. A value of -1 means the value
- * is not found.
- * Name in remote config: "fpr_vc_network_request_sampling_rate"
- *
- * @param samplingRate Default value to be returned if values does not exist in remote config.
- * @return Sampling rate used for the number of network request traces.
- */
- - (float)networkRequestSamplingRateWithDefaultValue:(float)samplingRate;
- #pragma mark - Session related configs.
- /**
- * Returns the sampling rate for sessions. A value of 1 means all the events must be sent to the
- * backend. A value of 0 means, no data must be sent. Range [0-1]. A value of -1 means the value is
- * not found.
- * Name in remote config: "fpr_vc_session_sampling_rate"
- *
- * @param samplingRate Default value to be returned if values does not exist in remote config.
- * @return Session sampling rate used for the number of sessions generated.
- */
- - (float)sessionSamplingRateWithDefaultValue:(float)samplingRate;
- /**
- * Returns the frequency at which CPU usage is measured when the app is in foreground. Measured in
- * milliseconds. Name in remote config: "fpr_session_gauge_cpu_capture_frequency_fg_ms"
- *
- * @param defaultFrequency Default value to be returned if values does not exist in remote config.
- * @return Frequency at which CPU information is captured when app is in foreground.
- */
- - (int)sessionGaugeCPUCaptureFrequencyInForegroundWithDefaultValue:(int)defaultFrequency;
- /**
- * Returns the frequency at which CPU usage is measured when the app is in background. Measured in
- * milliseconds. Name in remote config: "fpr_session_gauge_cpu_capture_frequency_bg_ms"
- *
- * @param defaultFrequency Default value to be returned if values does not exist in remote config.
- * @return Frequency at which CPU information is captured when app is in background.
- */
- - (int)sessionGaugeCPUCaptureFrequencyInBackgroundWithDefaultValue:(int)defaultFrequency;
- /**
- * Returns the frequency at which memory usage is measured when the app is in foreground. Measured
- * in milliseconds. Name in remote config: "fpr_session_gauge_memory_capture_frequency_fg_ms"
- *
- * @param defaultFrequency Default value to be returned if values does not exist in remote config.
- * @return Frequency at which memory information is captured when app is in foreground.
- */
- - (int)sessionGaugeMemoryCaptureFrequencyInForegroundWithDefaultValue:(int)defaultFrequency;
- /**
- * Returns the frequency at which memory usage is measured when the app is in background. Measured
- * in milliseconds. Name in remote config: "fpr_session_gauge_memory_capture_frequency_bg_ms"
- *
- * @param defaultFrequency Default value to be returned if values does not exist in remote config.
- * @return Frequency at which memory information is captured when app is in background.
- */
- - (int)sessionGaugeMemoryCaptureFrequencyInBackgroundWithDefaultValue:(int)defaultFrequency;
- /**
- * Returns the maximum allowed duration for the length of a session. Measured in minutes.
- * Name in remote config: "fpr_session_max_duration_min"
- *
- * @param maxDurationInMinutes Default value to be returned if values does not exist in remote
- * config.
- * @return Duration for which a sessions can be active.
- */
- - (int)sessionMaxDurationWithDefaultValue:(int)maxDurationInMinutes;
- @end
|