.class Lcom/google/firebase/database/connection/Connection; .super Ljava/lang/Object; .source "Connection.java" # interfaces .implements Lcom/google/firebase/database/connection/WebsocketConnection$Delegate; # annotations .annotation system Ldalvik/annotation/MemberClasses; value = { Lcom/google/firebase/database/connection/Connection$State;, Lcom/google/firebase/database/connection/Connection$Delegate;, Lcom/google/firebase/database/connection/Connection$DisconnectReason; } .end annotation # static fields .field private static final REQUEST_PAYLOAD:Ljava/lang/String; = "d" .field private static final REQUEST_TYPE:Ljava/lang/String; = "t" .field private static final REQUEST_TYPE_DATA:Ljava/lang/String; = "d" .field private static final SERVER_CONTROL_MESSAGE:Ljava/lang/String; = "c" .field private static final SERVER_CONTROL_MESSAGE_DATA:Ljava/lang/String; = "d" .field private static final SERVER_CONTROL_MESSAGE_HELLO:Ljava/lang/String; = "h" .field private static final SERVER_CONTROL_MESSAGE_RESET:Ljava/lang/String; = "r" .field private static final SERVER_CONTROL_MESSAGE_SHUTDOWN:Ljava/lang/String; = "s" .field private static final SERVER_CONTROL_MESSAGE_TYPE:Ljava/lang/String; = "t" .field private static final SERVER_DATA_MESSAGE:Ljava/lang/String; = "d" .field private static final SERVER_ENVELOPE_DATA:Ljava/lang/String; = "d" .field private static final SERVER_ENVELOPE_TYPE:Ljava/lang/String; = "t" .field private static final SERVER_HELLO_HOST:Ljava/lang/String; = "h" .field private static final SERVER_HELLO_SESSION_ID:Ljava/lang/String; = "s" .field private static final SERVER_HELLO_TIMESTAMP:Ljava/lang/String; = "ts" .field private static connectionIds:J # instance fields .field private conn:Lcom/google/firebase/database/connection/WebsocketConnection; .field private delegate:Lcom/google/firebase/database/connection/Connection$Delegate; .field private hostInfo:Lcom/google/firebase/database/connection/HostInfo; .field private final logger:Lcom/google/firebase/database/logging/LogWrapper; .field private state:Lcom/google/firebase/database/connection/Connection$State; # direct methods .method public static constructor ()V .locals 0 return-void .end method .method public constructor (Lcom/google/firebase/database/connection/ConnectionContext;Lcom/google/firebase/database/connection/HostInfo;Ljava/lang/String;Lcom/google/firebase/database/connection/Connection$Delegate;Ljava/lang/String;Ljava/lang/String;)V .locals 7 .line 1 invoke-direct {p0}, Ljava/lang/Object;->()V .line 2 sget-wide v0, Lcom/google/firebase/database/connection/Connection;->connectionIds:J const-wide/16 v2, 0x1 add-long/2addr v2, v0 sput-wide v2, Lcom/google/firebase/database/connection/Connection;->connectionIds:J .line 3 iput-object p2, p0, Lcom/google/firebase/database/connection/Connection;->hostInfo:Lcom/google/firebase/database/connection/HostInfo; .line 4 iput-object p4, p0, Lcom/google/firebase/database/connection/Connection;->delegate:Lcom/google/firebase/database/connection/Connection$Delegate; .line 5 new-instance p4, Lcom/google/firebase/database/logging/LogWrapper; invoke-virtual {p1}, Lcom/google/firebase/database/connection/ConnectionContext;->getLogger()Lcom/google/firebase/database/logging/Logger; move-result-object v2 const-string v3, "conn_" invoke-static {v3, v0, v1}, Landroidx/camera/core/l1;->a(Ljava/lang/String;J)Ljava/lang/String; move-result-object v0 const-string v1, "Connection" invoke-direct {p4, v2, v1, v0}, Lcom/google/firebase/database/logging/LogWrapper;->(Lcom/google/firebase/database/logging/Logger;Ljava/lang/String;Ljava/lang/String;)V iput-object p4, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; .line 6 sget-object p4, Lcom/google/firebase/database/connection/Connection$State;->REALTIME_CONNECTING:Lcom/google/firebase/database/connection/Connection$State; iput-object p4, p0, Lcom/google/firebase/database/connection/Connection;->state:Lcom/google/firebase/database/connection/Connection$State; .line 7 new-instance p4, Lcom/google/firebase/database/connection/WebsocketConnection; move-object v0, p4 move-object v1, p1 move-object v2, p2 move-object v3, p3 move-object v4, p6 move-object v5, p0 move-object v6, p5 invoke-direct/range {v0 .. v6}, Lcom/google/firebase/database/connection/WebsocketConnection;->(Lcom/google/firebase/database/connection/ConnectionContext;Lcom/google/firebase/database/connection/HostInfo;Ljava/lang/String;Ljava/lang/String;Lcom/google/firebase/database/connection/WebsocketConnection$Delegate;Ljava/lang/String;)V iput-object p4, p0, Lcom/google/firebase/database/connection/Connection;->conn:Lcom/google/firebase/database/connection/WebsocketConnection; return-void .end method .method private onConnectionReady(JLjava/lang/String;)V .locals 3 .line 1 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; invoke-virtual {v0}, Lcom/google/firebase/database/logging/LogWrapper;->logsDebug()Z move-result v0 if-eqz v0, :cond_0 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; const/4 v1, 0x0 new-array v1, v1, [Ljava/lang/Object; const-string v2, "realtime connection established" invoke-virtual {v0, v2, v1}, Lcom/google/firebase/database/logging/LogWrapper;->debug(Ljava/lang/String;[Ljava/lang/Object;)V .line 2 :cond_0 sget-object v0, Lcom/google/firebase/database/connection/Connection$State;->REALTIME_CONNECTED:Lcom/google/firebase/database/connection/Connection$State; iput-object v0, p0, Lcom/google/firebase/database/connection/Connection;->state:Lcom/google/firebase/database/connection/Connection$State; .line 3 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->delegate:Lcom/google/firebase/database/connection/Connection$Delegate; invoke-interface {v0, p1, p2, p3}, Lcom/google/firebase/database/connection/Connection$Delegate;->onReady(JLjava/lang/String;)V return-void .end method .method private onConnectionShutdown(Ljava/lang/String;)V .locals 3 .line 1 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; invoke-virtual {v0}, Lcom/google/firebase/database/logging/LogWrapper;->logsDebug()Z move-result v0 if-eqz v0, :cond_0 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; const/4 v1, 0x0 new-array v1, v1, [Ljava/lang/Object; const-string v2, "Connection shutdown command received. Shutting down..." invoke-virtual {v0, v2, v1}, Lcom/google/firebase/database/logging/LogWrapper;->debug(Ljava/lang/String;[Ljava/lang/Object;)V .line 2 :cond_0 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->delegate:Lcom/google/firebase/database/connection/Connection$Delegate; invoke-interface {v0, p1}, Lcom/google/firebase/database/connection/Connection$Delegate;->onKill(Ljava/lang/String;)V .line 3 invoke-virtual {p0}, Lcom/google/firebase/database/connection/Connection;->close()V return-void .end method .method private onControlMessage(Ljava/util/Map;)V .locals 4 .annotation system Ldalvik/annotation/Signature; value = { "(", "Ljava/util/Map<", "Ljava/lang/String;", "Ljava/lang/Object;", ">;)V" } .end annotation .line 1 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; invoke-virtual {v0}, Lcom/google/firebase/database/logging/LogWrapper;->logsDebug()Z move-result v0 const/4 v1, 0x0 if-eqz v0, :cond_0 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; const-string v2, "Got control message: " invoke-static {v2}, Landroid/support/v4/media/d;->a(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {p1}, Ljava/lang/Object;->toString()Ljava/lang/String; move-result-object v3 invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v2 new-array v3, v1, [Ljava/lang/Object; invoke-virtual {v0, v2, v3}, Lcom/google/firebase/database/logging/LogWrapper;->debug(Ljava/lang/String;[Ljava/lang/Object;)V :cond_0 :try_start_0 const-string v0, "t" .line 2 invoke-interface {p1, v0}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v0 check-cast v0, Ljava/lang/String; if-eqz v0, :cond_4 const-string v2, "s" .line 3 invoke-virtual {v0, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v2 :try_end_0 .catch Ljava/lang/ClassCastException; {:try_start_0 .. :try_end_0} :catch_0 const-string v3, "d" if-eqz v2, :cond_1 .line 4 :try_start_1 invoke-interface {p1, v3}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object p1 check-cast p1, Ljava/lang/String; .line 5 invoke-direct {p0, p1}, Lcom/google/firebase/database/connection/Connection;->onConnectionShutdown(Ljava/lang/String;)V goto/16 :goto_0 :cond_1 const-string v2, "r" .line 6 invoke-virtual {v0, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v2 if-eqz v2, :cond_2 .line 7 invoke-interface {p1, v3}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object p1 check-cast p1, Ljava/lang/String; .line 8 invoke-direct {p0, p1}, Lcom/google/firebase/database/connection/Connection;->onReset(Ljava/lang/String;)V goto/16 :goto_0 :cond_2 const-string v2, "h" .line 9 invoke-virtual {v0, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v2 if-eqz v2, :cond_3 .line 10 invoke-interface {p1, v3}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object p1 check-cast p1, Ljava/util/Map; .line 11 invoke-direct {p0, p1}, Lcom/google/firebase/database/connection/Connection;->onHandshake(Ljava/util/Map;)V goto :goto_0 .line 12 :cond_3 iget-object p1, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; invoke-virtual {p1}, Lcom/google/firebase/database/logging/LogWrapper;->logsDebug()Z move-result p1 if-eqz p1, :cond_7 iget-object p1, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;->()V const-string v3, "Ignoring unknown control message: " invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v0 new-array v2, v1, [Ljava/lang/Object; invoke-virtual {p1, v0, v2}, Lcom/google/firebase/database/logging/LogWrapper;->debug(Ljava/lang/String;[Ljava/lang/Object;)V goto :goto_0 .line 13 :cond_4 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; invoke-virtual {v0}, Lcom/google/firebase/database/logging/LogWrapper;->logsDebug()Z move-result v0 if-eqz v0, :cond_5 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;->()V const-string v3, "Got invalid control message: " invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p1}, Ljava/lang/Object;->toString()Ljava/lang/String; move-result-object p1 invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 new-array v2, v1, [Ljava/lang/Object; invoke-virtual {v0, p1, v2}, Lcom/google/firebase/database/logging/LogWrapper;->debug(Ljava/lang/String;[Ljava/lang/Object;)V .line 14 :cond_5 invoke-virtual {p0}, Lcom/google/firebase/database/connection/Connection;->close()V :try_end_1 .catch Ljava/lang/ClassCastException; {:try_start_1 .. :try_end_1} :catch_0 goto :goto_0 :catch_0 move-exception p1 .line 15 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; invoke-virtual {v0}, Lcom/google/firebase/database/logging/LogWrapper;->logsDebug()Z move-result v0 if-eqz v0, :cond_6 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; const-string v2, "Failed to parse control message: " invoke-static {v2}, Landroid/support/v4/media/d;->a(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {p1}, Ljava/lang/ClassCastException;->toString()Ljava/lang/String; move-result-object p1 invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 new-array v1, v1, [Ljava/lang/Object; invoke-virtual {v0, p1, v1}, Lcom/google/firebase/database/logging/LogWrapper;->debug(Ljava/lang/String;[Ljava/lang/Object;)V .line 16 :cond_6 invoke-virtual {p0}, Lcom/google/firebase/database/connection/Connection;->close()V :cond_7 :goto_0 return-void .end method .method private onDataMessage(Ljava/util/Map;)V .locals 3 .annotation system Ldalvik/annotation/Signature; value = { "(", "Ljava/util/Map<", "Ljava/lang/String;", "Ljava/lang/Object;", ">;)V" } .end annotation .line 1 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; invoke-virtual {v0}, Lcom/google/firebase/database/logging/LogWrapper;->logsDebug()Z move-result v0 if-eqz v0, :cond_0 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; const-string v1, "received data message: " invoke-static {v1}, Landroid/support/v4/media/d;->a(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v1 invoke-virtual {p1}, Ljava/lang/Object;->toString()Ljava/lang/String; move-result-object v2 invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 const/4 v2, 0x0 new-array v2, v2, [Ljava/lang/Object; invoke-virtual {v0, v1, v2}, Lcom/google/firebase/database/logging/LogWrapper;->debug(Ljava/lang/String;[Ljava/lang/Object;)V .line 2 :cond_0 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->delegate:Lcom/google/firebase/database/connection/Connection$Delegate; invoke-interface {v0, p1}, Lcom/google/firebase/database/connection/Connection$Delegate;->onDataMessage(Ljava/util/Map;)V return-void .end method .method private onHandshake(Ljava/util/Map;)V .locals 4 .annotation system Ldalvik/annotation/Signature; value = { "(", "Ljava/util/Map<", "Ljava/lang/String;", "Ljava/lang/Object;", ">;)V" } .end annotation const-string v0, "ts" .line 1 invoke-interface {p1, v0}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v0 check-cast v0, Ljava/lang/Long; invoke-virtual {v0}, Ljava/lang/Long;->longValue()J move-result-wide v0 const-string v2, "h" .line 2 invoke-interface {p1, v2}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v2 check-cast v2, Ljava/lang/String; .line 3 iget-object v3, p0, Lcom/google/firebase/database/connection/Connection;->delegate:Lcom/google/firebase/database/connection/Connection$Delegate; invoke-interface {v3, v2}, Lcom/google/firebase/database/connection/Connection$Delegate;->onCacheHost(Ljava/lang/String;)V const-string v2, "s" .line 4 invoke-interface {p1, v2}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object p1 check-cast p1, Ljava/lang/String; .line 5 iget-object v2, p0, Lcom/google/firebase/database/connection/Connection;->state:Lcom/google/firebase/database/connection/Connection$State; sget-object v3, Lcom/google/firebase/database/connection/Connection$State;->REALTIME_CONNECTING:Lcom/google/firebase/database/connection/Connection$State; if-ne v2, v3, :cond_0 .line 6 iget-object v2, p0, Lcom/google/firebase/database/connection/Connection;->conn:Lcom/google/firebase/database/connection/WebsocketConnection; invoke-virtual {v2}, Lcom/google/firebase/database/connection/WebsocketConnection;->start()V .line 7 invoke-direct {p0, v0, v1, p1}, Lcom/google/firebase/database/connection/Connection;->onConnectionReady(JLjava/lang/String;)V :cond_0 return-void .end method .method private onReset(Ljava/lang/String;)V .locals 3 .line 1 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; invoke-virtual {v0}, Lcom/google/firebase/database/logging/LogWrapper;->logsDebug()Z move-result v0 if-eqz v0, :cond_0 .line 2 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; const-string v1, "Got a reset; killing connection to " invoke-static {v1}, Landroid/support/v4/media/d;->a(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v1 iget-object v2, p0, Lcom/google/firebase/database/connection/Connection;->hostInfo:Lcom/google/firebase/database/connection/HostInfo; .line 3 invoke-virtual {v2}, Lcom/google/firebase/database/connection/HostInfo;->getHost()Ljava/lang/String; move-result-object v2 invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v2, "; Updating internalHost to " invoke-virtual {v1, v2}, 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 v1 const/4 v2, 0x0 new-array v2, v2, [Ljava/lang/Object; .line 4 invoke-virtual {v0, v1, v2}, Lcom/google/firebase/database/logging/LogWrapper;->debug(Ljava/lang/String;[Ljava/lang/Object;)V .line 5 :cond_0 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->delegate:Lcom/google/firebase/database/connection/Connection$Delegate; invoke-interface {v0, p1}, Lcom/google/firebase/database/connection/Connection$Delegate;->onCacheHost(Ljava/lang/String;)V .line 6 sget-object p1, Lcom/google/firebase/database/connection/Connection$DisconnectReason;->SERVER_RESET:Lcom/google/firebase/database/connection/Connection$DisconnectReason; invoke-virtual {p0, p1}, Lcom/google/firebase/database/connection/Connection;->close(Lcom/google/firebase/database/connection/Connection$DisconnectReason;)V return-void .end method .method private sendData(Ljava/util/Map;Z)V .locals 3 .annotation system Ldalvik/annotation/Signature; value = { "(", "Ljava/util/Map<", "Ljava/lang/String;", "Ljava/lang/Object;", ">;Z)V" } .end annotation .line 1 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->state:Lcom/google/firebase/database/connection/Connection$State; sget-object v1, Lcom/google/firebase/database/connection/Connection$State;->REALTIME_CONNECTED:Lcom/google/firebase/database/connection/Connection$State; const/4 v2, 0x0 if-eq v0, v1, :cond_0 .line 2 iget-object p1, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; new-array p2, v2, [Ljava/lang/Object; const-string v0, "Tried to send on an unconnected connection" invoke-virtual {p1, v0, p2}, Lcom/google/firebase/database/logging/LogWrapper;->debug(Ljava/lang/String;[Ljava/lang/Object;)V goto :goto_1 :cond_0 if-eqz p2, :cond_1 .line 3 iget-object p2, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; new-array v0, v2, [Ljava/lang/Object; const-string v1, "Sending data (contents hidden)" invoke-virtual {p2, v1, v0}, Lcom/google/firebase/database/logging/LogWrapper;->debug(Ljava/lang/String;[Ljava/lang/Object;)V goto :goto_0 .line 4 :cond_1 iget-object p2, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; const/4 v0, 0x1 new-array v0, v0, [Ljava/lang/Object; aput-object p1, v0, v2 const-string v1, "Sending data: %s" invoke-virtual {p2, v1, v0}, Lcom/google/firebase/database/logging/LogWrapper;->debug(Ljava/lang/String;[Ljava/lang/Object;)V .line 5 :goto_0 iget-object p2, p0, Lcom/google/firebase/database/connection/Connection;->conn:Lcom/google/firebase/database/connection/WebsocketConnection; invoke-virtual {p2, p1}, Lcom/google/firebase/database/connection/WebsocketConnection;->send(Ljava/util/Map;)V :goto_1 return-void .end method # virtual methods .method public close()V .locals 1 .line 8 sget-object v0, Lcom/google/firebase/database/connection/Connection$DisconnectReason;->OTHER:Lcom/google/firebase/database/connection/Connection$DisconnectReason; invoke-virtual {p0, v0}, Lcom/google/firebase/database/connection/Connection;->close(Lcom/google/firebase/database/connection/Connection$DisconnectReason;)V return-void .end method .method public close(Lcom/google/firebase/database/connection/Connection$DisconnectReason;)V .locals 4 .line 1 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->state:Lcom/google/firebase/database/connection/Connection$State; sget-object v1, Lcom/google/firebase/database/connection/Connection$State;->REALTIME_DISCONNECTED:Lcom/google/firebase/database/connection/Connection$State; if-eq v0, v1, :cond_2 .line 2 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; invoke-virtual {v0}, Lcom/google/firebase/database/logging/LogWrapper;->logsDebug()Z move-result v0 if-eqz v0, :cond_0 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; const/4 v2, 0x0 new-array v2, v2, [Ljava/lang/Object; const-string v3, "closing realtime connection" invoke-virtual {v0, v3, v2}, Lcom/google/firebase/database/logging/LogWrapper;->debug(Ljava/lang/String;[Ljava/lang/Object;)V .line 3 :cond_0 iput-object v1, p0, Lcom/google/firebase/database/connection/Connection;->state:Lcom/google/firebase/database/connection/Connection$State; .line 4 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->conn:Lcom/google/firebase/database/connection/WebsocketConnection; if-eqz v0, :cond_1 .line 5 invoke-virtual {v0}, Lcom/google/firebase/database/connection/WebsocketConnection;->close()V const/4 v0, 0x0 .line 6 iput-object v0, p0, Lcom/google/firebase/database/connection/Connection;->conn:Lcom/google/firebase/database/connection/WebsocketConnection; .line 7 :cond_1 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->delegate:Lcom/google/firebase/database/connection/Connection$Delegate; invoke-interface {v0, p1}, Lcom/google/firebase/database/connection/Connection$Delegate;->onDisconnect(Lcom/google/firebase/database/connection/Connection$DisconnectReason;)V :cond_2 return-void .end method .method public injectConnectionFailure()V .locals 0 .line 1 invoke-virtual {p0}, Lcom/google/firebase/database/connection/Connection;->close()V return-void .end method .method public onDisconnect(Z)V .locals 2 const/4 v0, 0x0 .line 1 iput-object v0, p0, Lcom/google/firebase/database/connection/Connection;->conn:Lcom/google/firebase/database/connection/WebsocketConnection; const/4 v0, 0x0 if-nez p1, :cond_0 .line 2 iget-object p1, p0, Lcom/google/firebase/database/connection/Connection;->state:Lcom/google/firebase/database/connection/Connection$State; sget-object v1, Lcom/google/firebase/database/connection/Connection$State;->REALTIME_CONNECTING:Lcom/google/firebase/database/connection/Connection$State; if-ne p1, v1, :cond_0 .line 3 iget-object p1, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; invoke-virtual {p1}, Lcom/google/firebase/database/logging/LogWrapper;->logsDebug()Z move-result p1 if-eqz p1, :cond_1 iget-object p1, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; new-array v0, v0, [Ljava/lang/Object; const-string v1, "Realtime connection failed" invoke-virtual {p1, v1, v0}, Lcom/google/firebase/database/logging/LogWrapper;->debug(Ljava/lang/String;[Ljava/lang/Object;)V goto :goto_0 .line 4 :cond_0 iget-object p1, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; invoke-virtual {p1}, Lcom/google/firebase/database/logging/LogWrapper;->logsDebug()Z move-result p1 if-eqz p1, :cond_1 iget-object p1, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; new-array v0, v0, [Ljava/lang/Object; const-string v1, "Realtime connection lost" invoke-virtual {p1, v1, v0}, Lcom/google/firebase/database/logging/LogWrapper;->debug(Ljava/lang/String;[Ljava/lang/Object;)V .line 5 :cond_1 :goto_0 invoke-virtual {p0}, Lcom/google/firebase/database/connection/Connection;->close()V return-void .end method .method public onMessage(Ljava/util/Map;)V .locals 4 .annotation system Ldalvik/annotation/Signature; value = { "(", "Ljava/util/Map<", "Ljava/lang/String;", "Ljava/lang/Object;", ">;)V" } .end annotation const-string v0, "d" const/4 v1, 0x0 :try_start_0 const-string v2, "t" .line 1 invoke-interface {p1, v2}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v2 check-cast v2, Ljava/lang/String; if-eqz v2, :cond_2 .line 2 invoke-virtual {v2, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v3 if-eqz v3, :cond_0 .line 3 invoke-interface {p1, v0}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object p1 check-cast p1, Ljava/util/Map; .line 4 invoke-direct {p0, p1}, Lcom/google/firebase/database/connection/Connection;->onDataMessage(Ljava/util/Map;)V goto/16 :goto_0 :cond_0 const-string v3, "c" .line 5 invoke-virtual {v2, v3}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v3 if-eqz v3, :cond_1 .line 6 invoke-interface {p1, v0}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object p1 check-cast p1, Ljava/util/Map; .line 7 invoke-direct {p0, p1}, Lcom/google/firebase/database/connection/Connection;->onControlMessage(Ljava/util/Map;)V goto :goto_0 .line 8 :cond_1 iget-object p1, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; invoke-virtual {p1}, Lcom/google/firebase/database/logging/LogWrapper;->logsDebug()Z move-result p1 if-eqz p1, :cond_5 .line 9 iget-object p1, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; new-instance v0, Ljava/lang/StringBuilder; invoke-direct {v0}, Ljava/lang/StringBuilder;->()V const-string v3, "Ignoring unknown server message type: " invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v0 new-array v2, v1, [Ljava/lang/Object; invoke-virtual {p1, v0, v2}, Lcom/google/firebase/database/logging/LogWrapper;->debug(Ljava/lang/String;[Ljava/lang/Object;)V goto :goto_0 .line 10 :cond_2 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; invoke-virtual {v0}, Lcom/google/firebase/database/logging/LogWrapper;->logsDebug()Z move-result v0 if-eqz v0, :cond_3 .line 11 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;->()V const-string v3, "Failed to parse server message: missing message type:" invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; .line 12 invoke-virtual {p1}, Ljava/lang/Object;->toString()Ljava/lang/String; move-result-object p1 invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 new-array v2, v1, [Ljava/lang/Object; .line 13 invoke-virtual {v0, p1, v2}, Lcom/google/firebase/database/logging/LogWrapper;->debug(Ljava/lang/String;[Ljava/lang/Object;)V .line 14 :cond_3 invoke-virtual {p0}, Lcom/google/firebase/database/connection/Connection;->close()V :try_end_0 .catch Ljava/lang/ClassCastException; {:try_start_0 .. :try_end_0} :catch_0 goto :goto_0 :catch_0 move-exception p1 .line 15 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; invoke-virtual {v0}, Lcom/google/firebase/database/logging/LogWrapper;->logsDebug()Z move-result v0 if-eqz v0, :cond_4 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; const-string v2, "Failed to parse server message: " invoke-static {v2}, Landroid/support/v4/media/d;->a(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {p1}, Ljava/lang/ClassCastException;->toString()Ljava/lang/String; move-result-object p1 invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 new-array v1, v1, [Ljava/lang/Object; invoke-virtual {v0, p1, v1}, Lcom/google/firebase/database/logging/LogWrapper;->debug(Ljava/lang/String;[Ljava/lang/Object;)V .line 16 :cond_4 invoke-virtual {p0}, Lcom/google/firebase/database/connection/Connection;->close()V :cond_5 :goto_0 return-void .end method .method public open()V .locals 3 .line 1 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; invoke-virtual {v0}, Lcom/google/firebase/database/logging/LogWrapper;->logsDebug()Z move-result v0 if-eqz v0, :cond_0 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->logger:Lcom/google/firebase/database/logging/LogWrapper; const/4 v1, 0x0 new-array v1, v1, [Ljava/lang/Object; const-string v2, "Opening a connection" invoke-virtual {v0, v2, v1}, Lcom/google/firebase/database/logging/LogWrapper;->debug(Ljava/lang/String;[Ljava/lang/Object;)V .line 2 :cond_0 iget-object v0, p0, Lcom/google/firebase/database/connection/Connection;->conn:Lcom/google/firebase/database/connection/WebsocketConnection; invoke-virtual {v0}, Lcom/google/firebase/database/connection/WebsocketConnection;->open()V return-void .end method .method public sendRequest(Ljava/util/Map;Z)V .locals 3 .annotation system Ldalvik/annotation/Signature; value = { "(", "Ljava/util/Map<", "Ljava/lang/String;", "Ljava/lang/Object;", ">;Z)V" } .end annotation .line 1 new-instance v0, Ljava/util/HashMap; invoke-direct {v0}, Ljava/util/HashMap;->()V const-string v1, "t" const-string v2, "d" .line 2 invoke-virtual {v0, v1, v2}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; .line 3 invoke-virtual {v0, v2, p1}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; .line 4 invoke-direct {p0, v0, p2}, Lcom/google/firebase/database/connection/Connection;->sendData(Ljava/util/Map;Z)V return-void .end method