.class Lcom/google/firebase/iid/SyncTask; .super Ljava/lang/Object; .source "com.google.firebase:firebase-iid@@21.1.0" # interfaces .implements Ljava/lang/Runnable; # annotations .annotation system Ldalvik/annotation/MemberClasses; value = { Lcom/google/firebase/iid/SyncTask$ConnectivityChangeReceiver; } .end annotation # instance fields .field private final iid:Lcom/google/firebase/iid/FirebaseInstanceId; .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 constructor (Lcom/google/firebase/iid/FirebaseInstanceId;J)V .locals 1 .annotation build Lcom/google/android/gms/common/util/VisibleForTesting; .end annotation invoke-direct {p0}, Ljava/lang/Object;->()V .line 1 invoke-static {}, Lcom/google/firebase/iid/FirebaseIidExecutors;->newCachedSingleThreadExecutor()Ljava/util/concurrent/ExecutorService; move-result-object v0 iput-object v0, p0, Lcom/google/firebase/iid/SyncTask;->processorExecutor:Ljava/util/concurrent/ExecutorService; iput-object p1, p0, Lcom/google/firebase/iid/SyncTask;->iid:Lcom/google/firebase/iid/FirebaseInstanceId; iput-wide p2, p0, Lcom/google/firebase/iid/SyncTask;->nextDelaySeconds:J .line 2 invoke-virtual {p0}, Lcom/google/firebase/iid/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/iid/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 synthetic access$000(Lcom/google/firebase/iid/SyncTask;)Lcom/google/firebase/iid/FirebaseInstanceId; .locals 0 .line 1 iget-object p0, p0, Lcom/google/firebase/iid/SyncTask;->iid:Lcom/google/firebase/iid/FirebaseInstanceId; return-object p0 .end method # virtual methods .method public getContext()Landroid/content/Context; .locals 1 iget-object v0, p0, Lcom/google/firebase/iid/SyncTask;->iid:Lcom/google/firebase/iid/FirebaseInstanceId; .line 1 invoke-virtual {v0}, Lcom/google/firebase/iid/FirebaseInstanceId;->getApp()Lcom/google/firebase/FirebaseApp; move-result-object v0 invoke-virtual {v0}, Lcom/google/firebase/FirebaseApp;->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/iid/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, "FirebaseInstanceId" iget-object v1, p0, Lcom/google/firebase/iid/SyncTask;->iid:Lcom/google/firebase/iid/FirebaseInstanceId; .line 1 invoke-virtual {v1}, Lcom/google/firebase/iid/FirebaseInstanceId;->getTokenWithoutTriggeringSync()Lcom/google/firebase/iid/Store$Token; move-result-object v1 iget-object v2, p0, Lcom/google/firebase/iid/SyncTask;->iid:Lcom/google/firebase/iid/FirebaseInstanceId; .line 2 invoke-virtual {v2, v1}, Lcom/google/firebase/iid/FirebaseInstanceId;->tokenNeedsRefresh(Lcom/google/firebase/iid/Store$Token;)Z move-result v1 const/4 v2, 0x1 if-nez v1, :cond_0 return v2 :cond_0 const/4 v1, 0x0 :try_start_0 iget-object v3, p0, Lcom/google/firebase/iid/SyncTask;->iid:Lcom/google/firebase/iid/FirebaseInstanceId; .line 3 invoke-virtual {v3}, Lcom/google/firebase/iid/FirebaseInstanceId;->blockingGetMasterToken()Ljava/lang/String; move-result-object v3 if-nez v3, :cond_1 const-string v2, "Token retrieval failed: null" .line 4 invoke-static {v0, v2}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I return v1 :cond_1 const/4 v3, 0x3 .line 5 invoke-static {v0, v3}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z move-result v3 if-eqz v3, :cond_2 const-string v3, "Token successfully retrieved" .line 6 invoke-static {v0, v3}, 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_2 return v2 :catch_0 const-string v2, "Token retrieval failed with SecurityException. Will retry token retrieval" .line 7 invoke-static {v0, v2}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I return v1 :catch_1 move-exception v2 .line 8 invoke-virtual {v2}, Ljava/io/IOException;->getMessage()Ljava/lang/String; move-result-object v3 invoke-static {v3}, Lcom/google/firebase/iid/GmsRpc;->isErrorMessageForRetryableError(Ljava/lang/String;)Z move-result v3 if-eqz v3, :cond_3 .line 9 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 10 :cond_3 invoke-virtual {v2}, Ljava/io/IOException;->getMessage()Ljava/lang/String; move-result-object v3 if-nez v3, :cond_4 const-string v2, "Token retrieval failed without exception message. Will retry token retrieval" .line 11 invoke-static {v0, v2}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I return v1 .line 12 :cond_4 throw v2 .end method .method public run()V .locals 5 .annotation build Landroid/annotation/SuppressLint; value = { "Wakelock" } .end annotation .line 1 invoke-static {}, Lcom/google/firebase/iid/ServiceStarter;->getInstance()Lcom/google/firebase/iid/ServiceStarter; move-result-object v0 invoke-virtual {p0}, Lcom/google/firebase/iid/SyncTask;->getContext()Landroid/content/Context; move-result-object v1 invoke-virtual {v0, v1}, Lcom/google/firebase/iid/ServiceStarter;->hasWakeLockPermission(Landroid/content/Context;)Z move-result v0 if-eqz v0, :cond_0 iget-object v0, p0, Lcom/google/firebase/iid/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/iid/SyncTask;->iid:Lcom/google/firebase/iid/FirebaseInstanceId; const/4 v2, 0x1 .line 3 invoke-virtual {v1, v2}, Lcom/google/firebase/iid/FirebaseInstanceId;->setSyncScheduledOrRunning(Z)V iget-object v1, p0, Lcom/google/firebase/iid/SyncTask;->iid:Lcom/google/firebase/iid/FirebaseInstanceId; .line 4 invoke-virtual {v1}, Lcom/google/firebase/iid/FirebaseInstanceId;->isGmsCorePresent()Z move-result v1 if-nez v1, :cond_2 iget-object v1, p0, Lcom/google/firebase/iid/SyncTask;->iid:Lcom/google/firebase/iid/FirebaseInstanceId; .line 5 invoke-virtual {v1, v0}, Lcom/google/firebase/iid/FirebaseInstanceId;->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/iid/ServiceStarter;->getInstance()Lcom/google/firebase/iid/ServiceStarter; move-result-object v0 invoke-virtual {p0}, Lcom/google/firebase/iid/SyncTask;->getContext()Landroid/content/Context; move-result-object v1 invoke-virtual {v0, v1}, Lcom/google/firebase/iid/ServiceStarter;->hasWakeLockPermission(Landroid/content/Context;)Z move-result v0 if-eqz v0, :cond_1 :goto_0 iget-object v0, p0, Lcom/google/firebase/iid/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/iid/ServiceStarter;->getInstance()Lcom/google/firebase/iid/ServiceStarter; move-result-object v1 invoke-virtual {p0}, Lcom/google/firebase/iid/SyncTask;->getContext()Landroid/content/Context; move-result-object v2 invoke-virtual {v1, v2}, Lcom/google/firebase/iid/ServiceStarter;->hasAccessNetworkStatePermission(Landroid/content/Context;)Z move-result v1 if-eqz v1, :cond_4 .line 9 invoke-virtual {p0}, Lcom/google/firebase/iid/SyncTask;->isDeviceConnected()Z move-result v1 if-nez v1, :cond_4 new-instance v1, Lcom/google/firebase/iid/SyncTask$ConnectivityChangeReceiver; .line 10 invoke-direct {v1, p0}, Lcom/google/firebase/iid/SyncTask$ConnectivityChangeReceiver;->(Lcom/google/firebase/iid/SyncTask;)V .line 11 invoke-virtual {v1}, Lcom/google/firebase/iid/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/iid/ServiceStarter;->getInstance()Lcom/google/firebase/iid/ServiceStarter; move-result-object v0 invoke-virtual {p0}, Lcom/google/firebase/iid/SyncTask;->getContext()Landroid/content/Context; move-result-object v1 invoke-virtual {v0, v1}, Lcom/google/firebase/iid/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/iid/SyncTask;->maybeRefreshToken()Z move-result v1 if-eqz v1, :cond_5 iget-object v1, p0, Lcom/google/firebase/iid/SyncTask;->iid:Lcom/google/firebase/iid/FirebaseInstanceId; .line 14 invoke-virtual {v1, v0}, Lcom/google/firebase/iid/FirebaseInstanceId;->setSyncScheduledOrRunning(Z)V goto :goto_1 .line 15 :cond_5 iget-object v1, p0, Lcom/google/firebase/iid/SyncTask;->iid:Lcom/google/firebase/iid/FirebaseInstanceId; iget-wide v2, p0, Lcom/google/firebase/iid/SyncTask;->nextDelaySeconds:J .line 16 invoke-virtual {v1, v2, v3}, Lcom/google/firebase/iid/FirebaseInstanceId;->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/iid/ServiceStarter;->getInstance()Lcom/google/firebase/iid/ServiceStarter; move-result-object v0 invoke-virtual {p0}, Lcom/google/firebase/iid/SyncTask;->getContext()Landroid/content/Context; move-result-object v1 invoke-virtual {v0, v1}, Lcom/google/firebase/iid/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, "FirebaseInstanceId" .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/iid/SyncTask;->iid:Lcom/google/firebase/iid/FirebaseInstanceId; .line 20 invoke-virtual {v1, v0}, Lcom/google/firebase/iid/FirebaseInstanceId;->setSyncScheduledOrRunning(Z)V :try_end_3 .catchall {:try_start_3 .. :try_end_3} :catchall_0 .line 21 invoke-static {}, Lcom/google/firebase/iid/ServiceStarter;->getInstance()Lcom/google/firebase/iid/ServiceStarter; move-result-object v0 invoke-virtual {p0}, Lcom/google/firebase/iid/SyncTask;->getContext()Landroid/content/Context; move-result-object v1 invoke-virtual {v0, v1}, Lcom/google/firebase/iid/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/iid/ServiceStarter;->getInstance()Lcom/google/firebase/iid/ServiceStarter; move-result-object v1 invoke-virtual {p0}, Lcom/google/firebase/iid/SyncTask;->getContext()Landroid/content/Context; move-result-object v2 invoke-virtual {v1, v2}, Lcom/google/firebase/iid/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/iid/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