FirebaseMessagingService.smali

.class public Lcom/google/firebase/messaging/FirebaseMessagingService;
.super Lcom/google/firebase/messaging/zzc;
.source "com.google.firebase:firebase-messaging@@20.1.0"


# static fields
.field private static final zza:Ljava/util/Queue;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/Queue<",
            "Ljava/lang/String;",
            ">;"
        }
    .end annotation
.end field


# direct methods
.method static constructor <clinit>()V
    .registers 2

    .line 107
    new-instance v0, Ljava/util/ArrayDeque;

    const/16 v1, 0xa

    invoke-direct {v0, v1}, Ljava/util/ArrayDeque;-><init>(I)V

    sput-object v0, Lcom/google/firebase/messaging/FirebaseMessagingService;->zza:Ljava/util/Queue;

    return-void
.end method

.method public constructor <init>()V
    .registers 1

    .line 1
    invoke-direct {p0}, Lcom/google/firebase/messaging/zzc;-><init>()V

    return-void
.end method


# virtual methods
.method public onDeletedMessages()V
    .registers 1

    .line 3
    return-void
.end method

.method public onMessageReceived(Lcom/google/firebase/messaging/RemoteMessage;)V
    .registers 2

    .line 2
    return-void
.end method

.method public onMessageSent(Ljava/lang/String;)V
    .registers 2

    .line 4
    return-void
.end method

.method public onNewToken(Ljava/lang/String;)V
    .registers 2

    .line 6
    return-void
.end method

.method public onSendError(Ljava/lang/String;Ljava/lang/Exception;)V
    .registers 3

    .line 5
    return-void
.end method

.method protected final zza(Landroid/content/Intent;)Landroid/content/Intent;
    .registers 2

    .line 7
    invoke-static {}, Lcom/google/firebase/iid/zzaq;->zza()Lcom/google/firebase/iid/zzaq;

    move-result-object p1

    invoke-virtual {p1}, Lcom/google/firebase/iid/zzaq;->zzb()Landroid/content/Intent;

    move-result-object p1

    return-object p1
.end method

.method public final zzb(Landroid/content/Intent;)Z
    .registers 4

    .line 8
    invoke-virtual {p1}, Landroid/content/Intent;->getAction()Ljava/lang/String;

    move-result-object v0

    const-string v1, "com.google.firebase.messaging.NOTIFICATION_OPEN"

    invoke-virtual {v1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z

    move-result v0

    if-eqz v0, :cond_2e

    .line 9
    nop

    .line 10
    const-string v0, "pending_intent"

    invoke-virtual {p1, v0}, Landroid/content/Intent;->getParcelableExtra(Ljava/lang/String;)Landroid/os/Parcelable;

    move-result-object v0

    check-cast v0, Landroid/app/PendingIntent;

    .line 11
    if-eqz v0, :cond_23

    .line 12
    :try_start_17
    invoke-virtual {v0}, Landroid/app/PendingIntent;->send()V
    :try_end_1a
    .catch Landroid/app/PendingIntent$CanceledException; {:try_start_17 .. :try_end_1a} :catch_1b

    .line 13
    goto :goto_23

    .line 14
    :catch_1b
    move-exception v0

    .line 15
    const-string v0, "FirebaseMessaging"

    const-string v1, "Notification pending intent canceled"

    invoke-static {v0, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I

    .line 16
    :cond_23
    :goto_23
    invoke-static {p1}, Lcom/google/firebase/messaging/zzo;->zzd(Landroid/content/Intent;)Z

    move-result v0

    if-eqz v0, :cond_2c

    .line 17
    invoke-static {p1}, Lcom/google/firebase/messaging/zzo;->zza(Landroid/content/Intent;)V

    .line 18
    :cond_2c
    const/4 p1, 0x1

    return p1

    .line 19
    :cond_2e
    const/4 p1, 0x0

    return p1
.end method

.method public final zzc(Landroid/content/Intent;)V
    .registers 14

    .line 20
    invoke-virtual {p1}, Landroid/content/Intent;->getAction()Ljava/lang/String;

    move-result-object v0

    .line 21
    const-string v1, "com.google.android.c2dm.intent.RECEIVE"

    invoke-virtual {v1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z

    move-result v1

    const-string v2, "FirebaseMessaging"

    if-nez v1, :cond_59

    const-string v1, "com.google.firebase.messaging.RECEIVE_DIRECT_BOOT"

    invoke-virtual {v1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z

    move-result v1

    if-eqz v1, :cond_17

    goto :goto_59

    .line 100
    :cond_17
    const-string v1, "com.google.firebase.messaging.NOTIFICATION_DISMISS"

    invoke-virtual {v1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z

    move-result v1

    if-eqz v1, :cond_29

    .line 101
    invoke-static {p1}, Lcom/google/firebase/messaging/zzo;->zzd(Landroid/content/Intent;)Z

    move-result v0

    if-eqz v0, :cond_58

    .line 102
    invoke-static {p1}, Lcom/google/firebase/messaging/zzo;->zzb(Landroid/content/Intent;)V

    return-void

    .line 103
    :cond_29
    const-string v1, "com.google.firebase.messaging.NEW_TOKEN"

    invoke-virtual {v1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z

    move-result v0

    if-eqz v0, :cond_3b

    .line 104
    const-string v0, "token"

    invoke-virtual {p1, v0}, Landroid/content/Intent;->getStringExtra(Ljava/lang/String;)Ljava/lang/String;

    move-result-object p1

    invoke-virtual {p0, p1}, Lcom/google/firebase/messaging/FirebaseMessagingService;->onNewToken(Ljava/lang/String;)V

    return-void

    .line 105
    :cond_3b
    const-string v0, "Unknown intent action: "

    invoke-virtual {p1}, Landroid/content/Intent;->getAction()Ljava/lang/String;

    move-result-object p1

    invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;

    move-result-object p1

    invoke-virtual {p1}, Ljava/lang/String;->length()I

    move-result v1

    if-eqz v1, :cond_50

    invoke-virtual {v0, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;

    move-result-object p1

    goto :goto_55

    :cond_50
    new-instance p1, Ljava/lang/String;

    invoke-direct {p1, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V

    :goto_55
    invoke-static {v2, p1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 106
    :cond_58
    return-void

    .line 22
    :cond_59
    :goto_59
    nop

    .line 23
    const-string v0, "google.message_id"

    invoke-virtual {p1, v0}, Landroid/content/Intent;->getStringExtra(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v1

    .line 24
    nop

    .line 25
    invoke-static {v1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z

    move-result v3

    const/4 v4, 0x0

    const/4 v5, 0x2

    if-eqz v3, :cond_6e

    .line 26
    invoke-static {v4}, Lcom/google/android/gms/tasks/Tasks;->forResult(Ljava/lang/Object;)Lcom/google/android/gms/tasks/Task;

    move-result-object v3

    goto :goto_7e

    .line 27
    :cond_6e
    new-instance v3, Landroid/os/Bundle;

    invoke-direct {v3}, Landroid/os/Bundle;-><init>()V

    .line 28
    invoke-virtual {v3, v0, v1}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V

    .line 29
    invoke-static {p0}, Lcom/google/firebase/iid/zzv;->zza(Landroid/content/Context;)Lcom/google/firebase/iid/zzv;

    move-result-object v6

    .line 30
    invoke-virtual {v6, v5, v3}, Lcom/google/firebase/iid/zzv;->zza(ILandroid/os/Bundle;)Lcom/google/android/gms/tasks/Task;

    move-result-object v3

    .line 31
    :goto_7e
    nop

    .line 32
    nop

    .line 33
    invoke-static {v1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z

    move-result v6

    const/4 v7, 0x1

    const/4 v8, 0x3

    const/4 v9, 0x0

    if-eqz v6, :cond_8b

    .line 34
    const/4 v1, 0x0

    goto :goto_c9

    .line 35
    :cond_8b
    sget-object v6, Lcom/google/firebase/messaging/FirebaseMessagingService;->zza:Ljava/util/Queue;

    invoke-interface {v6, v1}, Ljava/util/Queue;->contains(Ljava/lang/Object;)Z

    move-result v6

    if-eqz v6, :cond_b4

    .line 36
    invoke-static {v2, v8}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z

    move-result v6

    if-eqz v6, :cond_b2

    .line 37
    const-string v6, "Received duplicate message: "

    invoke-static {v1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;

    move-result-object v1

    invoke-virtual {v1}, Ljava/lang/String;->length()I

    move-result v10

    if-eqz v10, :cond_aa

    invoke-virtual {v6, v1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v1

    goto :goto_af

    :cond_aa
    new-instance v1, Ljava/lang/String;

    invoke-direct {v1, v6}, Ljava/lang/String;-><init>(Ljava/lang/String;)V

    :goto_af
    invoke-static {v2, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 38
    :cond_b2
    const/4 v1, 0x1

    goto :goto_c9

    .line 39
    :cond_b4
    sget-object v6, Lcom/google/firebase/messaging/FirebaseMessagingService;->zza:Ljava/util/Queue;

    invoke-interface {v6}, Ljava/util/Queue;->size()I

    move-result v6

    const/16 v10, 0xa

    if-lt v6, v10, :cond_c3

    .line 40
    sget-object v6, Lcom/google/firebase/messaging/FirebaseMessagingService;->zza:Ljava/util/Queue;

    invoke-interface {v6}, Ljava/util/Queue;->remove()Ljava/lang/Object;

    .line 41
    :cond_c3
    sget-object v6, Lcom/google/firebase/messaging/FirebaseMessagingService;->zza:Ljava/util/Queue;

    invoke-interface {v6, v1}, Ljava/util/Queue;->add(Ljava/lang/Object;)Z

    .line 42
    const/4 v1, 0x0

    .line 43
    :goto_c9
    if-nez v1, :cond_1cc

    .line 44
    nop

    .line 45
    const-string v1, "message_type"

    invoke-virtual {p1, v1}, Landroid/content/Intent;->getStringExtra(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v1

    .line 46
    const-string v6, "gcm"

    if-nez v1, :cond_d7

    .line 47
    move-object v1, v6

    .line 48
    :cond_d7
    const/4 v10, -0x1

    invoke-virtual {v1}, Ljava/lang/String;->hashCode()I

    move-result v11

    sparse-switch v11, :sswitch_data_1fc

    :cond_df
    goto :goto_105

    :sswitch_e0
    const-string v6, "send_event"

    invoke-virtual {v1, v6}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z

    move-result v6

    if-eqz v6, :cond_df

    const/4 v9, 0x2

    goto :goto_106

    :sswitch_ea
    const-string v6, "send_error"

    invoke-virtual {v1, v6}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z

    move-result v6

    if-eqz v6, :cond_df

    const/4 v9, 0x3

    goto :goto_106

    :sswitch_f4
    invoke-virtual {v1, v6}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z

    move-result v6

    if-eqz v6, :cond_df

    goto :goto_106

    :sswitch_fb
    const-string v6, "deleted_messages"

    invoke-virtual {v1, v6}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z

    move-result v6

    if-eqz v6, :cond_df

    const/4 v9, 0x1

    goto :goto_106

    :goto_105
    const/4 v9, -0x1

    :goto_106
    if-eqz v9, :cond_157

    if-eq v9, v7, :cond_152

    if-eq v9, v5, :cond_149

    if-eq v9, v8, :cond_12a

    .line 94
    const-string p1, "Received message with unknown type: "

    invoke-static {v1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;

    move-result-object v0

    invoke-virtual {v0}, Ljava/lang/String;->length()I

    move-result v1

    if-eqz v1, :cond_11f

    invoke-virtual {p1, v0}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;

    move-result-object p1

    goto :goto_125

    :cond_11f
    new-instance v0, Ljava/lang/String;

    invoke-direct {v0, p1}, Ljava/lang/String;-><init>(Ljava/lang/String;)V

    move-object p1, v0

    :goto_125
    invoke-static {v2, p1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I

    goto/16 :goto_1cc

    .line 84
    :cond_12a
    nop

    .line 85
    nop

    .line 86
    invoke-virtual {p1, v0}, Landroid/content/Intent;->getStringExtra(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    .line 87
    if-nez v0, :cond_138

    .line 88
    const-string v0, "message_id"

    invoke-virtual {p1, v0}, Landroid/content/Intent;->getStringExtra(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    .line 89
    :cond_138
    nop

    .line 90
    new-instance v1, Lcom/google/firebase/messaging/SendException;

    .line 91
    const-string v4, "error"

    invoke-virtual {p1, v4}, Landroid/content/Intent;->getStringExtra(Ljava/lang/String;)Ljava/lang/String;

    move-result-object p1

    invoke-direct {v1, p1}, Lcom/google/firebase/messaging/SendException;-><init>(Ljava/lang/String;)V

    .line 92
    invoke-virtual {p0, v0, v1}, Lcom/google/firebase/messaging/FirebaseMessagingService;->onSendError(Ljava/lang/String;Ljava/lang/Exception;)V

    .line 93
    goto/16 :goto_1cc

    .line 82
    :cond_149
    invoke-virtual {p1, v0}, Landroid/content/Intent;->getStringExtra(Ljava/lang/String;)Ljava/lang/String;

    move-result-object p1

    invoke-virtual {p0, p1}, Lcom/google/firebase/messaging/FirebaseMessagingService;->onMessageSent(Ljava/lang/String;)V

    .line 83
    goto/16 :goto_1cc

    .line 80
    :cond_152
    invoke-virtual {p0}, Lcom/google/firebase/messaging/FirebaseMessagingService;->onDeletedMessages()V

    .line 81
    goto/16 :goto_1cc

    .line 49
    :cond_157
    invoke-static {p1}, Lcom/google/firebase/messaging/zzo;->zzd(Landroid/content/Intent;)Z

    move-result v0

    if-eqz v0, :cond_160

    .line 50
    invoke-static {p1, v4}, Lcom/google/firebase/messaging/zzo;->zza(Landroid/content/Intent;Lcom/google/android/datatransport/Transport;)V

    .line 51
    :cond_160
    invoke-static {p1}, Lcom/google/firebase/messaging/zzo;->zze(Landroid/content/Intent;)Z

    move-result v0

    if-eqz v0, :cond_182

    .line 52
    :try_start_166
    sget-object v0, Lcom/google/firebase/messaging/FirebaseMessaging;->zza:Lcom/google/android/datatransport/TransportFactory;

    .line 53
    const-string v1, "FCM_CLIENT_EVENT_LOGGING"

    const-class v4, Ljava/lang/String;

    const-string v5, "json"

    .line 54
    invoke-static {v5}, Lcom/google/android/datatransport/Encoding;->of(Ljava/lang/String;)Lcom/google/android/datatransport/Encoding;

    move-result-object v5

    sget-object v6, Lcom/google/firebase/messaging/zzk;->zza:Lcom/google/android/datatransport/Transformer;

    .line 55
    invoke-interface {v0, v1, v4, v5, v6}, Lcom/google/android/datatransport/TransportFactory;->getTransport(Ljava/lang/String;Ljava/lang/Class;Lcom/google/android/datatransport/Encoding;Lcom/google/android/datatransport/Transformer;)Lcom/google/android/datatransport/Transport;

    move-result-object v0

    .line 56
    invoke-static {p1, v0}, Lcom/google/firebase/messaging/zzo;->zza(Landroid/content/Intent;Lcom/google/android/datatransport/Transport;)V
    :try_end_17b
    .catch Ljava/lang/NullPointerException; {:try_start_166 .. :try_end_17b} :catch_17c

    .line 57
    goto :goto_182

    .line 58
    :catch_17c
    move-exception v0

    .line 59
    const-string v0, "TransportFactory is null. Skip exporting message delivery metrics to Big Query"

    invoke-static {v2, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I

    .line 60
    :cond_182
    :goto_182
    nop

    .line 61
    invoke-virtual {p1}, Landroid/content/Intent;->getExtras()Landroid/os/Bundle;

    move-result-object v0

    .line 62
    if-nez v0, :cond_18e

    .line 63
    new-instance v0, Landroid/os/Bundle;

    invoke-direct {v0}, Landroid/os/Bundle;-><init>()V

    .line 64
    :cond_18e
    const-string v1, "androidx.contentpager.content.wakelockid"

    invoke-virtual {v0, v1}, Landroid/os/Bundle;->remove(Ljava/lang/String;)V

    .line 65
    invoke-static {v0}, Lcom/google/firebase/messaging/zzn;->zza(Landroid/os/Bundle;)Z

    move-result v1

    if-eqz v1, :cond_1c4

    .line 66
    new-instance v1, Lcom/google/firebase/messaging/zzn;

    invoke-direct {v1, v0}, Lcom/google/firebase/messaging/zzn;-><init>(Landroid/os/Bundle;)V

    .line 67
    invoke-static {}, Ljava/util/concurrent/Executors;->newSingleThreadExecutor()Ljava/util/concurrent/ExecutorService;

    move-result-object v4

    .line 68
    new-instance v5, Lcom/google/firebase/messaging/zzd;

    invoke-direct {v5, p0, v1, v4}, Lcom/google/firebase/messaging/zzd;-><init>(Landroid/content/Context;Lcom/google/firebase/messaging/zzn;Ljava/util/concurrent/Executor;)V

    .line 69
    :try_start_1a7
    invoke-virtual {v5}, Lcom/google/firebase/messaging/zzd;->zza()Z

    move-result v1
    :try_end_1ab
    .catchall {:try_start_1a7 .. :try_end_1ab} :catchall_1bf

    if-eqz v1, :cond_1b1

    .line 70
    invoke-interface {v4}, Ljava/util/concurrent/ExecutorService;->shutdown()V

    .line 71
    goto :goto_1cc

    .line 72
    :cond_1b1
    invoke-interface {v4}, Ljava/util/concurrent/ExecutorService;->shutdown()V

    .line 73
    nop

    .line 76
    invoke-static {p1}, Lcom/google/firebase/messaging/zzo;->zzd(Landroid/content/Intent;)Z

    move-result v1

    if-eqz v1, :cond_1c4

    .line 77
    invoke-static {p1}, Lcom/google/firebase/messaging/zzo;->zzc(Landroid/content/Intent;)V

    goto :goto_1c4

    .line 74
    :catchall_1bf
    move-exception p1

    invoke-interface {v4}, Ljava/util/concurrent/ExecutorService;->shutdown()V

    .line 75
    throw p1

    .line 78
    :cond_1c4
    :goto_1c4
    new-instance p1, Lcom/google/firebase/messaging/RemoteMessage;

    invoke-direct {p1, v0}, Lcom/google/firebase/messaging/RemoteMessage;-><init>(Landroid/os/Bundle;)V

    invoke-virtual {p0, p1}, Lcom/google/firebase/messaging/FirebaseMessagingService;->onMessageReceived(Lcom/google/firebase/messaging/RemoteMessage;)V

    .line 95
    :cond_1cc
    :goto_1cc
    const-wide/16 v0, 0x1

    :try_start_1ce
    sget-object p1, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;

    invoke-static {v3, v0, v1, p1}, Lcom/google/android/gms/tasks/Tasks;->await(Lcom/google/android/gms/tasks/Task;JLjava/util/concurrent/TimeUnit;)Ljava/lang/Object;
    :try_end_1d3
    .catch Ljava/util/concurrent/ExecutionException; {:try_start_1ce .. :try_end_1d3} :catch_1d8
    .catch Ljava/lang/InterruptedException; {:try_start_1ce .. :try_end_1d3} :catch_1d6
    .catch Ljava/util/concurrent/TimeoutException; {:try_start_1ce .. :try_end_1d3} :catch_1d4

    .line 96
    return-void

    .line 97
    :catch_1d4
    move-exception p1

    goto :goto_1d9

    :catch_1d6
    move-exception p1

    goto :goto_1d9

    :catch_1d8
    move-exception p1

    .line 98
    :goto_1d9
    invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;

    move-result-object p1

    invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;

    move-result-object v0

    invoke-virtual {v0}, Ljava/lang/String;->length()I

    move-result v0

    add-int/lit8 v0, v0, 0x14

    new-instance v1, Ljava/lang/StringBuilder;

    invoke-direct {v1, v0}, Ljava/lang/StringBuilder;-><init>(I)V

    const-string v0, "Message ack failed: "

    invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    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 {v2, p1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I

    .line 99
    return-void

    :sswitch_data_1fc
    .sparse-switch
        -0x7aedf14e -> :sswitch_fb
        0x18f11 -> :sswitch_f4
        0x308f3e91 -> :sswitch_ea
        0x3090df23 -> :sswitch_e0
    .end sparse-switch
.end method