Skip to content

MrVeit/Firebase-Remote-Config-WebGL

Repository files navigation

FIREBASE REMOTE CONFIG WEBGL

Unity Version License Last commit Last release Downloads

qr

FRC WEBGL is a plugin for using Firebase Remote Config functionality in Unity projects for WebGL builds based on the Firebase JavaScript SDK.

Technical Demo

You can test the plugin without installation in a demo scene via this link.

Installation

Download the latest version of the SDK via the .unityPackage file here.

Creating app

Before you start using this plugin - you need to create a configuration of your game.

P.S: if you have already used this service for your mobile projects, then skip these steps by going to this section.

qr

After successfully creating the project, you need to go to the Remote Config section. This can be done by the path Run -> Remote Config, having previously expanded the Run tab.

qr

Now you can create your test/real parameters, after clicking on the Create configuration button.

qr

To allow the Unity client to access these settings, after creating them, be sure to publish the changes using the Publish Changes button.

qr

Well, almost everything is ready! It remains to get the project configuration data to use it in the plugin.

To do this, go through the gear icon to Project Settings to create them.

qr

Now scroll down the page just below and click on the </> icon, which stands for web application, since my plugin, is built on top of their JavaScript SDK!

qr

Now switch to the Config tab in the same window and save these data, as we will need them in the code.

qr

Initialization

In plugin version 1.0.0, it is available ONLY MANUAL INITIALIZATION with code.

Below is a test example of what this initialization might look like:

public sealed class InitPluginExample: MonoBehaviour
{
    private IRemoteConfigService_remoteConfig;

    private void OnDestroy()
    {
        _remoteConfig.OnInitialized -= OnRemoteConfigInitialized;
    }

    private void Start()
    {
        var initConfig = new FirebaseInitConfig()
        {
            apiKey = "AIzaSyA4KMCcJ1BAANqfJ21sn811ftfgMgWPTbaM",
            authDomain = "my-best-game-ever.firebaseapp.com",
            projectId = "my-best-game-ever",
            appId = "1:611501254098:web:bdeb0b69f669c70bc8d40b",

            minFetchDelayPerMillis = 60000,
            fetchTimeoutMillis = 60000,
        };

        var defaultConfig = new Dictionary<string, object>()
        {
            { "test_boolean_item_1", true },
            { "test_boolean_item_2", false },
            { "test_int_item_1", 1488 },
            { "test_int_item_2", 69 },
            { "test_string_item_1", "Powered by Veittech" },
            { "test_string_item_2", "Failed to fetch X-Powered-By" }
        };

        _remoteConfig = RemoteConfigProvider.Instance;

        _remoteConfig.OnInitialized += OnRemoteConfigInitialized;

        _remoteConfig.Init(true, initConfig, defaultConfig);
    }

    private void OnRemoteConfigInitialized(bool isSuccess)
    {
        Debug.Log($"Remote config init status: {isSuccess}");

        if (!isSuccess)
        {
            Debug.LogError("Failed to initialize remote config service");

            return;
        }

        Debug.Log("Remote config service initialized and ready for fetch");
    }
}

In the FirebaseInitConfig object, we use the data we created earlier in the Firebase console for our project in this section.

As recommended by the official Remote Config documentation, the value of the minFetchDelayPerMillis variable should be set to a MINIMUM 12 HOURS in milliseconds when building a project for production. For testing purposes, you can set the value to 1 minute if you do not make requests too often to avoid getting an exceed limit error.

It is strongly RECOMMENDED to create standard configs in Dictionary<string, object> format, which will be placed locally in local storage, after the WebGL build. You can also pass an empty dictionary with no values, but in that case the local data MAY NOT BE AVAILABLE from the storage unless you force the loading of the config values.

In case you do not specify values for variables minFetchDelayPerMillis and fetchTimeoutMillis in object FirebaseInitConfig, the plugin will do it by itself, specifying values for testing EVALUATE 1 MINUTE in milliseconds.

P.S: The keys and values must match those you previously created in the Remote Config console.

Initially, access to the IRemoteConfigService implementation, as a single instance, is provided through the RemoteConfigProvider proxy class. If you want to "register" a service yourself to access it in your project, the following are examples using Service Locator/Zenject/VContainer.

For example, through an implementation of the Service Locator pattern:

ServiceLocator.Bind<IRemoteConfigService>(new RemoteConfigService());

Via DI framework like Zenject/VContainer:

void BindViaZenject()
{
     Container.Bind<IRemoteConfigService>().To<RemoteConfigService>().AsSingle().NonLazy();
}

void BindViaVContainer(IContainerBuilder builder)
{
     builder.Register<RemoteConfigService>(Lifetime.Singleton).As<IRemoteConfigService>().As<IStartable>();
}

Usage Template

After successfully initializing the plugin, we can now load the current version of the remote config.

Fetch Config

There are two options: step-by-step loading with manual activation and implementation of both stages using a single method:

public sealed class FetchConfigExample: MonoBehaviour
{
     [SerializeField, Space] private Button _fetchConfigButton;
     [SerializeField] private Button _activateConfigButton;
     [SerializeField, Space] private Button _fetchAndActivateButton;

     private IRemoteConfigService _remoteConfig;

     private void Start()
     {
          _fetchConfigButton.onClick.AddListener(Fetch);
          _activateConfigButton.onClick.AddListener(Activate);
          _fetchAndActivateButton.onClick.AddListener(FetchAndActivate);

          _remoteConfig = RemoteConfigProvider.Instance;

          _remoteConfig.OnStorageFetched += OnRemoteStorageFetched;
          _remoteConfig.OnStorageActivated += OnRemoteStorageActivated;
     }

     private void Fetch()
     {
          if (!IsAvailable())
          {
              return;
          }

          _remoteConfig.FetchConfig();
     }

     private void Activate()
     {
          if (!IsAvailable())
          {
               return;
          }

          _remoteConfig.Activate();
     }

     private void FetchAndActivate()
     {
          if (!IsAvailable())
          {
              return;
          }

          _remoteConfig.FetchAndActivate();
     }

     private bool IsAvailable()
     {
          if (!_remoteConfig.IsInitialized)
          {
               Debug.LogWarning("Remote config is not initialized!");

               return false;
          }

          return true;
     }

     private void OnRemoteStorageFetched(bool isSuccess)
     {
          if (isSuccess)
          {
               Debug.Log("Remote storage successfully downloaded and cached locally");
          }
     }

     private void OnRemoteStorageActivated(bool isSuccess)
     {
          if (isSuccess)
          {
               Debug.Log("Remote storage ready for use!");
          }
     }
}

When Fetch() method is called, the plugin tries to download the current version of the remote values and if the request is successful - caches the result locally, but the past version will be available before activation.

The Activate() method updates the old version of the repository to the newly loaded version.

Similarly, the FetchAndActivate() method performs both of these functions to use the current version of the repository.

Load Data

Once the current version of the configuration has been successfully downloaded and activated - it is time to start using the data from there.

IRemoteConfigStorage storage = RemoteConfigProvider.Instance.Storage;

var myIntValue = storage.GetNumber("my-int-value-key");
var myStringValue = storage.GetString("my-string-value-key");
var myBoolValue = storage.GetBoolean("my-bool-value-key");

var myValue = storage.GetValue("my-string-value-key");
var myValues = storage.GetAll();

The GetAll() method returns all available data from the storage in Dictionary<string, object> format, and object GetValue(string key) you can use in cases when you don't know exactly what data type the key is or for convenience.

In case we want to get the type of storage from where the data was loaded, it is enough to call this method:

var intValueSource = storage.GetNumber("my-int-value-key");

An enumeration with Default/Remote/Static/Unknown will be returned.

This is the full functionality of the plugin as of version 1.0.0. It may change in the future, so follow the current documentation version here.

Build

Before you start building a unity project in WebGL, there are a few things you need to do to make sure the plugin will work properly.

qr

Go to the Build Settings window, then open Project Settings -> Player -> Resolution and Presentation and select the FRC Plugin build template. The Run in Background setting and the others do not affect anything, so you can leave them unchanged.

Now you can build the project and test the required functionality!

Donations

Multichain Wallet (BTC/ETH/BNB/USDT)

0x231803Df809C207FaA330646BB5547fD087FEcA1

Paypal

Thanks for your support!

Support

Email