h.smali
.class public final Ln5/h;
.super Ljava/lang/Object;
.source "com.google.firebase:firebase-messaging@@20.2.0"
# interfaces
.implements Ljava/lang/Runnable;
# static fields
.field public static final f:Ljava/lang/Object;
.field public static g:Ljava/lang/Boolean;
.annotation build Landroidx/annotation/GuardedBy;
value = "TOPIC_SYNC_TASK_LOCK"
.end annotation
.end field
.field public static h:Ljava/lang/Boolean;
.annotation build Landroidx/annotation/GuardedBy;
value = "TOPIC_SYNC_TASK_LOCK"
.end annotation
.end field
# instance fields
.field public final a:Landroid/content/Context;
.field public final b:Lg5/q;
.field public final c:Landroid/os/PowerManager$WakeLock;
.field public final d:Ln5/f;
.field public final e:J
# direct methods
.method public static constructor <clinit>()V
.registers 1
new-instance v0, Ljava/lang/Object;
invoke-direct {v0}, Ljava/lang/Object;-><init>()V
sput-object v0, Ln5/h;->f:Ljava/lang/Object;
return-void
.end method
.method public constructor <init>(Ln5/f;Landroid/content/Context;Lg5/q;J)V
.registers 6
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
iput-object p1, p0, Ln5/h;->d:Ln5/f;
iput-object p2, p0, Ln5/h;->a:Landroid/content/Context;
iput-wide p4, p0, Ln5/h;->e:J
iput-object p3, p0, Ln5/h;->b:Lg5/q;
const-string p1, "power"
invoke-virtual {p2, p1}, 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, "wake:com.google.firebase.messaging"
invoke-virtual {p1, p2, p3}, Landroid/os/PowerManager;->newWakeLock(ILjava/lang/String;)Landroid/os/PowerManager$WakeLock;
move-result-object p1
iput-object p1, p0, Ln5/h;->c:Landroid/os/PowerManager$WakeLock;
return-void
.end method
.method public static a(Landroid/content/Context;)Z
.registers 4
sget-object v0, Ln5/h;->f:Ljava/lang/Object;
monitor-enter v0
:try_start_3
sget-object v1, Ln5/h;->g:Ljava/lang/Boolean;
if-nez v1, :cond_10
const-string v1, "android.permission.WAKE_LOCK"
sget-object v2, Ln5/h;->g:Ljava/lang/Boolean;
invoke-static {p0, v1, v2}, Ln5/h;->a(Landroid/content/Context;Ljava/lang/String;Ljava/lang/Boolean;)Z
move-result p0
goto :goto_16
:cond_10
sget-object p0, Ln5/h;->g:Ljava/lang/Boolean;
invoke-virtual {p0}, Ljava/lang/Boolean;->booleanValue()Z
move-result p0
:goto_16
invoke-static {p0}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object p0
sput-object p0, Ln5/h;->g:Ljava/lang/Boolean;
invoke-virtual {p0}, Ljava/lang/Boolean;->booleanValue()Z
move-result p0
monitor-exit v0
return p0
:catchall_22
move-exception p0
monitor-exit v0
:try_end_24
.catchall {:try_start_3 .. :try_end_24} :catchall_22
throw p0
.end method
.method public static a(Landroid/content/Context;Ljava/lang/String;Ljava/lang/Boolean;)Z
.registers 5
if-eqz p2, :cond_7
invoke-virtual {p2}, Ljava/lang/Boolean;->booleanValue()Z
move-result p0
return p0
:cond_7
invoke-virtual {p0, p1}, Landroid/content/Context;->checkCallingOrSelfPermission(Ljava/lang/String;)I
move-result p0
if-nez p0, :cond_f
const/4 p0, 0x1
goto :goto_10
:cond_f
const/4 p0, 0x0
:goto_10
if-nez p0, :cond_3e
const/4 p2, 0x3
const-string v0, "FirebaseMessaging"
invoke-static {v0, p2}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result p2
if-eqz p2, :cond_3e
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p2
invoke-virtual {p2}, Ljava/lang/String;->length()I
move-result p2
add-int/lit16 p2, p2, 0x8e
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1, p2}, Ljava/lang/StringBuilder;-><init>(I)V
const-string p2, "Missing Permission: "
invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p1, ". This permission should normally be included by the manifest merger, but may needed to be manually added to your manifest"
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {v0, p1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
:cond_3e
return p0
.end method
.method public static synthetic a(Ln5/h;)Z
.registers 1
invoke-virtual {p0}, Ln5/h;->a()Z
move-result p0
return p0
.end method
.method public static synthetic b(Ln5/h;)Ln5/f;
.registers 1
iget-object p0, p0, Ln5/h;->d:Ln5/f;
return-object p0
.end method
.method public static synthetic b()Z
.registers 1
invoke-static {}, Ln5/h;->c()Z
move-result v0
return v0
.end method
.method public static b(Landroid/content/Context;)Z
.registers 4
sget-object v0, Ln5/h;->f:Ljava/lang/Object;
monitor-enter v0
:try_start_3
sget-object v1, Ln5/h;->h:Ljava/lang/Boolean;
if-nez v1, :cond_10
const-string v1, "android.permission.ACCESS_NETWORK_STATE"
sget-object v2, Ln5/h;->h:Ljava/lang/Boolean;
invoke-static {p0, v1, v2}, Ln5/h;->a(Landroid/content/Context;Ljava/lang/String;Ljava/lang/Boolean;)Z
move-result p0
goto :goto_16
:cond_10
sget-object p0, Ln5/h;->h:Ljava/lang/Boolean;
invoke-virtual {p0}, Ljava/lang/Boolean;->booleanValue()Z
move-result p0
:goto_16
invoke-static {p0}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object p0
sput-object p0, Ln5/h;->h:Ljava/lang/Boolean;
invoke-virtual {p0}, Ljava/lang/Boolean;->booleanValue()Z
move-result p0
monitor-exit v0
return p0
:catchall_22
move-exception p0
monitor-exit v0
:try_end_24
.catchall {:try_start_3 .. :try_end_24} :catchall_22
throw p0
.end method
.method public static c()Z
.registers 4
const/4 v0, 0x3
const-string v1, "FirebaseMessaging"
invoke-static {v1, v0}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v2
if-nez v2, :cond_18
sget v2, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v3, 0x17
if-ne v2, v3, :cond_16
invoke-static {v1, v0}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v0
if-eqz v0, :cond_16
goto :goto_18
:cond_16
const/4 v0, 0x0
return v0
:cond_18
:goto_18
const/4 v0, 0x1
return v0
.end method
# virtual methods
.method public final declared-synchronized a()Z
.registers 3
monitor-enter p0
:try_start_1
iget-object v0, p0, Ln5/h;->a:Landroid/content/Context;
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_12
invoke-virtual {v0}, Landroid/net/ConnectivityManager;->getActiveNetworkInfo()Landroid/net/NetworkInfo;
move-result-object v0
goto :goto_13
:cond_12
const/4 v0, 0x0
:goto_13
if-eqz v0, :cond_1e
invoke-virtual {v0}, Landroid/net/NetworkInfo;->isConnected()Z
move-result v0
:try_end_19
.catchall {:try_start_1 .. :try_end_19} :catchall_20
if-eqz v0, :cond_1e
const/4 v0, 0x1
:goto_1c
monitor-exit p0
return v0
:cond_1e
const/4 v0, 0x0
goto :goto_1c
:catchall_20
move-exception v0
monitor-exit p0
goto :goto_24
:goto_23
throw v0
:goto_24
goto :goto_23
.end method
.method public final run()V
.registers 9
.annotation build Landroid/annotation/SuppressLint;
value = {
"Wakelock"
}
.end annotation
const-string v0, "TopicsSyncTask\'s wakelock was already released due to timeout."
const-string v1, "FirebaseMessaging"
iget-object v2, p0, Ln5/h;->a:Landroid/content/Context;
invoke-static {v2}, Ln5/h;->a(Landroid/content/Context;)Z
move-result v2
if-eqz v2, :cond_13
iget-object v2, p0, Ln5/h;->c:Landroid/os/PowerManager$WakeLock;
sget-wide v3, Ln5/k;->a:J
invoke-virtual {v2, v3, v4}, Landroid/os/PowerManager$WakeLock;->acquire(J)V
:cond_13
const/4 v2, 0x0
:try_start_14
iget-object v3, p0, Ln5/h;->d:Ln5/f;
const/4 v4, 0x1
invoke-virtual {v3, v4}, Ln5/f;->a(Z)V
iget-object v3, p0, Ln5/h;->b:Lg5/q;
invoke-virtual {v3}, Lg5/q;->a()Z
move-result v3
if-nez v3, :cond_39
iget-object v3, p0, Ln5/h;->d:Ln5/f;
invoke-virtual {v3, v2}, Ln5/f;->a(Z)V
:try_end_27
.catch Ljava/io/IOException; {:try_start_14 .. :try_end_27} :catch_b1
.catchall {:try_start_14 .. :try_end_27} :catchall_af
iget-object v2, p0, Ln5/h;->a:Landroid/content/Context;
invoke-static {v2}, Ln5/h;->a(Landroid/content/Context;)Z
move-result v2
if-eqz v2, :cond_38
:try_start_2f
iget-object v2, p0, Ln5/h;->c:Landroid/os/PowerManager$WakeLock;
invoke-virtual {v2}, Landroid/os/PowerManager$WakeLock;->release()V
:try_end_34
.catch Ljava/lang/RuntimeException; {:try_start_2f .. :try_end_34} :catch_35
return-void
:catch_35
invoke-static {v1, v0}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
:cond_38
return-void
:cond_39
:try_start_39
iget-object v3, p0, Ln5/h;->a:Landroid/content/Context;
invoke-static {v3}, Ln5/h;->b(Landroid/content/Context;)Z
move-result v3
if-eqz v3, :cond_88
invoke-virtual {p0}, Ln5/h;->a()Z
move-result v3
if-nez v3, :cond_88
new-instance v3, Ln5/g;
invoke-direct {v3, p0, p0}, Ln5/g;-><init>(Ln5/h;Ln5/h;)V
const/4 v5, 0x3
invoke-static {v1, v5}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v6
if-nez v6, :cond_61
sget v6, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v7, 0x17
if-ne v6, v7, :cond_60
invoke-static {v1, v5}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v5
if-eqz v5, :cond_60
goto :goto_61
:cond_60
const/4 v4, 0x0
:cond_61
:goto_61
if-eqz v4, :cond_68
const-string v4, "Connectivity change received registered"
invoke-static {v1, v4}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
:cond_68
iget-object v4, v3, Ln5/g;->b:Ln5/h;
iget-object v4, v4, Ln5/h;->a:Landroid/content/Context;
new-instance v5, Landroid/content/IntentFilter;
const-string v6, "android.net.conn.CONNECTIVITY_CHANGE"
invoke-direct {v5, v6}, Landroid/content/IntentFilter;-><init>(Ljava/lang/String;)V
invoke-virtual {v4, v3, v5}, Landroid/content/Context;->registerReceiver(Landroid/content/BroadcastReceiver;Landroid/content/IntentFilter;)Landroid/content/Intent;
:try_end_76
.catch Ljava/io/IOException; {:try_start_39 .. :try_end_76} :catch_b1
.catchall {:try_start_39 .. :try_end_76} :catchall_af
iget-object v2, p0, Ln5/h;->a:Landroid/content/Context;
invoke-static {v2}, Ln5/h;->a(Landroid/content/Context;)Z
move-result v2
if-eqz v2, :cond_87
:try_start_7e
iget-object v2, p0, Ln5/h;->c:Landroid/os/PowerManager$WakeLock;
invoke-virtual {v2}, Landroid/os/PowerManager$WakeLock;->release()V
:try_end_83
.catch Ljava/lang/RuntimeException; {:try_start_7e .. :try_end_83} :catch_84
return-void
:catch_84
invoke-static {v1, v0}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
:cond_87
return-void
:cond_88
:try_start_88
iget-object v3, p0, Ln5/h;->d:Ln5/f;
invoke-virtual {v3}, Ln5/f;->b()Z
move-result v3
if-eqz v3, :cond_96
iget-object v3, p0, Ln5/h;->d:Ln5/f;
invoke-virtual {v3, v2}, Ln5/f;->a(Z)V
goto :goto_9d
:cond_96
iget-object v3, p0, Ln5/h;->d:Ln5/f;
iget-wide v4, p0, Ln5/h;->e:J
invoke-virtual {v3, v4, v5}, Ln5/f;->a(J)V
:try_end_9d
.catch Ljava/io/IOException; {:try_start_88 .. :try_end_9d} :catch_b1
.catchall {:try_start_88 .. :try_end_9d} :catchall_af
:goto_9d
iget-object v2, p0, Ln5/h;->a:Landroid/content/Context;
invoke-static {v2}, Ln5/h;->a(Landroid/content/Context;)Z
move-result v2
if-eqz v2, :cond_e5
:try_start_a5
iget-object v2, p0, Ln5/h;->c:Landroid/os/PowerManager$WakeLock;
invoke-virtual {v2}, Landroid/os/PowerManager$WakeLock;->release()V
:try_end_aa
.catch Ljava/lang/RuntimeException; {:try_start_a5 .. :try_end_aa} :catch_ab
return-void
:catch_ab
invoke-static {v1, v0}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
return-void
:catchall_af
move-exception v2
goto :goto_e6
:catch_b1
move-exception v3
:try_start_b2
const-string v4, "Failed to sync topics. Won\'t retry sync. "
invoke-virtual {v3}, Ljava/io/IOException;->getMessage()Ljava/lang/String;
move-result-object v3
invoke-static {v3}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/String;->length()I
move-result v5
if-eqz v5, :cond_c7
invoke-virtual {v4, v3}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v3
goto :goto_cc
:cond_c7
new-instance v3, Ljava/lang/String;
invoke-direct {v3, v4}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_cc
invoke-static {v1, v3}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
iget-object v3, p0, Ln5/h;->d:Ln5/f;
invoke-virtual {v3, v2}, Ln5/f;->a(Z)V
:try_end_d4
.catchall {:try_start_b2 .. :try_end_d4} :catchall_af
iget-object v2, p0, Ln5/h;->a:Landroid/content/Context;
invoke-static {v2}, Ln5/h;->a(Landroid/content/Context;)Z
move-result v2
if-eqz v2, :cond_e5
:try_start_dc
iget-object v2, p0, Ln5/h;->c:Landroid/os/PowerManager$WakeLock;
invoke-virtual {v2}, Landroid/os/PowerManager$WakeLock;->release()V
:try_end_e1
.catch Ljava/lang/RuntimeException; {:try_start_dc .. :try_end_e1} :catch_e2
return-void
:catch_e2
invoke-static {v1, v0}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
:cond_e5
return-void
:goto_e6
iget-object v3, p0, Ln5/h;->a:Landroid/content/Context;
invoke-static {v3}, Ln5/h;->a(Landroid/content/Context;)Z
move-result v3
if-eqz v3, :cond_f7
:try_start_ee
iget-object v3, p0, Ln5/h;->c:Landroid/os/PowerManager$WakeLock;
invoke-virtual {v3}, Landroid/os/PowerManager$WakeLock;->release()V
:try_end_f3
.catch Ljava/lang/RuntimeException; {:try_start_ee .. :try_end_f3} :catch_f4
goto :goto_f7
:catch_f4
invoke-static {v1, v0}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
:cond_f7
:goto_f7
throw v2
.end method