Skip to main content

Android - Create Force Update App Module in 30 minutes

In the article “Android – Create Force Update App Module in 30 minutes“. I will be using the firebase remote config for the app force update module.

First, navigate to Firebase and login with your Google account. Once signing will be done you will be able to see Go to Console on the right top corner of the page.

remote config - Goto Console
Click on Go to Console

After entering into the console you will have to create a new project. Click on the Add Project button.

Now on the next screen, you have to enter the project name and click on Continue to move further.

On the next screen, You will be asked to enable google analytics on your project it is by default enable so just click on continue to move further.

remote config - Google Analytics screen
Click on continue

Then on the next screen, you will be asked to select google account for google analytics. Select default account for Firebase if you don’t have already created an account. Otherwise, in the drop-down you will see your other account. For this example, I am using the default Firebase account.

remote config - Configure Google Analytics
Click on Create Project

After this screen you will be redirected to another screen

remote config - Project Creation in progress
Then click on continue

Once your project has been created. Then click on Add App and then you will get a new screen to register your APP.

remote config - Register App
Register App

The above steps are self-explanatory so I am not getting into deep. At last, you will get google-services.json file that you need to place on your project’s app root folder.

To set up the remote config app environment for this app. Please check-out the following tutorial.

 // To setup firebase related configurations    private void setup()    {        config = FirebaseRemoteConfig.getInstance();        FirebaseRemoteConfigSettings settings = new FirebaseRemoteConfigSettings.Builder().setMinimumFetchIntervalInSeconds(60).                build();        config.setConfigSettingsAsync(settings);        // Setting Defaults for remote config        config.setDefaultsAsync(R.xml.remote_config_defaults);    }

In the above code, I am setting up the remote configuration.

This includes following -:

  • Initializing FirebaseRemoteConfig Object
  • Setting MinimumFetchInterval time
  • Applying those settings to for remote config using setConfigSettingsAsync
  • Then setting defaults XML file for using setDefaultsAsync

The method setMinimumFetchIntervalInSeconds is very important which is used to set the time for fetching the remote changes. In this example, I am setting it to 60 seconds. It depends on you what interval time you want to give as per your app requirement you can increase or decrease time.

In remote config, we create an XML file for setting the default value. This can be done in two ways.

1. Programmatically by using Map.
2. Using the XML file in the resource folder.

For the sake of simplicity, I am using an XML file


remote_config_defaults.xml

<?xml version="1.0" encoding="utf-8"?><defaultsMap>    <entry>        <key>version</key>        <value></value>    </entry>    <entry>        <key>release_notes</key>        <value></value>    </entry></defaultsMap>

This is how you declare the default values. In this example, I am not using any values as default values.

private void checkVersion()    {          // setup callback to fetch and activate remote configurations        config.fetchAndActivate().addOnCompleteListener(MainActivity.this,         new OnCompleteListener<Boolean>() {            @Override            public void onComplete(@NonNull Task<Boolean> task) {                if(task.isSuccessful())                {                    // If task is successful then get name and version                    String version = config.getString("version");                    String release_notes =                     config.getString("release_notes");                    Log.d(getPackageName(), "Version: " + version);                    Log.d(getPackageName(), "Whats New: " + release_notes);                    // Display Force update dialog                    displayAppUpdateDialog(version, release_notes);                }                else                {                    // If fetch failed then show a toast message                    Toast.makeText(MainActivity.this, "Fetch Failed",                     Toast.LENGTH_SHORT).show();                }            }    });    }

The above code doing following things:

  • Calling fetchAndActivate() method and then checking the result.
  • If the Above request is successful then checking it with isSuccessful() method.
  • Then fetching the values using getString() method by passing keys (the key that we mentioned in an XML file and calling displayAppUpdateDialog to show a dialog.
  • We have also added else condition to notify the user in case if the request failed using toast message

Now navigate to remote config comes under Grow section. And click on Add Parameter to create remote configurations. You will get a dialog that contains Parameter Key where you will enter your key which you have specified in your remote_config_defaults.xml file.

The second thing is the Default Value. Either you can specify any string here (text) or leave it as empty. For this example, I am leaving it as an empty string as the default value.

remote config - Add value for condition
Add value for condition

Now you have to enter your new value for your key. To do this click on Add value for condition and a new dialog appears on the screen.

Here you will have to enter the name of your app. It could be anything.

Next, click on Applies If and select App from the dropdown dialog and then select the app from the right side dropdown.

remote config - Define new condition
Define a new condition

remote config - Create Condition
Click on Create Condition

remote config - Final Configurations

Once we have created the conditions all you need to do is run the application and you should see the dialog with default values.

Go back to the console and click on the version key and update its value to v1.9 (example) and click on update to close the dialog.


remote config - update configurations
Click on update

Now click on publish changes and run your app. You should see the result.

remote config - Publish changes
Click on Publish Changes

AndroidManifest.xml

 <uses-permission android:name="android.permission.INTERNET" />

MainActivity.java

package com.tuts.forceupdateapp;import androidx.annotation.NonNull;import androidx.appcompat.app.AlertDialog;import androidx.appcompat.app.AppCompatActivity;import android.content.DialogInterface;import android.os.Bundle;import android.util.Log;import android.widget.Toast;import com.google.android.gms.tasks.OnCompleteListener;import com.google.android.gms.tasks.OnFailureListener;import com.google.android.gms.tasks.OnSuccessListener;import com.google.android.gms.tasks.Task;import com.google.firebase.remoteconfig.FirebaseRemoteConfig;import com.google.firebase.remoteconfig.FirebaseRemoteConfigSettings;import java.io.IOException;public class MainActivity extends AppCompatActivity {   private FirebaseRemoteConfig config;   @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);           setup();        checkVersion();    }   // To setup firebase related configurations    private void setup()    {        config = FirebaseRemoteConfig.getInstance();        FirebaseRemoteConfigSettings settings = new         FirebaseRemoteConfigSettings.Builder()        .setMinimumFetchIntervalInSeconds(60)        .build();        config.setConfigSettingsAsync(settings);        // Setting Defaults for remote config        config.setDefaultsAsync(R.xml.remote_config_defaults);    }    private void checkVersion()    {         // setup callback to fetch and activate remote configurations        config.fetchAndActivate().addOnCompleteListener(MainActivity.this,         new OnCompleteListener<Boolean>() {            @Override            public void onComplete(@NonNull Task<Boolean> task) {                if(task.isSuccessful())                {                    // If task is successful then get name and version                    String version = config.getString("version");                    String release_notes =                     config.getString("release_notes");                    Log.d(getPackageName(), "Version: " + version);                    Log.d(getPackageName(), "Whats New: " + release_notes);                    // Display Force update dialog                    displayAppUpdateDialog(version, release_notes);                }                else                {                    // If fetch failed then show a toast message                    Toast.makeText(MainActivity.this, "Fetch Failed",                     Toast.LENGTH_SHORT).show();               }           }    });    }    private void displayAppUpdateDialog(String version, String whats_new)    {        AlertDialog.Builder builder = new         AlertDialog.Builder(MainActivity.this);        builder.setTitle("New Version: " + version);        builder.setMessage("Whats New: \n" + whats_new);        builder.setPositiveButton("Update", new         DialogInterface.OnClickListener() {            @Override            public void onClick(DialogInterface dialog, int which) {                Toast.makeText(MainActivity.this,"Update Started",                 Toast.LENGTH_SHORT).show();            }        });        builder.setNegativeButton("Cancel", new         DialogInterface.OnClickListener() {            @Override            public void onClick(DialogInterface dialog, int which) {                        dialog.cancel();            }        });        AlertDialog dialog = builder.create();            dialog.show();    }}

If you have any queries to remote config then leave your comments below. I will try to solve your queries.

Thanks for reading 🙂 🙂

Comments

Popular posts from this blog

3D ANALYZER SETTINGS

Settings for Prince of Persia Sands of Time Works with this game, u can try wid others also which are not in above list Performance section: -force zBuffer Hardware limits: -emulate HW TnL caps -emulate Pixel shader caps ANTI-DETECT MODE section: -shaders Z-buffer section: -24 bit zbuffer(with stencil) DirectX DeviceID’s section: NVIDIA GeForce Ti4600 Configuration: VendorID : 4318 Device ID :592 Works well in the following or higher configuration -Intel 865GSA motherboard, -512 MB RAM, -Pentium D dual core 2.66 GHz processor, -No graphics card required…….. have fun.

SMACKDOWN HERE COMES THE PAIN PCSX2 SETTINGS

Smack Down Here Comes The Pain Configuration: GRAPHICS-GSDX 1600(MSVC 15.00 SSSE3)0.1.15 CONTROLLERS-LILLY PAD 0.10.0 CDVDROM-EPP POLLING CDVD DRIVER 0.4.0 USB-USB NULL DRIVER 0.6.0 SOUND-SPU2-X1.1.0 SECOND CONTROLLER-LILLY PAD 0.10.0 DEV9-DEV9NULL DRIVER-0.4.0 FIRE WIRE-FWNULL DRIVER 0.5.0 BIOS-EUROPE V01.60(04/10/2001)CONSOLE SYSTEM REQUIREMENTS FOR PCSX2- MINIMUM - * Windows/Linux OS * CPU: Any that supports SSE2 (Pentium 4 and up, Athlon64 and up) * GPU: Any that supports Pixel Shader model 2.0, except Nvidia FX series (broken SM2.0, too slow anyway) * 512mb RAM (note Vista needs at least 2gb to run reliably) RECOMMENDED - * Windows Vista 32bit/64bit with the latest DirectX * CPU: Intel Core 2 Duo @ 3.2ghz or better * GPU: 8600gt or better (for Direct3D10 support) * RAM: 1gb on Linux/Windows XP, 2gb or more on Vista MY SYSTEM REQUIREMENTS WINDOWS XP SP3 PENTIUM DUAL CORE 2.6GHZ (E5300) 2GB RAM ZOTAC 8400GS 512MB DIRECT-X 9...

Choosing the Best CPU for Your Gaming Computer

Picking the latest, fastest or most expensive processor on the market won’t always result in the right CPU for your particular system. Some processors are designed to work with certain motherboards, so the CPU you choose will limit the type of motherboard you can get. The CPU (Central Processing Unit) is one of the most important components in any computer system. The CPU could be described as the brains of a computer. It contains the logic circuitry that performs the instructions of the software you run. The performance of your games and other applications will be directly related to this tiny little microprocessor. The Major Players: Intel and AMD Two companies dominate the CPU market, Intel and AMD (Advanced Micro Devices). Both companies make a range of different processor models.  For example, Intel have the Core i7 and Core i5 processor models, while AMD have the Athlon and Phenom series.  The Best CPU for Gaming If you’re a basic computer user and y...