153 lines
6.5 KiB
Java
153 lines
6.5 KiB
Java
package com.google.firebase.messaging;
|
|
|
|
import android.annotation.SuppressLint;
|
|
import android.content.BroadcastReceiver;
|
|
import android.content.Context;
|
|
import android.content.Intent;
|
|
import android.content.IntentFilter;
|
|
import android.net.ConnectivityManager;
|
|
import android.net.NetworkInfo;
|
|
import android.os.PowerManager;
|
|
import android.util.Log;
|
|
import com.google.android.gms.common.util.concurrent.NamedThreadFactory;
|
|
import java.io.IOException;
|
|
import java.util.concurrent.ExecutorService;
|
|
import java.util.concurrent.LinkedBlockingQueue;
|
|
import java.util.concurrent.ThreadPoolExecutor;
|
|
import java.util.concurrent.TimeUnit;
|
|
|
|
/* JADX INFO: Access modifiers changed from: package-private */
|
|
/* loaded from: classes3.dex */
|
|
public class SyncTask implements Runnable {
|
|
private final FirebaseMessaging firebaseMessaging;
|
|
private final long nextDelaySeconds;
|
|
|
|
@SuppressLint({"ThreadPoolCreation"})
|
|
ExecutorService processorExecutor = new ThreadPoolExecutor(0, 1, 30, TimeUnit.SECONDS, new LinkedBlockingQueue(), new NamedThreadFactory("firebase-iid-executor"));
|
|
private final PowerManager.WakeLock syncWakeLock;
|
|
|
|
/* loaded from: classes3.dex */
|
|
public static class ConnectivityChangeReceiver extends BroadcastReceiver {
|
|
private SyncTask task;
|
|
|
|
public ConnectivityChangeReceiver(SyncTask syncTask) {
|
|
this.task = syncTask;
|
|
}
|
|
|
|
@Override // android.content.BroadcastReceiver
|
|
public void onReceive(Context context, Intent intent) {
|
|
SyncTask syncTask = this.task;
|
|
if (syncTask != null && syncTask.isDeviceConnected()) {
|
|
if (SyncTask.isDebugLogEnabled()) {
|
|
Log.d(Constants.TAG, "Connectivity changed. Starting background sync.");
|
|
}
|
|
this.task.firebaseMessaging.enqueueTaskWithDelaySeconds(this.task, 0L);
|
|
this.task.getContext().unregisterReceiver(this);
|
|
this.task = null;
|
|
}
|
|
}
|
|
|
|
public void registerReceiver() {
|
|
if (SyncTask.isDebugLogEnabled()) {
|
|
Log.d(Constants.TAG, "Connectivity change received registered");
|
|
}
|
|
this.task.getContext().registerReceiver(this, new IntentFilter("android.net.conn.CONNECTIVITY_CHANGE"));
|
|
}
|
|
}
|
|
|
|
@SuppressLint({"InvalidWakeLockTag"})
|
|
public SyncTask(FirebaseMessaging firebaseMessaging, long j4) {
|
|
this.firebaseMessaging = firebaseMessaging;
|
|
this.nextDelaySeconds = j4;
|
|
PowerManager.WakeLock newWakeLock = ((PowerManager) getContext().getSystemService("power")).newWakeLock(1, "fiid-sync");
|
|
this.syncWakeLock = newWakeLock;
|
|
newWakeLock.setReferenceCounted(false);
|
|
}
|
|
|
|
public static boolean isDebugLogEnabled() {
|
|
return Log.isLoggable(Constants.TAG, 3);
|
|
}
|
|
|
|
public Context getContext() {
|
|
return this.firebaseMessaging.getApplicationContext();
|
|
}
|
|
|
|
public boolean isDeviceConnected() {
|
|
ConnectivityManager connectivityManager = (ConnectivityManager) getContext().getSystemService("connectivity");
|
|
NetworkInfo activeNetworkInfo = connectivityManager != null ? connectivityManager.getActiveNetworkInfo() : null;
|
|
return activeNetworkInfo != null && activeNetworkInfo.isConnected();
|
|
}
|
|
|
|
public boolean maybeRefreshToken() throws IOException {
|
|
try {
|
|
if (this.firebaseMessaging.blockingGetToken() == null) {
|
|
Log.e(Constants.TAG, "Token retrieval failed: null");
|
|
return false;
|
|
}
|
|
if (!Log.isLoggable(Constants.TAG, 3)) {
|
|
return true;
|
|
}
|
|
Log.d(Constants.TAG, "Token successfully retrieved");
|
|
return true;
|
|
} catch (IOException e4) {
|
|
if (!GmsRpc.isErrorMessageForRetryableError(e4.getMessage())) {
|
|
if (e4.getMessage() != null) {
|
|
throw e4;
|
|
}
|
|
Log.w(Constants.TAG, "Token retrieval failed without exception message. Will retry token retrieval");
|
|
return false;
|
|
}
|
|
Log.w(Constants.TAG, "Token retrieval failed: " + e4.getMessage() + ". Will retry token retrieval");
|
|
return false;
|
|
} catch (SecurityException unused) {
|
|
Log.w(Constants.TAG, "Token retrieval failed with SecurityException. Will retry token retrieval");
|
|
return false;
|
|
}
|
|
}
|
|
|
|
@Override // java.lang.Runnable
|
|
@SuppressLint({"WakelockTimeout"})
|
|
public void run() {
|
|
if (ServiceStarter.getInstance().hasWakeLockPermission(getContext())) {
|
|
this.syncWakeLock.acquire();
|
|
}
|
|
try {
|
|
try {
|
|
this.firebaseMessaging.setSyncScheduledOrRunning(true);
|
|
if (!this.firebaseMessaging.isGmsCorePresent()) {
|
|
this.firebaseMessaging.setSyncScheduledOrRunning(false);
|
|
if (!ServiceStarter.getInstance().hasWakeLockPermission(getContext())) {
|
|
return;
|
|
}
|
|
} else if (!ServiceStarter.getInstance().hasAccessNetworkStatePermission(getContext()) || isDeviceConnected()) {
|
|
if (maybeRefreshToken()) {
|
|
this.firebaseMessaging.setSyncScheduledOrRunning(false);
|
|
} else {
|
|
this.firebaseMessaging.syncWithDelaySecondsInternal(this.nextDelaySeconds);
|
|
}
|
|
if (!ServiceStarter.getInstance().hasWakeLockPermission(getContext())) {
|
|
return;
|
|
}
|
|
} else {
|
|
new ConnectivityChangeReceiver(this).registerReceiver();
|
|
if (!ServiceStarter.getInstance().hasWakeLockPermission(getContext())) {
|
|
return;
|
|
}
|
|
}
|
|
this.syncWakeLock.release();
|
|
} catch (IOException e4) {
|
|
Log.e(Constants.TAG, "Topic sync or token retrieval failed on hard failure exceptions: " + e4.getMessage() + ". Won't retry the operation.");
|
|
this.firebaseMessaging.setSyncScheduledOrRunning(false);
|
|
if (ServiceStarter.getInstance().hasWakeLockPermission(getContext())) {
|
|
this.syncWakeLock.release();
|
|
}
|
|
}
|
|
} catch (Throwable th) {
|
|
if (ServiceStarter.getInstance().hasWakeLockPermission(getContext())) {
|
|
this.syncWakeLock.release();
|
|
}
|
|
throw th;
|
|
}
|
|
}
|
|
}
|