Search code examples
javaandroidjsonfirebasefirebase-remote-config

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 the initiation of App Update notification, but so far I am still unable to get the 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 update 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 + "\n\n");
                            }
                        } 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.


Solution

  • 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