.class Lcom/google/firebase/messaging/SyncTask; .super Ljava/lang/Object; .source "com.google.firebase:firebase-messaging@@23.0.0" # interfaces .implements Ljava/lang/Runnable; # annotations .annotation system Ldalvik/annotation/MemberClasses; value = { Lcom/google/firebase/messaging/SyncTask$ConnectivityChangeReceiver; } .end annotation # instance fields .field private final firebaseMessaging:Lcom/google/firebase/messaging/FirebaseMessaging; .field private final nextDelaySeconds:J .field public processorExecutor:Ljava/util/concurrent/ExecutorService; .annotation build Lcom/google/android/gms/common/util/VisibleForTesting; .end annotation .end field .field private final syncWakeLock:Landroid/os/PowerManager$WakeLock; # direct methods .method public static bridge synthetic -$$Nest$fgetfirebaseMessaging(Lcom/google/firebase/messaging/SyncTask;)Lcom/google/firebase/messaging/FirebaseMessaging; .locals 0 iget-object p0, p0, Lcom/google/firebase/messaging/SyncTask;->firebaseMessaging:Lcom/google/firebase/messaging/FirebaseMessaging; return-object p0 .end method .method public constructor (Lcom/google/firebase/messaging/FirebaseMessaging;J)V .locals 9 .annotation build Landroid/annotation/SuppressLint; value = { "InvalidWakeLockTag" } .end annotation .annotation build Lcom/google/android/gms/common/util/VisibleForTesting; .end annotation .line 1 invoke-direct {p0}, Ljava/lang/Object;->()V new-instance v8, Ljava/util/concurrent/ThreadPoolExecutor; sget-object v5, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit; new-instance v6, Ljava/util/concurrent/LinkedBlockingQueue; invoke-direct {v6}, Ljava/util/concurrent/LinkedBlockingQueue;->()V new-instance v7, Lcom/google/android/gms/common/util/concurrent/NamedThreadFactory; const-string v0, "firebase-iid-executor" invoke-direct {v7, v0}, Lcom/google/android/gms/common/util/concurrent/NamedThreadFactory;->(Ljava/lang/String;)V const/4 v1, 0x0 const/4 v2, 0x1 const-wide/16 v3, 0x1e move-object v0, v8 invoke-direct/range {v0 .. v7}, Ljava/util/concurrent/ThreadPoolExecutor;->(IIJLjava/util/concurrent/TimeUnit;Ljava/util/concurrent/BlockingQueue;Ljava/util/concurrent/ThreadFactory;)V iput-object v8, p0, Lcom/google/firebase/messaging/SyncTask;->processorExecutor:Ljava/util/concurrent/ExecutorService; iput-object p1, p0, Lcom/google/firebase/messaging/SyncTask;->firebaseMessaging:Lcom/google/firebase/messaging/FirebaseMessaging; iput-wide p2, p0, Lcom/google/firebase/messaging/SyncTask;->nextDelaySeconds:J .line 2 invoke-virtual {p0}, Lcom/google/firebase/messaging/SyncTask;->getContext()Landroid/content/Context; move-result-object p1 const-string p2, "power" invoke-virtual {p1, p2}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object; move-result-object p1 check-cast p1, Landroid/os/PowerManager; const/4 p2, 0x1 const-string p3, "fiid-sync" .line 3 invoke-virtual {p1, p2, p3}, Landroid/os/PowerManager;->newWakeLock(ILjava/lang/String;)Landroid/os/PowerManager$WakeLock; move-result-object p1 iput-object p1, p0, Lcom/google/firebase/messaging/SyncTask;->syncWakeLock:Landroid/os/PowerManager$WakeLock; const/4 p2, 0x0 .line 4 invoke-virtual {p1, p2}, Landroid/os/PowerManager$WakeLock;->setReferenceCounted(Z)V return-void .end method .method public static isDebugLogEnabled()Z .locals 2 const-string v0, "FirebaseMessaging" const/4 v1, 0x3 .line 1 invoke-static {v0, v1}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z move-result v0 if-nez v0, :cond_0 const/4 v0, 0x0 goto :goto_0 :cond_0 const/4 v0, 0x1 :goto_0 return v0 .end method # virtual methods .method public getContext()Landroid/content/Context; .locals 1 .line 1 iget-object v0, p0, Lcom/google/firebase/messaging/SyncTask;->firebaseMessaging:Lcom/google/firebase/messaging/FirebaseMessaging; invoke-virtual {v0}, Lcom/google/firebase/messaging/FirebaseMessaging;->getApplicationContext()Landroid/content/Context; move-result-object v0 return-object v0 .end method .method public isDeviceConnected()Z .locals 2 .line 1 invoke-virtual {p0}, Lcom/google/firebase/messaging/SyncTask;->getContext()Landroid/content/Context; move-result-object v0 const-string v1, "connectivity" invoke-virtual {v0, v1}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object; move-result-object v0 check-cast v0, Landroid/net/ConnectivityManager; if-eqz v0, :cond_0 .line 2 invoke-virtual {v0}, Landroid/net/ConnectivityManager;->getActiveNetworkInfo()Landroid/net/NetworkInfo; move-result-object v0 goto :goto_0 :cond_0 const/4 v0, 0x0 :goto_0 if-eqz v0, :cond_1 .line 3 invoke-virtual {v0}, Landroid/net/NetworkInfo;->isConnected()Z move-result v0 if-eqz v0, :cond_1 const/4 v0, 0x1 return v0 :cond_1 const/4 v0, 0x0 return v0 .end method .method public maybeRefreshToken()Z .locals 5 .annotation build Lcom/google/android/gms/common/util/VisibleForTesting; .end annotation .annotation system Ldalvik/annotation/Throws; value = { Ljava/io/IOException; } .end annotation const-string v0, "FirebaseMessaging" const/4 v1, 0x0 .line 1 :try_start_0 iget-object v2, p0, Lcom/google/firebase/messaging/SyncTask;->firebaseMessaging:Lcom/google/firebase/messaging/FirebaseMessaging; invoke-virtual {v2}, Lcom/google/firebase/messaging/FirebaseMessaging;->blockingGetToken()Ljava/lang/String; move-result-object v2 if-nez v2, :cond_0 const-string v2, "Token retrieval failed: null" .line 2 invoke-static {v0, v2}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I return v1 :cond_0 const/4 v2, 0x3 .line 3 invoke-static {v0, v2}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z move-result v2 if-eqz v2, :cond_1 const-string v2, "Token successfully retrieved" .line 4 invoke-static {v0, v2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I :try_end_0 .catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_1 .catch Ljava/lang/SecurityException; {:try_start_0 .. :try_end_0} :catch_0 :cond_1 const/4 v0, 0x1 return v0 :catch_0 const-string v2, "Token retrieval failed with SecurityException. Will retry token retrieval" .line 5 invoke-static {v0, v2}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I return v1 :catch_1 move-exception v2 .line 6 invoke-virtual {v2}, Ljava/io/IOException;->getMessage()Ljava/lang/String; move-result-object v3 invoke-static {v3}, Lcom/google/firebase/messaging/GmsRpc;->isErrorMessageForRetryableError(Ljava/lang/String;)Z move-result v3 if-eqz v3, :cond_2 .line 7 invoke-virtual {v2}, Ljava/io/IOException;->getMessage()Ljava/lang/String; move-result-object v2 invoke-static {v2}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String; move-result-object v3 invoke-virtual {v3}, Ljava/lang/String;->length()I move-result v3 new-instance v4, Ljava/lang/StringBuilder; add-int/lit8 v3, v3, 0x34 invoke-direct {v4, v3}, Ljava/lang/StringBuilder;->(I)V const-string v3, "Token retrieval failed: " invoke-virtual {v4, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v4, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v2, ". Will retry token retrieval" invoke-virtual {v4, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v2 invoke-static {v0, v2}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I return v1 .line 8 :cond_2 invoke-virtual {v2}, Ljava/io/IOException;->getMessage()Ljava/lang/String; move-result-object v3 if-nez v3, :cond_3 const-string v2, "Token retrieval failed without exception message. Will retry token retrieval" .line 9 invoke-static {v0, v2}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I return v1 .line 10 :cond_3 throw v2 .end method .method public run()V .locals 5 .annotation build Landroid/annotation/SuppressLint; value = { "WakelockTimeout" } .end annotation .line 1 invoke-static {}, Lcom/google/firebase/messaging/ServiceStarter;->getInstance()Lcom/google/firebase/messaging/ServiceStarter; move-result-object v0 invoke-virtual {p0}, Lcom/google/firebase/messaging/SyncTask;->getContext()Landroid/content/Context; move-result-object v1 invoke-virtual {v0, v1}, Lcom/google/firebase/messaging/ServiceStarter;->hasWakeLockPermission(Landroid/content/Context;)Z move-result v0 if-eqz v0, :cond_0 iget-object v0, p0, Lcom/google/firebase/messaging/SyncTask;->syncWakeLock:Landroid/os/PowerManager$WakeLock; .line 2 invoke-virtual {v0}, Landroid/os/PowerManager$WakeLock;->acquire()V :cond_0 const/4 v0, 0x0 :try_start_0 iget-object v1, p0, Lcom/google/firebase/messaging/SyncTask;->firebaseMessaging:Lcom/google/firebase/messaging/FirebaseMessaging; const/4 v2, 0x1 .line 3 invoke-virtual {v1, v2}, Lcom/google/firebase/messaging/FirebaseMessaging;->setSyncScheduledOrRunning(Z)V iget-object v1, p0, Lcom/google/firebase/messaging/SyncTask;->firebaseMessaging:Lcom/google/firebase/messaging/FirebaseMessaging; .line 4 invoke-virtual {v1}, Lcom/google/firebase/messaging/FirebaseMessaging;->isGmsCorePresent()Z move-result v1 if-nez v1, :cond_2 iget-object v1, p0, Lcom/google/firebase/messaging/SyncTask;->firebaseMessaging:Lcom/google/firebase/messaging/FirebaseMessaging; .line 5 invoke-virtual {v1, v0}, Lcom/google/firebase/messaging/FirebaseMessaging;->setSyncScheduledOrRunning(Z)V :try_end_0 .catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 .line 6 invoke-static {}, Lcom/google/firebase/messaging/ServiceStarter;->getInstance()Lcom/google/firebase/messaging/ServiceStarter; move-result-object v0 invoke-virtual {p0}, Lcom/google/firebase/messaging/SyncTask;->getContext()Landroid/content/Context; move-result-object v1 invoke-virtual {v0, v1}, Lcom/google/firebase/messaging/ServiceStarter;->hasWakeLockPermission(Landroid/content/Context;)Z move-result v0 if-eqz v0, :cond_1 :goto_0 iget-object v0, p0, Lcom/google/firebase/messaging/SyncTask;->syncWakeLock:Landroid/os/PowerManager$WakeLock; .line 7 invoke-virtual {v0}, Landroid/os/PowerManager$WakeLock;->release()V :cond_1 return-void .line 8 :cond_2 :try_start_1 invoke-static {}, Lcom/google/firebase/messaging/ServiceStarter;->getInstance()Lcom/google/firebase/messaging/ServiceStarter; move-result-object v1 invoke-virtual {p0}, Lcom/google/firebase/messaging/SyncTask;->getContext()Landroid/content/Context; move-result-object v2 invoke-virtual {v1, v2}, Lcom/google/firebase/messaging/ServiceStarter;->hasAccessNetworkStatePermission(Landroid/content/Context;)Z move-result v1 if-eqz v1, :cond_4 .line 9 invoke-virtual {p0}, Lcom/google/firebase/messaging/SyncTask;->isDeviceConnected()Z move-result v1 if-nez v1, :cond_4 new-instance v1, Lcom/google/firebase/messaging/SyncTask$ConnectivityChangeReceiver; .line 10 invoke-direct {v1, p0}, Lcom/google/firebase/messaging/SyncTask$ConnectivityChangeReceiver;->(Lcom/google/firebase/messaging/SyncTask;)V .line 11 invoke-virtual {v1}, Lcom/google/firebase/messaging/SyncTask$ConnectivityChangeReceiver;->registerReceiver()V :try_end_1 .catch Ljava/io/IOException; {:try_start_1 .. :try_end_1} :catch_0 .catchall {:try_start_1 .. :try_end_1} :catchall_0 .line 12 invoke-static {}, Lcom/google/firebase/messaging/ServiceStarter;->getInstance()Lcom/google/firebase/messaging/ServiceStarter; move-result-object v0 invoke-virtual {p0}, Lcom/google/firebase/messaging/SyncTask;->getContext()Landroid/content/Context; move-result-object v1 invoke-virtual {v0, v1}, Lcom/google/firebase/messaging/ServiceStarter;->hasWakeLockPermission(Landroid/content/Context;)Z move-result v0 if-eqz v0, :cond_3 goto :goto_0 :cond_3 return-void .line 13 :cond_4 :try_start_2 invoke-virtual {p0}, Lcom/google/firebase/messaging/SyncTask;->maybeRefreshToken()Z move-result v1 if-eqz v1, :cond_5 iget-object v1, p0, Lcom/google/firebase/messaging/SyncTask;->firebaseMessaging:Lcom/google/firebase/messaging/FirebaseMessaging; .line 14 invoke-virtual {v1, v0}, Lcom/google/firebase/messaging/FirebaseMessaging;->setSyncScheduledOrRunning(Z)V goto :goto_1 .line 15 :cond_5 iget-object v1, p0, Lcom/google/firebase/messaging/SyncTask;->firebaseMessaging:Lcom/google/firebase/messaging/FirebaseMessaging; iget-wide v2, p0, Lcom/google/firebase/messaging/SyncTask;->nextDelaySeconds:J .line 16 invoke-virtual {v1, v2, v3}, Lcom/google/firebase/messaging/FirebaseMessaging;->syncWithDelaySecondsInternal(J)V :try_end_2 .catch Ljava/io/IOException; {:try_start_2 .. :try_end_2} :catch_0 .catchall {:try_start_2 .. :try_end_2} :catchall_0 .line 17 :goto_1 invoke-static {}, Lcom/google/firebase/messaging/ServiceStarter;->getInstance()Lcom/google/firebase/messaging/ServiceStarter; move-result-object v0 invoke-virtual {p0}, Lcom/google/firebase/messaging/SyncTask;->getContext()Landroid/content/Context; move-result-object v1 invoke-virtual {v0, v1}, Lcom/google/firebase/messaging/ServiceStarter;->hasWakeLockPermission(Landroid/content/Context;)Z move-result v0 if-eqz v0, :cond_6 goto :goto_0 :catchall_0 move-exception v0 goto :goto_2 :catch_0 move-exception v1 :try_start_3 const-string v2, "FirebaseMessaging" .line 18 invoke-virtual {v1}, Ljava/io/IOException;->getMessage()Ljava/lang/String; move-result-object v1 invoke-static {v1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String; move-result-object v3 invoke-virtual {v3}, Ljava/lang/String;->length()I move-result v3 add-int/lit8 v3, v3, 0x5d new-instance v4, Ljava/lang/StringBuilder; invoke-direct {v4, v3}, Ljava/lang/StringBuilder;->(I)V const-string v3, "Topic sync or token retrieval failed on hard failure exceptions: " invoke-virtual {v4, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v1, ". Won\'t retry the operation." invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 .line 19 invoke-static {v2, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I iget-object v1, p0, Lcom/google/firebase/messaging/SyncTask;->firebaseMessaging:Lcom/google/firebase/messaging/FirebaseMessaging; .line 20 invoke-virtual {v1, v0}, Lcom/google/firebase/messaging/FirebaseMessaging;->setSyncScheduledOrRunning(Z)V :try_end_3 .catchall {:try_start_3 .. :try_end_3} :catchall_0 .line 21 invoke-static {}, Lcom/google/firebase/messaging/ServiceStarter;->getInstance()Lcom/google/firebase/messaging/ServiceStarter; move-result-object v0 invoke-virtual {p0}, Lcom/google/firebase/messaging/SyncTask;->getContext()Landroid/content/Context; move-result-object v1 invoke-virtual {v0, v1}, Lcom/google/firebase/messaging/ServiceStarter;->hasWakeLockPermission(Landroid/content/Context;)Z move-result v0 if-eqz v0, :cond_6 goto/16 :goto_0 :cond_6 return-void :goto_2 invoke-static {}, Lcom/google/firebase/messaging/ServiceStarter;->getInstance()Lcom/google/firebase/messaging/ServiceStarter; move-result-object v1 invoke-virtual {p0}, Lcom/google/firebase/messaging/SyncTask;->getContext()Landroid/content/Context; move-result-object v2 invoke-virtual {v1, v2}, Lcom/google/firebase/messaging/ServiceStarter;->hasWakeLockPermission(Landroid/content/Context;)Z move-result v1 if-nez v1, :cond_7 goto :goto_3 .line 22 :cond_7 iget-object v1, p0, Lcom/google/firebase/messaging/SyncTask;->syncWakeLock:Landroid/os/PowerManager$WakeLock; .line 23 invoke-virtual {v1}, Landroid/os/PowerManager$WakeLock;->release()V .line 24 :goto_3 throw v0 .end method