a.smali

.class public final Lcom/imo/android/imoim/av/ptm/a;
.super Lcom/imo/android/imoim/managers/h;
.source "SourceFile"

# interfaces
.implements Lcom/imo/android/imoim/av/ptm/b;


# annotations
.annotation system Ldalvik/annotation/Signature;
    value = {
        "Lcom/imo/android/imoim/managers/h<",
        "Lcom/imo/android/imoim/av/ptm/b;",
        ">;",
        "Lcom/imo/android/imoim/av/ptm/b;"
    }
.end annotation


# static fields
.field private static g:Ljava/util/concurrent/Executor;


# instance fields
.field public a:Z

.field private b:Ljava/util/Queue;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/Queue<",
            "Lcom/imo/android/imoim/av/ptm/c;",
            ">;"
        }
    .end annotation
.end field

.field private c:Lcom/imo/android/imoim/av/ptm/PtmCThread;

.field private d:Z

.field private final e:Landroid/os/Handler;

.field private f:Ljava/lang/Runnable;


# direct methods
.method public constructor <init>()V
    .registers 4

    const-string v0, "PacketTrainMapManager"

    .line 50
    invoke-direct {p0, v0}, Lcom/imo/android/imoim/managers/h;-><init>(Ljava/lang/String;)V

    .line 52
    new-instance v0, Ljava/util/LinkedList;

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

    iput-object v0, p0, Lcom/imo/android/imoim/av/ptm/a;->b:Ljava/util/Queue;

    const/4 v0, 0x0

    .line 53
    iput-object v0, p0, Lcom/imo/android/imoim/av/ptm/a;->c:Lcom/imo/android/imoim/av/ptm/PtmCThread;

    const/4 v1, 0x0

    .line 54
    iput-boolean v1, p0, Lcom/imo/android/imoim/av/ptm/a;->a:Z

    .line 55
    iput-boolean v1, p0, Lcom/imo/android/imoim/av/ptm/a;->d:Z

    .line 56
    new-instance v1, Landroid/os/Handler;

    invoke-static {}, Landroid/os/Looper;->getMainLooper()Landroid/os/Looper;

    move-result-object v2

    invoke-direct {v1, v2}, Landroid/os/Handler;-><init>(Landroid/os/Looper;)V

    iput-object v1, p0, Lcom/imo/android/imoim/av/ptm/a;->e:Landroid/os/Handler;

    .line 57
    sput-object v0, Lcom/imo/android/imoim/av/ptm/a;->g:Ljava/util/concurrent/Executor;

    .line 58
    iput-object v0, p0, Lcom/imo/android/imoim/av/ptm/a;->f:Ljava/lang/Runnable;

    return-void
.end method

.method static synthetic a(Lcom/imo/android/imoim/av/ptm/a;)Ljava/lang/Runnable;
    .registers 2

    const/4 v0, 0x0

    .line 34
    iput-object v0, p0, Lcom/imo/android/imoim/av/ptm/a;->f:Ljava/lang/Runnable;

    return-object v0
.end method

.method private a(Lcom/imo/android/imoim/av/ptm/c;)Z
    .registers 7

    .line 110
    invoke-direct {p0}, Lcom/imo/android/imoim/av/ptm/a;->e()Z

    move-result v0

    const/4 v1, 0x0

    const/4 v2, 0x1

    const-string v3, "PacketTrainMapManager"

    if-nez v0, :cond_10

    const-string p1, "Failed to load the native lib!"

    .line 4079
    invoke-static {v3, p1, v2}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V

    return v1

    .line 115
    :cond_10
    sget-object v0, Lcom/imo/android/imoim/av/ptm/a;->g:Ljava/util/concurrent/Executor;

    if-nez v0, :cond_23

    .line 116
    new-instance v0, Lcom/imo/android/imoim/util/ExSerialExecutor;

    .line 5051
    invoke-static {}, Lsg/bigo/core/task/a$a;->a()Lsg/bigo/core/task/a;

    move-result-object v4

    .line 116
    invoke-virtual {v4}, Lsg/bigo/core/task/a;->d()Ljava/util/concurrent/ExecutorService;

    move-result-object v4

    invoke-direct {v0, v4}, Lcom/imo/android/imoim/util/ExSerialExecutor;-><init>(Ljava/util/concurrent/Executor;)V

    sput-object v0, Lcom/imo/android/imoim/av/ptm/a;->g:Ljava/util/concurrent/Executor;

    :cond_23
    const-string v0, "Starting a new test now"

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

    .line 120
    new-instance v0, Lcom/imo/android/imoim/av/ptm/PtmCThread;

    invoke-direct {v0, p0, p1}, Lcom/imo/android/imoim/av/ptm/PtmCThread;-><init>(Lcom/imo/android/imoim/av/ptm/b;Lcom/imo/android/imoim/av/ptm/c;)V

    iput-object v0, p0, Lcom/imo/android/imoim/av/ptm/a;->c:Lcom/imo/android/imoim/av/ptm/PtmCThread;

    .line 121
    sget-object p1, Lcom/imo/android/imoim/av/ptm/a;->g:Ljava/util/concurrent/Executor;

    new-array v1, v1, [Ljava/lang/Void;

    invoke-virtual {v0, p1, v1}, Lcom/imo/android/imoim/av/ptm/PtmCThread;->executeOnExecutor(Ljava/util/concurrent/Executor;[Ljava/lang/Object;)Landroid/os/AsyncTask;

    return v2
.end method

.method private static b(Ljava/lang/String;Lcom/imo/android/imoim/av/ptm/c;)V
    .registers 6

    const-string v0, "PacketTrainMapManager"

    .line 231
    new-instance v1, Ljava/util/HashMap;

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

    .line 9099
    iget-wide v2, p1, Lcom/imo/android/imoim/av/ptm/c;->a:J

    .line 232
    invoke-static {v2, v3}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;

    move-result-object v2

    const-string v3, "packet_train_id"

    invoke-interface {v1, v3, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 9103
    iget-object v2, p1, Lcom/imo/android/imoim/av/ptm/c;->b:[Ljava/lang/String;

    const/4 v3, 0x0

    .line 233
    aget-object v2, v2, v3

    const-string v3, "server_ip"

    invoke-interface {v1, v3, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 234
    sget-object v2, Lcom/imo/android/imoim/IMO;->d:Lcom/imo/android/imoim/managers/c;

    invoke-virtual {v2}, Lcom/imo/android/imoim/managers/c;->i()Ljava/lang/String;

    move-result-object v2

    const-string v3, "uid"

    invoke-interface {v1, v3, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 235
    invoke-static {}, Lcom/imo/android/imoim/util/ei;->a()Ljava/lang/String;

    move-result-object v2

    const-string v3, "udid"

    invoke-interface {v1, v3, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

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

    invoke-virtual {v2}, Lcom/imo/android/imoim/network/Dispatcher4;->getSSID()Ljava/lang/String;

    move-result-object v2

    const-string v3, "ssid"

    invoke-interface {v1, v3, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    const-string v2, "reason"

    .line 237
    invoke-interface {v1, v2, p0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 9131
    iget p0, p1, Lcom/imo/android/imoim/av/ptm/c;->h:I

    if-nez p0, :cond_4c

    const-string p0, "ptm_worker"

    const-string p1, "test_failed"

    .line 239
    invoke-static {p0, p1, v1}, Lcom/imo/android/imoim/av/ptm/a;->send(Ljava/lang/String;Ljava/lang/String;Ljava/util/Map;)V

    return-void

    .line 10131
    :cond_4c
    iget p0, p1, Lcom/imo/android/imoim/av/ptm/c;->h:I

    const/4 p1, 0x2

    if-ne p0, p1, :cond_67

    .line 242
    :try_start_51
    invoke-static {v1}, Lcom/imo/android/imoim/util/cg;->a(Ljava/util/Map;)Lorg/json/JSONObject;

    move-result-object p0

    const-string p1, "Sending log to Monitor"

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

    .line 244
    sget-object p1, Lcom/imo/android/imoim/IMO;->b:Lcom/imo/android/imoim/managers/bb;

    const-string v1, "ptm_ipv6"

    invoke-virtual {p1, v1, p0}, Lcom/imo/android/imoim/managers/bb;->b(Ljava/lang/String;Lorg/json/JSONObject;)V
    :try_end_61
    .catch Ljava/lang/Exception; {:try_start_51 .. :try_end_61} :catch_62

    return-void

    :catch_62
    const-string p0, "Error converting to json from map"

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

    :cond_67
    return-void
.end method

.method private b()Z
    .registers 2

    .line 126
    iget-object v0, p0, Lcom/imo/android/imoim/av/ptm/a;->c:Lcom/imo/android/imoim/av/ptm/PtmCThread;

    if-eqz v0, :cond_6

    const/4 v0, 0x1

    return v0

    :cond_6
    const/4 v0, 0x0

    return v0
.end method

.method private c()V
    .registers 5

    .line 268
    iget-object v0, p0, Lcom/imo/android/imoim/av/ptm/a;->f:Ljava/lang/Runnable;

    if-eqz v0, :cond_9

    .line 269
    iget-object v1, p0, Lcom/imo/android/imoim/av/ptm/a;->e:Landroid/os/Handler;

    invoke-virtual {v1, v0}, Landroid/os/Handler;->removeCallbacks(Ljava/lang/Runnable;)V

    .line 271
    :cond_9
    new-instance v0, Lcom/imo/android/imoim/av/ptm/a$1;

    invoke-direct {v0, p0}, Lcom/imo/android/imoim/av/ptm/a$1;-><init>(Lcom/imo/android/imoim/av/ptm/a;)V

    iput-object v0, p0, Lcom/imo/android/imoim/av/ptm/a;->f:Ljava/lang/Runnable;

    .line 277
    iget-object v1, p0, Lcom/imo/android/imoim/av/ptm/a;->e:Landroid/os/Handler;

    const-wide/16 v2, 0x7d0

    invoke-virtual {v1, v0, v2, v3}, Landroid/os/Handler;->postDelayed(Ljava/lang/Runnable;J)Z

    return-void
.end method

.method private d()Z
    .registers 2

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

    invoke-virtual {v0}, Lcom/imo/android/imoim/network/Dispatcher4;->hasQueuedMessages()Z

    move-result v0

    if-nez v0, :cond_24

    sget-object v0, Lcom/imo/android/imoim/IMO;->y:Lcom/imo/android/imoim/av/AVManager;

    invoke-virtual {v0}, Lcom/imo/android/imoim/av/AVManager;->k()Z

    move-result v0

    if-nez v0, :cond_24

    .line 282
    invoke-direct {p0}, Lcom/imo/android/imoim/av/ptm/a;->b()Z

    move-result v0

    if-nez v0, :cond_24

    iget-boolean v0, p0, Lcom/imo/android/imoim/av/ptm/a;->a:Z

    if-eqz v0, :cond_24

    sget-object v0, Lcom/imo/android/imoim/IMO;->z:Lcom/imo/android/imoim/av/GroupAVManager;

    invoke-virtual {v0}, Lcom/imo/android/imoim/av/GroupAVManager;->j()Z

    move-result v0

    if-eqz v0, :cond_24

    const/4 v0, 0x1

    return v0

    :cond_24
    const/4 v0, 0x0

    return v0
.end method

.method private e()Z
    .registers 8

    const-string v0, "PacketTrainMapManager"

    .line 286
    iget-boolean v1, p0, Lcom/imo/android/imoim/av/ptm/a;->d:Z

    const/4 v2, 0x1

    if-nez v1, :cond_32

    .line 288
    :try_start_7
    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v3

    const-string v1, "imostream"

    .line 289
    invoke-static {v1}, Lsg/bigo/common/ab;->a(Ljava/lang/String;)V

    .line 290
    new-instance v1, Ljava/lang/StringBuilder;

    const-string v5, "load imostream took "

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

    .line 291
    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v5

    sub-long/2addr v5, v3

    invoke-virtual {v1, v5, v6}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

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

    move-result-object v1

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

    .line 292
    iput-boolean v2, p0, Lcom/imo/android/imoim/av/ptm/a;->d:Z
    :try_end_28
    .catch Ljava/lang/UnsatisfiedLinkError; {:try_start_7 .. :try_end_28} :catch_29

    goto :goto_32

    :catch_29
    move-exception v1

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

    move-result-object v1

    const/4 v2, 0x0

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

    :cond_32
    :goto_32
    return v2
.end method

.method private f()V
    .registers 5

    const/4 v0, 0x0

    .line 340
    :goto_1
    iget-object v1, p0, Lcom/imo/android/imoim/av/ptm/a;->b:Ljava/util/Queue;

    invoke-interface {v1}, Ljava/util/Queue;->isEmpty()Z

    move-result v1

    if-nez v1, :cond_1f

    .line 341
    iget-object v1, p0, Lcom/imo/android/imoim/av/ptm/a;->b:Ljava/util/Queue;

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

    move-result-object v1

    check-cast v1, Lcom/imo/android/imoim/av/ptm/c;

    .line 342
    invoke-virtual {v1}, Lcom/imo/android/imoim/av/ptm/c;->a()Z

    move-result v1

    if-eqz v1, :cond_1f

    .line 345
    iget-object v1, p0, Lcom/imo/android/imoim/av/ptm/a;->b:Ljava/util/Queue;

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

    add-int/lit8 v0, v0, 0x1

    goto :goto_1

    :cond_1f
    const-string v1, "PacketTrainMapManager"

    if-lez v0, :cond_3d

    .line 350
    new-instance v2, Ljava/lang/StringBuilder;

    const-string v3, "Expired "

    invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V

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

    move-result-object v0

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

    const-string v0, " tests"

    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

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

    .line 352
    :cond_3d
    iget-object v0, p0, Lcom/imo/android/imoim/av/ptm/a;->b:Ljava/util/Queue;

    invoke-interface {v0}, Ljava/util/Queue;->isEmpty()Z

    move-result v0

    if-nez v0, :cond_6d

    sget-object v0, Lcom/imo/android/imoim/IMO;->y:Lcom/imo/android/imoim/av/AVManager;

    invoke-virtual {v0}, Lcom/imo/android/imoim/av/AVManager;->k()Z

    move-result v0

    if-nez v0, :cond_6d

    .line 353
    new-instance v0, Ljava/lang/StringBuilder;

    const-string v2, "There are "

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

    iget-object v2, p0, Lcom/imo/android/imoim/av/ptm/a;->b:Ljava/util/Queue;

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

    move-result v2

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

    move-result-object v2

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

    const-string v2, " tests queued"

    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

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

    :cond_6d
    return-void
.end method


# virtual methods
.method public final a()V
    .registers 3

    .line 252
    sget-object v0, Lcom/imo/android/imoim/IMO;->y:Lcom/imo/android/imoim/av/AVManager;

    invoke-virtual {v0}, Lcom/imo/android/imoim/av/AVManager;->k()Z

    move-result v0

    if-nez v0, :cond_f

    const-string v0, "PacketTrainMapManager"

    const-string v1, "Checking for any scheduled PTM tests"

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

    .line 255
    :cond_f
    invoke-direct {p0}, Lcom/imo/android/imoim/av/ptm/a;->f()V

    .line 256
    iget-object v0, p0, Lcom/imo/android/imoim/av/ptm/a;->b:Ljava/util/Queue;

    invoke-interface {v0}, Ljava/util/Queue;->isEmpty()Z

    move-result v0

    if-nez v0, :cond_2c

    invoke-direct {p0}, Lcom/imo/android/imoim/av/ptm/a;->d()Z

    move-result v0

    if-eqz v0, :cond_2c

    .line 258
    iget-object v0, p0, Lcom/imo/android/imoim/av/ptm/a;->b:Ljava/util/Queue;

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

    move-result-object v0

    check-cast v0, Lcom/imo/android/imoim/av/ptm/c;

    .line 259
    invoke-direct {p0, v0}, Lcom/imo/android/imoim/av/ptm/a;->a(Lcom/imo/android/imoim/av/ptm/c;)Z

    return-void

    .line 260
    :cond_2c
    iget-object v0, p0, Lcom/imo/android/imoim/av/ptm/a;->b:Ljava/util/Queue;

    invoke-interface {v0}, Ljava/util/Queue;->isEmpty()Z

    move-result v0

    if-nez v0, :cond_37

    .line 263
    invoke-direct {p0}, Lcom/imo/android/imoim/av/ptm/a;->c()V

    :cond_37
    return-void
.end method

.method public final a(JLjava/lang/String;IIII)V
    .registers 9

    const/4 v0, 0x0

    .line 150
    iput-object v0, p0, Lcom/imo/android/imoim/av/ptm/a;->c:Lcom/imo/android/imoim/av/ptm/PtmCThread;

    .line 151
    invoke-virtual {p0}, Lcom/imo/android/imoim/av/ptm/a;->a()V

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

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

    .line 5209
    invoke-static {p1, p2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;

    move-result-object p1

    const-string p2, "packet_train_id"

    invoke-interface {v0, p2, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    const-string p1, "server_ip"

    .line 5210
    invoke-interface {v0, p1, p3}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 5211
    invoke-static {p4}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;

    move-result-object p1

    const-string p2, "probes_sent"

    invoke-interface {v0, p2, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 5212
    invoke-static {p5}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;

    move-result-object p1

    const-string p2, "probes_recv"

    invoke-interface {v0, p2, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 5213
    invoke-static {p6}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;

    move-result-object p1

    const-string p2, "median_rtt"

    invoke-interface {v0, p2, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 5214
    invoke-static {p7}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;

    move-result-object p1

    const-string p2, "median_jitter"

    invoke-interface {v0, p2, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 5215
    sget-object p1, Lcom/imo/android/imoim/IMO;->d:Lcom/imo/android/imoim/managers/c;

    invoke-virtual {p1}, Lcom/imo/android/imoim/managers/c;->i()Ljava/lang/String;

    move-result-object p1

    const-string p2, "uid"

    invoke-interface {v0, p2, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 5216
    invoke-static {}, Lcom/imo/android/imoim/util/ei;->a()Ljava/lang/String;

    move-result-object p1

    const-string p2, "udid"

    invoke-interface {v0, p2, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

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

    invoke-virtual {p1}, Lcom/imo/android/imoim/network/Dispatcher4;->getSSID()Ljava/lang/String;

    move-result-object p1

    const-string p2, "ssid"

    invoke-interface {v0, p2, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    const-string p1, "ptm_worker"

    const-string p2, "push_log"

    .line 5218
    invoke-static {p1, p2, v0}, Lcom/imo/android/imoim/av/ptm/a;->send(Ljava/lang/String;Ljava/lang/String;Ljava/util/Map;)V

    return-void
.end method

.method public final a(JLjava/lang/String;IIIILjava/lang/String;I)V
    .registers 12

    const-string v0, "PacketTrainMapManager"

    const/4 v1, 0x0

    .line 162
    iput-object v1, p0, Lcom/imo/android/imoim/av/ptm/a;->c:Lcom/imo/android/imoim/av/ptm/PtmCThread;

    .line 163
    invoke-virtual {p0}, Lcom/imo/android/imoim/av/ptm/a;->a()V

    .line 6185
    new-instance v1, Ljava/util/HashMap;

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

    .line 6186
    invoke-static {p1, p2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;

    move-result-object p1

    const-string p2, "packet_train_id"

    invoke-interface {v1, p2, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    const-string p1, "server_ip"

    .line 6187
    invoke-interface {v1, p1, p3}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 6188
    invoke-static {p4}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;

    move-result-object p1

    const-string p2, "probes_sent"

    invoke-interface {v1, p2, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 6189
    invoke-static {p5}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;

    move-result-object p1

    const-string p2, "probes_recv"

    invoke-interface {v1, p2, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 6190
    invoke-static {p6}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;

    move-result-object p1

    const-string p2, "median_rtt"

    invoke-interface {v1, p2, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 6191
    invoke-static {p7}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;

    move-result-object p1

    const-string p2, "median_jitter"

    invoke-interface {v1, p2, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 6192
    sget-object p1, Lcom/imo/android/imoim/IMO;->d:Lcom/imo/android/imoim/managers/c;

    invoke-virtual {p1}, Lcom/imo/android/imoim/managers/c;->i()Ljava/lang/String;

    move-result-object p1

    const-string p2, "uid"

    invoke-interface {v1, p2, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 6193
    invoke-static {}, Lcom/imo/android/imoim/util/ei;->a()Ljava/lang/String;

    move-result-object p1

    const-string p2, "udid"

    invoke-interface {v1, p2, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

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

    invoke-virtual {p1}, Lcom/imo/android/imoim/network/Dispatcher4;->getSSID()Ljava/lang/String;

    move-result-object p1

    const-string p2, "ssid"

    invoke-interface {v1, p2, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    const-string p1, "local_ip"

    .line 6195
    invoke-interface {v1, p1, p8}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 6196
    invoke-static {p9}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;

    move-result-object p1

    const-string p2, "local_port"

    invoke-interface {v1, p2, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 6198
    :try_start_6c
    invoke-static {v1}, Lcom/imo/android/imoim/util/cg;->a(Ljava/util/Map;)Lorg/json/JSONObject;

    move-result-object p1

    const-string p2, "Sending log to Monitor"

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

    .line 6200
    sget-object p2, Lcom/imo/android/imoim/IMO;->b:Lcom/imo/android/imoim/managers/bb;

    const-string p3, "ptm_ipv6"

    invoke-virtual {p2, p3, p1}, Lcom/imo/android/imoim/managers/bb;->b(Ljava/lang/String;Lorg/json/JSONObject;)V
    :try_end_7c
    .catch Ljava/lang/Exception; {:try_start_6c .. :try_end_7c} :catch_7d

    return-void

    :catch_7d
    const/4 p1, 0x1

    const-string p2, "Error creating json from map"

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

    return-void
.end method

.method public final a(Ljava/lang/String;Lcom/imo/android/imoim/av/ptm/c;)V
    .registers 5

    const/4 v0, 0x0

    .line 171
    iput-object v0, p0, Lcom/imo/android/imoim/av/ptm/a;->c:Lcom/imo/android/imoim/av/ptm/PtmCThread;

    .line 7131
    iget v0, p2, Lcom/imo/android/imoim/av/ptm/c;->h:I

    if-eqz v0, :cond_c

    .line 8131
    iget v0, p2, Lcom/imo/android/imoim/av/ptm/c;->h:I

    const/4 v1, 0x2

    if-ne v0, v1, :cond_f

    .line 174
    :cond_c
    invoke-static {p1, p2}, Lcom/imo/android/imoim/av/ptm/a;->b(Ljava/lang/String;Lcom/imo/android/imoim/av/ptm/c;)V

    :cond_f
    return-void
.end method

.method public final a(Lorg/json/JSONObject;)V
    .registers 7

    const-string v0, "name"

    .line 79
    invoke-static {v0, p1}, Lcom/imo/android/imoim/util/cg;->a(Ljava/lang/String;Lorg/json/JSONObject;)Ljava/lang/String;

    move-result-object v0

    .line 80
    invoke-static {v0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;

    move-result-object v1

    const-string v2, "handleMessage() "

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

    move-result-object v1

    const-string v2, "PacketTrainMapManager"

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

    const-string v1, "start_test"

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

    move-result v1

    if-nez v1, :cond_2d

    const-string v1, "nat_probe"

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

    move-result v1

    if-nez v1, :cond_2d

    const-string v1, "ipv6_test"

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

    move-result v0

    if-eqz v0, :cond_79

    .line 82
    :cond_2d
    new-instance v0, Lcom/imo/android/imoim/av/ptm/c;

    invoke-direct {v0, p1}, Lcom/imo/android/imoim/av/ptm/c;-><init>(Lorg/json/JSONObject;)V

    .line 83
    iget-boolean p1, p0, Lcom/imo/android/imoim/av/ptm/a;->a:Z

    const/4 v1, 0x1

    if-nez p1, :cond_42

    const-string p1, "PTM is disabled!"

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

    const-string p1, "ptm-disabled"

    .line 85
    invoke-static {p1, v0}, Lcom/imo/android/imoim/av/ptm/a;->b(Ljava/lang/String;Lcom/imo/android/imoim/av/ptm/c;)V

    return-void

    :cond_42
    const-string p1, "starting a new test"

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

    .line 2098
    invoke-direct {p0}, Lcom/imo/android/imoim/av/ptm/a;->d()Z

    move-result p1

    const/4 v3, 0x0

    if-nez p1, :cond_69

    .line 2222
    invoke-direct {p0}, Lcom/imo/android/imoim/av/ptm/a;->f()V

    .line 2223
    iget-object p1, p0, Lcom/imo/android/imoim/av/ptm/a;->b:Ljava/util/Queue;

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

    move-result p1

    const/4 v4, 0x5

    if-ge p1, v4, :cond_61

    .line 2224
    iget-object p1, p0, Lcom/imo/android/imoim/av/ptm/a;->b:Ljava/util/Queue;

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

    const/4 p1, 0x1

    goto :goto_62

    :cond_61
    const/4 p1, 0x0

    :goto_62
    if-eqz p1, :cond_6d

    .line 2100
    invoke-direct {p0}, Lcom/imo/android/imoim/av/ptm/a;->c()V

    const/4 v3, 0x1

    goto :goto_6d

    .line 2106
    :cond_69
    invoke-direct {p0, v0}, Lcom/imo/android/imoim/av/ptm/a;->a(Lcom/imo/android/imoim/av/ptm/c;)Z

    move-result v3

    :cond_6d
    :goto_6d
    if-nez v3, :cond_79

    const-string p1, "already reached the maximum number of tests!"

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

    const-string p1, "too-many-queued-tests"

    .line 91
    invoke-static {p1, v0}, Lcom/imo/android/imoim/av/ptm/a;->b(Ljava/lang/String;Lcom/imo/android/imoim/av/ptm/c;)V

    :cond_79
    return-void
.end method

.method public final b(Lorg/json/JSONObject;)V
    .registers 4

    const/4 v0, 0x0

    .line 130
    iput-object v0, p0, Lcom/imo/android/imoim/av/ptm/a;->c:Lcom/imo/android/imoim/av/ptm/PtmCThread;

    .line 131
    invoke-virtual {p0}, Lcom/imo/android/imoim/av/ptm/a;->a()V

    if-eqz p1, :cond_2b

    :try_start_8
    const-string v0, "carrier"

    .line 134
    invoke-static {}, Lcom/imo/android/imoim/util/ei;->U()Ljava/lang/String;

    move-result-object v1

    invoke-virtual {p1, v0, v1}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;

    const-string v0, "carrier_code"

    .line 135
    invoke-static {}, Lcom/imo/android/imoim/util/ei;->W()Ljava/lang/String;

    move-result-object v1

    invoke-virtual {p1, v0, v1}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;

    const-string v0, "connection"

    .line 136
    invoke-static {}, Lcom/imo/android/imoim/util/ei;->J()Ljava/lang/String;

    move-result-object v1

    invoke-virtual {p1, v0, v1}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
    :try_end_23
    .catch Lorg/json/JSONException; {:try_start_8 .. :try_end_23} :catch_23

    .line 140
    :catch_23
    sget-object v0, Lcom/imo/android/imoim/IMO;->b:Lcom/imo/android/imoim/managers/bb;

    const-string v1, "nat_probe"

    invoke-virtual {v0, v1, p1}, Lcom/imo/android/imoim/managers/bb;->b(Ljava/lang/String;Lorg/json/JSONObject;)V

    return-void

    :cond_2b
    const/4 p1, 0x1

    const-string v0, "PacketTrainMapManager"

    const-string v1, "log is null after nat probe test"

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

    return-void
.end method