Primer paso de la investigacion. Se aportan el .apk, las carpetas con el apk extraido y el apk descompilado. El archivo API_DOCUMENTATION.md es un archivo donde se anotaran los descubrimientos del funcionamiento de la API, y los .py son scripts para probar la funcionalidad de la API con los métodos que vayamos encontrando. Finalmente, los archivos .js son scripts de Frida para extraer informacion de la APP durante la ejecucion.

This commit is contained in:
2025-12-04 13:59:54 +01:00
parent f2fd1c3bf5
commit e0133d2ca2
10432 changed files with 1019085 additions and 1 deletions

View File

@@ -0,0 +1,76 @@
package com.google.firebase.remoteconfig.internal;
import android.content.Context;
import com.google.firebase.FirebaseApp;
import com.google.firebase.installations.FirebaseInstallationsApi;
import com.google.firebase.remoteconfig.ConfigUpdateListener;
import com.google.firebase.remoteconfig.ConfigUpdateListenerRegistration;
import java.util.LinkedHashSet;
import java.util.Set;
import java.util.concurrent.ScheduledExecutorService;
/* loaded from: classes3.dex */
public class ConfigRealtimeHandler {
private final ConfigCacheClient activatedCacheClient;
private final ConfigFetchHandler configFetchHandler;
private final ConfigRealtimeHttpClient configRealtimeHttpClient;
private final Context context;
private final FirebaseApp firebaseApp;
private final FirebaseInstallationsApi firebaseInstallations;
private final Set<ConfigUpdateListener> listeners;
private final ConfigMetadataClient metadataClient;
private final String namespace;
private final ScheduledExecutorService scheduledExecutorService;
/* loaded from: classes3.dex */
public class ConfigUpdateListenerRegistrationInternal implements ConfigUpdateListenerRegistration {
private final ConfigUpdateListener listener;
public ConfigUpdateListenerRegistrationInternal(ConfigUpdateListener configUpdateListener) {
this.listener = configUpdateListener;
}
@Override // com.google.firebase.remoteconfig.ConfigUpdateListenerRegistration
public void remove() {
ConfigRealtimeHandler.this.removeRealtimeConfigUpdateListener(this.listener);
}
}
public ConfigRealtimeHandler(FirebaseApp firebaseApp, FirebaseInstallationsApi firebaseInstallationsApi, ConfigFetchHandler configFetchHandler, ConfigCacheClient configCacheClient, Context context, String str, ConfigMetadataClient configMetadataClient, ScheduledExecutorService scheduledExecutorService) {
LinkedHashSet linkedHashSet = new LinkedHashSet();
this.listeners = linkedHashSet;
this.configRealtimeHttpClient = new ConfigRealtimeHttpClient(firebaseApp, firebaseInstallationsApi, configFetchHandler, configCacheClient, context, str, linkedHashSet, configMetadataClient, scheduledExecutorService);
this.firebaseApp = firebaseApp;
this.configFetchHandler = configFetchHandler;
this.firebaseInstallations = firebaseInstallationsApi;
this.activatedCacheClient = configCacheClient;
this.context = context;
this.namespace = str;
this.metadataClient = configMetadataClient;
this.scheduledExecutorService = scheduledExecutorService;
}
private synchronized void beginRealtime() {
if (!this.listeners.isEmpty()) {
this.configRealtimeHttpClient.startHttpConnection();
}
}
/* JADX INFO: Access modifiers changed from: private */
public synchronized void removeRealtimeConfigUpdateListener(ConfigUpdateListener configUpdateListener) {
this.listeners.remove(configUpdateListener);
}
public synchronized ConfigUpdateListenerRegistration addRealtimeConfigUpdateListener(ConfigUpdateListener configUpdateListener) {
this.listeners.add(configUpdateListener);
beginRealtime();
return new ConfigUpdateListenerRegistrationInternal(configUpdateListener);
}
public synchronized void setBackgroundState(boolean z3) {
this.configRealtimeHttpClient.setRealtimeBackgroundState(z3);
if (!z3) {
beginRealtime();
}
}
}