| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 |
- /*
- * Copyright 2019 Google
- *
- * 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 <FirebaseRemoteConfig/FIRRemoteConfig.h>
- #import "RCNConfigSettings.h" // This import is needed to expose settings for the Swift API tests.
- @class FIROptions;
- @class RCNConfigContent;
- @class RCNConfigDBManager;
- @class RCNConfigFetch;
- @class RCNConfigRealtime;
- @protocol FIRAnalyticsInterop;
- NS_ASSUME_NONNULL_BEGIN
- @class RCNConfigSettings;
- @interface FIRRemoteConfigUpdate ()
- /// Designated initializer.
- - (instancetype)initWithUpdatedKeys:(NSSet<NSString *> *)updatedKeys;
- @end
- @interface FIRRemoteConfig () {
- NSString *_FIRNamespace;
- }
- /// Internal settings
- @property(nonatomic, readonly, strong) RCNConfigSettings *settings;
- /// Config settings are custom settings.
- @property(nonatomic, readwrite, strong, nonnull) RCNConfigFetch *configFetch;
- @property(nonatomic, readwrite, strong, nonnull) RCNConfigRealtime *configRealtime;
- /// Returns the FIRRemoteConfig instance for your namespace and for the default Firebase App.
- /// This singleton object contains the complete set of Remote Config parameter values available to
- /// the app, including the Active Config and Default Config.. This object also caches values fetched
- /// from the Remote Config Server until they are copied to the Active Config by calling
- /// activateFetched. When you fetch values from the Remote Config Server using the default Firebase
- /// namespace service, you should use this class method to create a shared instance of the
- /// FIRRemoteConfig object to ensure that your app will function properly with the Remote Config
- /// Server and the Firebase service. This API is used internally by 2P teams.
- + (FIRRemoteConfig *)remoteConfigWithFIRNamespace:(NSString *)remoteConfigNamespace
- NS_SWIFT_NAME(remoteConfig(FIRNamespace:));
- /// Returns the FIRRemoteConfig instance for your namespace and for the default 3P developer's app.
- /// This singleton object contains the complete set of Remote Config parameter values available to
- /// the app, including the Active Config and Default Config. This object also caches values fetched
- /// from the Remote Config Server until they are copied to the Active Config by calling
- /// activateFetched. When you fetch values from the Remote Config Server using the default Firebase
- /// namespace service, you should use this class method to create a shared instance of the
- /// FIRRemoteConfig object to ensure that your app will function properly with the Remote Config
- /// Server and the Firebase service.
- + (FIRRemoteConfig *)remoteConfigWithFIRNamespace:(NSString *)remoteConfigNamespace
- app:(FIRApp *)app
- NS_SWIFT_NAME(remoteConfig(FIRNamespace:app:));
- /// Initialize a FIRRemoteConfig instance with all the required parameters directly. This exists so
- /// tests can create FIRRemoteConfig objects without needing FIRApp.
- - (instancetype)initWithAppName:(NSString *)appName
- FIROptions:(FIROptions *)options
- namespace:(NSString *)FIRNamespace
- DBManager:(RCNConfigDBManager *)DBManager
- configContent:(RCNConfigContent *)configContent
- analytics:(nullable id<FIRAnalyticsInterop>)analytics;
- @end
- NS_ASSUME_NONNULL_END
|