Cordova plugin for Firebase Remote Config
Your help is appreciated. Create a PR, submit a bug or just grab me 🍺 |
---|
- iOS
- Android
$ cordova plugin add cordova-plugin-firebase-config
Use variables IOS_FIREBASE_POD_VERSION
and ANDROID_FIREBASE_BOM_VERSION
to override dependency versions for Firebase SDKs:
$ cordova plugin add cordova-plugin-firebase-config \
--variable IOS_FIREBASE_POD_VERSION="9.3.0" \
--variable ANDROID_FIREBASE_BOM_VERSION="30.3.1"
Cordova supports resource-file
tag for easy copying resources files. Firebase SDK requires google-services.json
on Android and GoogleService-Info.plist
on iOS platforms.
- Put
google-services.json
and/orGoogleService-Info.plist
into the root directory of your Cordova project - Add new tag for Android platform
<platform name="android">
...
<resource-file src="google-services.json" target="app/google-services.json" />
</platform>
...
<platform name="ios">
...
<resource-file src="GoogleService-Info.plist" />
</platform>
You can specify FirebaseRemoteConfigDefaults
in config.xml
to define filename of a file with default values. Keep in mind that android and ios have different naming convensions there it's useful to specify different file names.
<platform name="android">
...
<preference name="FirebaseRemoteConfigDefaults" value="remote_config_defaults" />
<resource-file src="resources/android/remote_config_defaults.xml" target="app/src/main/res/xml/remote_config_defaults.xml" />
</platform>
<platform name="ios">
...
<preference name="FirebaseRemoteConfigDefaults" value="RemoteConfigDefaults" />
<resource-file src="resources/ios/RemoteConfigDefaults.plist" />
</platform>
On Android platform file remote_config_defaults.xml
has a structure like below:
<?xml version="1.0" encoding="utf-8"?>
<defaultsMap>
<entry>
<key>param1</key>
<value>value1</value>
</entry>
<entry>
<key>param2</key>
<value>value2</value>
</entry>
</defaultsMap>
On iOS platform file RemoteConfigDefaults.plist
has a structure like below:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>param1</key>
<string>value1</string>
<key>param2</key>
<string>value2</string>
</dict>
</plist>
VALUE_SOURCE_DEFAULT: number
Indicates that the value returned was retrieved from the defaults set by the client.
Constant
VALUE_SOURCE_REMOTE: number
Indicates that the value returned was retrieved from the Firebase Remote Config Server.
Constant
VALUE_SOURCE_STATIC: number
Indicates that the value returned is the static default value.
Constant
activate(): Promise
<boolean
>
Asynchronously activates the most recently fetched configs, so that the fetched key value pairs take effect.
Example
cordova.plugins.firebase.config.activate();
Promise
<boolean
>
Fulfills promise with flag if current config was activated
fetch(expirationDuration
): Promise
<void
>
Starts fetching configs, adhering to the specified minimum fetch interval.
Example
cordova.plugins.firebase.config.fetch(8 * 3600);
Name | Type | Description |
---|---|---|
expirationDuration |
number |
Minimum fetch interval in seconds |
Promise
<void
>
Callback when operation is completed
fetchAndActivate(): Promise
<boolean
>
Asynchronously fetches and then activates the fetched configs.
Example
cordova.plugins.firebase.config.fetchAndActivate();
Promise
<boolean
>
Fulfills promise with flag if current config was activated
getBoolean(key
): Promise
<boolean
>
Returns the boolean parameter value for the given key
Example
cordova.plugins.firebase.config.getBoolean("myBool").then(function(value) {
// use value from remote config
});
Name | Type | Description |
---|---|---|
key |
string |
Parameter key |
Promise
<boolean
>
Fulfills promise with parameter value
getBytes(key
): Promise
<ArrayBuffer
>
Returns the bytes parameter value for the given key
Example
cordova.plugins.firebase.config.getBytes("myByteArray").then(function(value) {
// use value from remote config
});
Name | Type | Description |
---|---|---|
key |
string |
Parameter key |
Promise
<ArrayBuffer
>
Fulfills promise with parameter value
getNumber(key
): Promise
<number
>
Returns the number parameter value for the given key
Example
cordova.plugins.firebase.config.getNumber("myNumber").then(function(value) {
// use value from remote config
});
Name | Type | Description |
---|---|---|
key |
string |
Parameter key |
Promise
<number
>
Fulfills promise with parameter value
getString(key
): Promise
<string
>
Returns the string parameter value for the given key
Example
cordova.plugins.firebase.config.getString("myStr").then(function(value) {
// use value from remote config
});
Name | Type | Description |
---|---|---|
key |
string |
Parameter key |
Promise
<string
>
Fulfills promise with parameter value
getValueSource(key
): Promise
<number
>
Returns source of the value for the specified key.
Example
cordova.plugins.firebase.config.getValueSource("myArbitraryValue").then(function(source) {
if (source === cordova.plugins.firebase.config.VALUE_SOURCE_DEFAULT) {
// ...
}
});
Name | Type | Description |
---|---|---|
key |
string |
Parameter key |
Promise
<number
>
Fulfills promise with parameter value