f.smali

.class public final Lcom/imo/android/imoim/f;
.super Ljava/lang/Object;
.source "SourceFile"


# annotations
.annotation system Ldalvik/annotation/MemberClasses;
    value = {
        Lcom/imo/android/imoim/f$a;,
        Lcom/imo/android/imoim/f$b;
    }
.end annotation


# static fields
.field static final e:Lcom/imo/android/imoim/util/eu;


# instance fields
.field public a:Lcom/imo/android/imoim/f$b;

.field public b:Ljava/lang/String;

.field public c:Ljava/lang/String;

.field public d:Ljava/lang/String;

.field f:Ljava/util/Map;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/Map<",
            "Ljava/lang/Integer;",
            "Lcom/imo/android/imoim/f$a;",
            ">;"
        }
    .end annotation
.end field

.field public g:Z


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

    .line 61
    new-instance v0, Lcom/imo/android/imoim/util/eu;

    invoke-direct {v0}, Lcom/imo/android/imoim/util/eu;-><init>()V

    sput-object v0, Lcom/imo/android/imoim/f;->e:Lcom/imo/android/imoim/util/eu;

    return-void
.end method

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

    .line 67
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    .line 63
    new-instance v0, Ljava/util/HashMap;

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

    iput-object v0, p0, Lcom/imo/android/imoim/f;->f:Ljava/util/Map;

    .line 68
    new-instance v0, Landroid/os/HandlerThread;

    const-string v1, "gcmhandler"

    invoke-direct {v0, v1}, Landroid/os/HandlerThread;-><init>(Ljava/lang/String;)V

    .line 69
    invoke-virtual {v0}, Landroid/os/HandlerThread;->start()V

    .line 70
    new-instance v1, Lcom/imo/android/imoim/f$b;

    invoke-virtual {v0}, Landroid/os/HandlerThread;->getLooper()Landroid/os/Looper;

    move-result-object v0

    invoke-direct {v1, p0, v0}, Lcom/imo/android/imoim/f$b;-><init>(Lcom/imo/android/imoim/f;Landroid/os/Looper;)V

    iput-object v1, p0, Lcom/imo/android/imoim/f;->a:Lcom/imo/android/imoim/f$b;

    const/4 v0, 0x2

    .line 71
    invoke-virtual {v1, v0}, Lcom/imo/android/imoim/f$b;->sendEmptyMessage(I)Z

    return-void
.end method

.method public static a([B)Ljava/lang/String;
    .registers 3

    .line 246
    :try_start_0
    sget-object v0, Lcom/imo/android/imoim/f;->e:Lcom/imo/android/imoim/util/eu;

    invoke-virtual {v0, p0}, Lcom/imo/android/imoim/util/eu;->a([B)[B

    move-result-object p0

    const/4 v0, 0x2

    .line 247
    invoke-static {p0, v0}, Landroid/util/Base64;->encode([BI)[B

    move-result-object p0

    .line 248
    new-instance v0, Ljava/lang/String;

    const-string v1, "UTF-8"

    invoke-direct {v0, p0, v1}, Ljava/lang/String;-><init>([BLjava/lang/String;)V
    :try_end_12
    .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_12} :catch_13

    return-object v0

    :catch_13
    move-exception p0

    .line 251
    invoke-virtual {p0}, Ljava/lang/Exception;->toString()Ljava/lang/String;

    move-result-object p0

    const/4 v0, 0x1

    const-string v1, "GCMNetwork4"

    .line 1079
    invoke-static {v1, p0, v0}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V

    const/4 p0, 0x0

    return-object p0
.end method

.method static synthetic a(Ljava/lang/String;)Ljava/util/List;
    .registers 9

    .line 7257
    new-instance v0, Ljava/util/ArrayList;

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

    .line 7259
    invoke-virtual {p0}, Ljava/lang/String;->length()I

    move-result v1

    add-int/lit16 v2, v1, 0xdac

    add-int/lit8 v2, v2, -0x1

    .line 7261
    div-int/lit16 v2, v2, 0xdac

    .line 7262
    new-instance v3, Ljava/util/Random;

    invoke-direct {v3}, Ljava/util/Random;-><init>()V

    .line 7263
    invoke-virtual {v3}, Ljava/util/Random;->nextInt()I

    move-result v3

    invoke-static {v3}, Ljava/lang/Integer;->toString(I)Ljava/lang/String;

    move-result-object v3

    const/4 v4, 0x0

    :goto_1d
    if-ge v4, v2, :cond_52

    mul-int/lit16 v5, v4, 0xdac

    add-int/lit16 v6, v5, 0xdac

    .line 7267
    invoke-static {v1, v6}, Ljava/lang/Math;->min(II)I

    move-result v6

    .line 7268
    invoke-virtual {p0, v5, v6}, Ljava/lang/String;->substring(II)Ljava/lang/String;

    move-result-object v5

    .line 7269
    new-instance v6, Ljava/util/HashMap;

    invoke-direct {v6}, Ljava/util/HashMap;-><init>()V

    const-string v7, "data"

    .line 7270
    invoke-interface {v6, v7, v5}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 7271
    invoke-static {v4}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object v5

    const-string v7, "chunk"

    invoke-interface {v6, v7, v5}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 7272
    invoke-static {v2}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object v5

    const-string v7, "total"

    invoke-interface {v6, v7, v5}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    const-string v5, "object_id"

    .line 7273
    invoke-interface {v6, v5, v3}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 7274
    invoke-interface {v0, v6}, Ljava/util/List;->add(Ljava/lang/Object;)Z

    add-int/lit8 v4, v4, 0x1

    goto :goto_1d

    :cond_52
    return-object v0
.end method

.method static synthetic a(Lcom/imo/android/imoim/f;Ljava/lang/String;)V
    .registers 22

    move-object/from16 v0, p0

    const-string v1, "got old name_channel, ignore"

    const-string v2, "channel_id matches!"

    const-string v3, "got name_channel"

    const-string v4, "data"

    const-string v5, "gcm"

    const-string v6, "GCMNetwork4"

    .line 1130
    sget-object v7, Lcom/imo/android/imoim/IMO;->c:Lcom/imo/android/imoim/network/Dispatcher4;

    invoke-virtual {v7}, Lcom/imo/android/imoim/network/Dispatcher4;->updateLastRecvTime()V

    const/4 v7, 0x1

    .line 1133
    :try_start_14
    new-instance v8, Lorg/json/JSONObject;

    move-object/from16 v9, p1

    invoke-direct {v8, v9}, Lorg/json/JSONObject;-><init>(Ljava/lang/String;)V

    const-string v10, "chunk"

    .line 1134
    invoke-virtual {v8, v10}, Lorg/json/JSONObject;->getInt(Ljava/lang/String;)I

    move-result v10

    const-string v11, "total"

    .line 1135
    invoke-virtual {v8, v11}, Lorg/json/JSONObject;->getInt(Ljava/lang/String;)I

    move-result v11

    const-string v12, "object_id"

    .line 1136
    invoke-virtual {v8, v12}, Lorg/json/JSONObject;->getInt(Ljava/lang/String;)I

    move-result v12

    .line 1137
    invoke-virtual {v8, v4}, Lorg/json/JSONObject;->getString(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v8

    .line 1139
    iget-object v13, v0, Lcom/imo/android/imoim/f;->f:Ljava/util/Map;

    invoke-static {v12}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;

    move-result-object v14

    invoke-interface {v13, v14}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object v13

    check-cast v13, Lcom/imo/android/imoim/f$a;

    if-nez v13, :cond_4d

    .line 1141
    new-instance v13, Lcom/imo/android/imoim/f$a;

    invoke-direct {v13, v11}, Lcom/imo/android/imoim/f$a;-><init>(I)V

    .line 1142
    iget-object v11, v0, Lcom/imo/android/imoim/f;->f:Ljava/util/Map;

    invoke-static {v12}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;

    move-result-object v14

    invoke-interface {v11, v14, v13}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 1351
    :cond_4d
    iget-object v11, v13, Lcom/imo/android/imoim/f$a;->a:[Ljava/lang/String;

    aget-object v11, v11, v10

    if-nez v11, :cond_5d

    .line 1352
    iget-object v11, v13, Lcom/imo/android/imoim/f$a;->a:[Ljava/lang/String;

    aput-object v8, v11, v10

    .line 1353
    iget v8, v13, Lcom/imo/android/imoim/f$a;->c:I

    add-int/2addr v8, v7

    iput v8, v13, Lcom/imo/android/imoim/f$a;->c:I

    goto :goto_62

    :cond_5d
    const-string v8, "duplicated chunk"

    .line 2071
    invoke-static {v6, v8}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 2359
    :goto_62
    iget v8, v13, Lcom/imo/android/imoim/f$a;->b:I

    iget v10, v13, Lcom/imo/android/imoim/f$a;->c:I

    const/4 v11, 0x0

    if-ne v8, v10, :cond_6b

    const/4 v8, 0x1

    goto :goto_6c

    :cond_6b
    const/4 v8, 0x0

    :goto_6c
    if-eqz v8, :cond_119

    .line 1146
    iget-object v8, v0, Lcom/imo/android/imoim/f;->f:Ljava/util/Map;

    invoke-static {v12}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;

    move-result-object v10

    invoke-interface {v8, v10}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;

    .line 1147
    new-instance v8, Lorg/json/JSONObject;

    invoke-virtual {v13}, Lcom/imo/android/imoim/f$a;->a()Ljava/lang/String;

    move-result-object v10

    invoke-direct {v8, v10}, Lorg/json/JSONObject;-><init>(Ljava/lang/String;)V

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

    move-result v9
    :try_end_84
    .catch Lorg/json/JSONException; {:try_start_14 .. :try_end_84} :catch_11c
    .catch Ljava/lang/NullPointerException; {:try_start_14 .. :try_end_84} :catch_11a

    int-to-long v9, v9

    :try_start_85
    const-string v12, "method"

    .line 3158
    invoke-virtual {v8, v12}, Lorg/json/JSONObject;->getString(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v12

    const-string v13, "name_channel"

    .line 3159
    invoke-virtual {v12, v13}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z

    move-result v12

    if-eqz v12, :cond_fa

    .line 4071
    invoke-static {v6, v3}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 3161
    invoke-static {}, Lcom/imo/android/imoim/network/NetworkLogger;->getInstance()Lcom/imo/android/imoim/network/NetworkLogger;

    move-result-object v4

    invoke-virtual {v4, v6, v3}, Lcom/imo/android/imoim/network/NetworkLogger;->log(Ljava/lang/String;Ljava/lang/String;)V

    const-string v3, "connection_id"

    .line 3163
    invoke-virtual {v8, v3}, Lorg/json/JSONObject;->getString(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v3

    .line 3164
    iget-object v4, v0, Lcom/imo/android/imoim/f;->c:Ljava/lang/String;

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

    move-result v3

    if-nez v3, :cond_b6

    .line 5071
    invoke-static {v6, v1}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 3166
    invoke-static {}, Lcom/imo/android/imoim/network/NetworkLogger;->getInstance()Lcom/imo/android/imoim/network/NetworkLogger;

    move-result-object v0

    invoke-virtual {v0, v6, v1}, Lcom/imo/android/imoim/network/NetworkLogger;->log(Ljava/lang/String;Ljava/lang/String;)V

    return-void

    .line 6071
    :cond_b6
    invoke-static {v6, v2}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 3170
    invoke-static {}, Lcom/imo/android/imoim/network/NetworkLogger;->getInstance()Lcom/imo/android/imoim/network/NetworkLogger;

    move-result-object v1

    invoke-virtual {v1, v6, v2}, Lcom/imo/android/imoim/network/NetworkLogger;->log(Ljava/lang/String;Ljava/lang/String;)V

    const-string v1, "com.imo.android.imoim.TIMEOUT_GCM"

    .line 3172
    invoke-static {}, Lcom/imo/android/imoim/IMO;->a()Lcom/imo/android/imoim/IMO;

    move-result-object v2

    invoke-static {v1, v2}, Lcom/imo/android/imoim/Alarms;->a(Ljava/lang/String;Landroid/content/Context;)V

    .line 3173
    iput-boolean v11, v0, Lcom/imo/android/imoim/f;->g:Z

    .line 3174
    iget-object v1, v0, Lcom/imo/android/imoim/f;->c:Ljava/lang/String;

    iput-object v1, v0, Lcom/imo/android/imoim/f;->b:Ljava/lang/String;

    .line 3176
    new-instance v1, Lcom/imo/android/imoim/network/ConnectData3;

    const-string v9, "gcm"

    const-string v10, "gcm"

    const/4 v11, -0x1

    iget-object v12, v0, Lcom/imo/android/imoim/f;->d:Ljava/lang/String;

    const/4 v13, -0x1

    const/4 v14, 0x1

    move-object v8, v1

    invoke-direct/range {v8 .. v14}, Lcom/imo/android/imoim/network/ConnectData3;-><init>(Ljava/lang/String;Ljava/lang/String;ILjava/lang/String;IZ)V

    .line 3177
    invoke-static {}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->get()Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;

    move-result-object v0

    const/4 v2, -0x1

    invoke-virtual {v0, v5, v2}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->markGetChannelName(Ljava/lang/String;I)V

    .line 3178
    invoke-static {}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->get()Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;

    move-result-object v0

    invoke-virtual {v0, v5, v2}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->markTcpConnectSuc(Ljava/lang/String;I)V

    .line 3179
    sget-object v0, Lcom/imo/android/imoim/IMO;->c:Lcom/imo/android/imoim/network/Dispatcher4;

    invoke-virtual {v0, v5, v7, v1}, Lcom/imo/android/imoim/network/Dispatcher4;->senderStarted(Ljava/lang/String;ZLcom/imo/android/imoim/network/ConnectData3;)V

    .line 3181
    invoke-static {}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->get()Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;

    move-result-object v0

    invoke-virtual {v0, v7}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->setGCMConnectState(I)V

    return-void

    .line 3183
    :cond_fa
    new-instance v14, Lorg/json/JSONObject;

    invoke-direct {v14}, Lorg/json/JSONObject;-><init>()V

    .line 3184
    invoke-virtual {v14, v4, v8}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;

    .line 3186
    sget-object v12, Lcom/imo/android/imoim/IMO;->c:Lcom/imo/android/imoim/network/Dispatcher4;

    const-string v13, "gcm"

    const/4 v15, 0x1

    invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J

    move-result-wide v18

    move-wide/from16 v16, v9

    invoke-virtual/range {v12 .. v19}, Lcom/imo/android/imoim/network/Dispatcher4;->onMessageFromOtherThread(Ljava/lang/String;Lorg/json/JSONObject;ZJJ)V
    :try_end_110
    .catch Lorg/json/JSONException; {:try_start_85 .. :try_end_110} :catch_111
    .catch Ljava/lang/NullPointerException; {:try_start_85 .. :try_end_110} :catch_11a

    return-void

    :catch_111
    move-exception v0

    .line 3189
    :try_start_112
    invoke-virtual {v0}, Lorg/json/JSONException;->toString()Ljava/lang/String;

    move-result-object v0

    .line 6079
    invoke-static {v6, v0, v7}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V
    :try_end_119
    .catch Lorg/json/JSONException; {:try_start_112 .. :try_end_119} :catch_11c
    .catch Ljava/lang/NullPointerException; {:try_start_112 .. :try_end_119} :catch_11a

    :cond_119
    return-void

    :catch_11a
    move-exception v0

    goto :goto_11d

    :catch_11c
    move-exception v0

    .line 1152
    :goto_11d
    invoke-virtual {v0}, Ljava/lang/Exception;->toString()Ljava/lang/String;

    move-result-object v0

    .line 7079
    invoke-static {v6, v0, v7}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V

    return-void
.end method


# virtual methods
.method public final a(Lcom/imo/android/imoim/util/y;)V
    .registers 11

    .line 201
    iget-object v0, p0, Lcom/imo/android/imoim/f;->b:Ljava/lang/String;

    if-nez v0, :cond_15

    const-string p1, "GCMNetwork4"

    const-string v0, "no connection id"

    .line 1071
    invoke-static {p1, v0}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 203
    invoke-static {}, Lcom/imo/android/imoim/network/NetworkLogger;->getInstance()Lcom/imo/android/imoim/network/NetworkLogger;

    move-result-object v0

    const-string v1, "no connection id(wait for reconnect)"

    invoke-virtual {v0, p1, v1}, Lcom/imo/android/imoim/network/NetworkLogger;->log(Ljava/lang/String;Ljava/lang/String;)V

    return-void

    :cond_15
    const/4 v0, 0x1

    .line 209
    invoke-virtual {p1, v0}, Lcom/imo/android/imoim/util/y;->a(Z)[B

    move-result-object v0

    .line 233
    invoke-static {v0}, Lcom/imo/android/imoim/f;->a([B)Ljava/lang/String;

    move-result-object v0

    .line 234
    iget-object v1, p1, Lcom/imo/android/imoim/util/y;->o:Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;

    if-eqz v1, :cond_2a

    .line 235
    iget-object v1, p1, Lcom/imo/android/imoim/util/y;->o:Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;

    invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J

    move-result-wide v2

    iput-wide v2, v1, Lcom/imo/android/imoim/network/Dispatcher4$RequestInfo;->realSendTs:J

    .line 237
    :cond_2a
    iget-object v1, p0, Lcom/imo/android/imoim/f;->a:Lcom/imo/android/imoim/f$b;

    const/4 v2, 0x0

    invoke-virtual {v1, v2, v0}, Lcom/imo/android/imoim/f$b;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;

    move-result-object v1

    .line 238
    iget-object v2, p0, Lcom/imo/android/imoim/f;->a:Lcom/imo/android/imoim/f$b;

    invoke-virtual {v2, v1}, Lcom/imo/android/imoim/f$b;->sendMessage(Landroid/os/Message;)Z

    if-eqz v0, :cond_47

    .line 240
    iget-object v3, p1, Lcom/imo/android/imoim/util/y;->c:Ljava/lang/String;

    iget-object v4, p1, Lcom/imo/android/imoim/util/y;->a:Ljava/lang/String;

    iget-object v5, p1, Lcom/imo/android/imoim/util/y;->d:Ljava/lang/String;

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

    move-result p1

    int-to-long v6, p1

    const/4 v8, 0x1

    invoke-static/range {v3 .. v8}, Lcom/imo/android/imoim/network/stat/TrafficReport;->reportRequestTraffic(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;JZ)V

    :cond_47
    return-void
.end method