Skip to content
Advertisement

How to Get Value from JSON in Firebase Remote Config

I am a novice to Android app development and Firebase.

I want to know how can I get the value (String & Int) in the JSONArray file stored in Firebase Remote Config?

I use Firebase Remote Config with the final goal to compare my app’s version code and priority level with the one stored in Firebase Remote Config to determine initiation of App Update notification, but so far I still unable get Remote Config value.

I tried to parse the JSON using Volley (jsonParse in MainActivity2 class), but it also didn’t work. (Error bad url)

I have several times tried to implement previous answers, but maybe because of my misunderstanding, all those came to no avail.

Can I declare an array to Firebase Remote config?

Can I get JSONObject from Default value of Firebase Remote Config

FirebaseRemoteConfig getString is empty

I also have read this interesting article about implementing in-app updates notifications with some specific criteria using Remote Config, but unfortunately for me, the codes are written in Kotlin.

https://engineering.q42.nl/android-in-app-updates/

test_json file stored in Firebase Remote Config.

[
  {
    "versionCode": "1",
    "priorityLevel": 2
  },
  {
    "versionCode": "2",
    "priorityLevel": 4
  },
  {
    "versionCode": "3",
    "priorityLevel": 1
  }
]

MainActivity2 class

        remoteConfig = FirebaseRemoteConfig.getInstance();
        FirebaseRemoteConfigSettings configSettings = new FirebaseRemoteConfigSettings.Builder()
                .setFetchTimeoutInSeconds(2000)
                .build();
        remoteConfig.setConfigSettingsAsync(configSettings);

        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                remoteConfig.fetchAndActivate().addOnCompleteListener(new OnCompleteListener<Boolean>() {
                    @Override
                    public void onComplete(@NonNull Task<Boolean> task) {
                        if (task.isSuccessful()) {
                            String object = remoteConfig.getString("test_json");
                            //jsonParse(object);
                            Gson gson = new GsonBuilder().create();
                            ArrayList<Lessons> lessons = gson.fromJson(object, 
                                 new TypeToken<List<Lessons>>(){}.getType());

                        } else {
                            Toast.makeText(MainActivity2.this, "Fetch Failed!", Toast.LENGTH_SHORT).show();
                        }
                    }
                });
            }
        });

        private void jsonParse(String object) {
                JsonObjectRequest request = new JsonObjectRequest(Request.Method.GET, object, null,
                    new Response.Listener<JSONObject>() {
                    @Override
                    public void onResponse(JSONObject response) {
                        try {
                            JSONArray jsonArray = response.getJSONArray("condition");

                            for (int i = 0; i < jsonArray.length(); i++) {
                                JSONObject condition = jsonArray.getJSONObject(i);

                                String versionCode = condition.getString("versionCode");
                                int priorityLevel = condition.getInt("priorityLevel");

                                textView.append(versionCode + "nn");
                            }
                        } catch (JSONException e) {
                            e.printStackTrace();
                        }
                    }
                }, new Response.ErrorListener() {
            @Override
            public void onErrorResponse(VolleyError error) {
                error.printStackTrace();
            }
        });

        mQueue.add(request);
    }

Lessons class

public class Lessons {
    String versionCode;
    Int priorityLevel;
}

Any help would be greatly appreciated.

Thank you.

Advertisement

Answer

For me worked like that

import com.google.gson.annotations.SerializedName

data class VersionData(
    @SerializedName("name")
    val name: String,
    @SerializedName("age")
    var age: Int,
    @SerializedName("isFemale")
    var isFemale: Boolean
)

init {
    remoteConfig.fetchAndActivate()
}

private val _mutableLiveData = MutableLiveData<VersionData>()
val remoteLiveData: LiveData<VersionData> = _mutableLiveData
fun remoteConfiguration() {
    val gson = Gson()
    val remote = remoteConfig.fetchAndActivate()
    remote.addOnSuccessListener{
        val stringJson = remoteConfig.getString("json_object_name")
       if(stringJson.isNotEmpty()){
         val jsonModel = gson.fromJson(stringJson, VersionData::class.java)
          _mutableLiveData.value = VersionData(
              name = jsonModel.name,
              age = jsonModel.age,
              isFemale = jsonModel.isFemale
          )
       }else{
          // probably your remote param not exists
        }           
    }
}

so observe in compose

val localLifecycle = LocalLifecycleOwner.current
myViewModel.remoteLiveData.observe(localLifecycle){
 Log.d("remoteLiveData", "remoteLiveData: $it")
}

enter image description here

User contributions licensed under: CC BY-SA
3 People found this is helpful
Advertisement