ConnectionService.smali

.class public Lio/rong/imlib/ConnectionService;
.super Ljava/lang/Object;
.source "ConnectionService.java"


# annotations
.annotation system Ldalvik/annotation/MemberClasses;
    value = {
        Lio/rong/imlib/ConnectionService$ReconnectRunnable;,
        Lio/rong/imlib/ConnectionService$ConnectStatusListener;,
        Lio/rong/imlib/ConnectionService$SingleHolder;
    }
.end annotation


# static fields
.field private static final RECONNECT_INTERVAL:I = 0x3e8

.field private static final RECONNECT_INTERVAL_MAX_LENGTH:I = 0xa

.field private static final TAG:Ljava/lang/String; = "ConnectionService"


# instance fields
.field private mAppKey:Ljava/lang/String;

.field private mCallBackExecutor:Ljava/util/concurrent/Executor;

.field private mConnectCallback:Lio/rong/imlib/NativeClient$IConnectResultCallback;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Lio/rong/imlib/NativeClient$IConnectResultCallback<",
            "Ljava/lang/String;",
            ">;"
        }
    .end annotation
.end field

.field private mConnectListener:Lio/rong/imlib/ConnectionService$ConnectStatusListener;

.field private mConnectionState:Lio/rong/imlib/ConnectionState;

.field private mContext:Landroid/content/Context;

.field private mEnableReconnectKick:Z

.field private mHandler:Landroid/os/Handler;

.field private mIsForeground:Z

.field private mNativeObj:Lio/rong/imlib/NativeObject;

.field private mRcRetryCount:Ljava/util/concurrent/atomic/AtomicInteger;

.field private mReconnectInterval:[Ljava/lang/String;

.field private mReconnectRunnable:Lio/rong/imlib/ConnectionService$ReconnectRunnable;

.field private volatile mToken:Ljava/lang/String;


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

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

    const/4 v0, 0x0

    .line 3
    iput-object v0, p0, Lio/rong/imlib/ConnectionService;->mContext:Landroid/content/Context;

    const/4 v0, 0x0

    .line 4
    iput-boolean v0, p0, Lio/rong/imlib/ConnectionService;->mEnableReconnectKick:Z

    .line 5
    new-instance v1, Ljava/util/concurrent/atomic/AtomicInteger;

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

    iput-object v1, p0, Lio/rong/imlib/ConnectionService;->mRcRetryCount:Ljava/util/concurrent/atomic/AtomicInteger;

    const/16 v1, 0xa

    .line 6
    new-array v1, v1, [Ljava/lang/String;

    const-string v2, "0"

    aput-object v2, v1, v0

    const/4 v0, 0x1

    const-string v2, "0.25"

    aput-object v2, v1, v0

    const/4 v0, 0x2

    const-string v2, "0.5"

    aput-object v2, v1, v0

    const/4 v0, 0x3

    const-string v2, "1"

    aput-object v2, v1, v0

    const/4 v0, 0x4

    const-string v2, "2"

    aput-object v2, v1, v0

    const/4 v0, 0x5

    const-string v2, "4"

    aput-object v2, v1, v0

    const/4 v0, 0x6

    const-string v2, "8"

    aput-object v2, v1, v0

    const/4 v0, 0x7

    const-string v2, "16"

    aput-object v2, v1, v0

    const/16 v0, 0x8

    const-string v2, "32"

    aput-object v2, v1, v0

    const/16 v0, 0x9

    const-string v2, "64"

    aput-object v2, v1, v0

    iput-object v1, p0, Lio/rong/imlib/ConnectionService;->mReconnectInterval:[Ljava/lang/String;

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

    const-string v1, "IPC_RECONNECT_WORK"

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

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

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

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

    move-result-object v0

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

    iput-object v1, p0, Lio/rong/imlib/ConnectionService;->mHandler:Landroid/os/Handler;

    .line 10
    new-instance v0, Lio/rong/imlib/ConnectionService$1;

    invoke-direct {v0, p0}, Lio/rong/imlib/ConnectionService$1;-><init>(Lio/rong/imlib/ConnectionService;)V

    invoke-static {v0}, Ljava/util/concurrent/Executors;->newSingleThreadExecutor(Ljava/util/concurrent/ThreadFactory;)Ljava/util/concurrent/ExecutorService;

    move-result-object v0

    iput-object v0, p0, Lio/rong/imlib/ConnectionService;->mCallBackExecutor:Ljava/util/concurrent/Executor;

    .line 11
    new-instance v0, Lio/rong/imlib/ConnectionState;

    invoke-direct {v0}, Lio/rong/imlib/ConnectionState;-><init>()V

    iput-object v0, p0, Lio/rong/imlib/ConnectionService;->mConnectionState:Lio/rong/imlib/ConnectionState;

    return-void
.end method

.method synthetic constructor <init>(Lio/rong/imlib/ConnectionService$1;)V
    .registers 2

    .line 1
    invoke-direct {p0}, Lio/rong/imlib/ConnectionService;-><init>()V

    return-void
.end method

.method private OnProtocolDBOpened(I)V
    .registers 2

    .line 1
    invoke-direct {p0, p1}, Lio/rong/imlib/ConnectionService;->responseDBOpenBlock(I)V

    return-void
.end method

.method private OnProtocolPongReceived()V
    .registers 3

    const-string v0, "ConnectionService"

    const-string v1, "ConnectionStatusListener OnPongReceived."

    .line 1
    invoke-static {v0, v1}, Lio/rong/common/rlog/RLog;->i(Ljava/lang/String;Ljava/lang/String;)I

    return-void
.end method

.method private OnProtocolRmtpComplete(ILjava/lang/String;ISLjava/lang/String;)V
    .registers 14

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

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

    const-string v1, "[connect] operationComplete status:"

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

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

    const-string v1, ", logInfo:"

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

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

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

    move-result-object p5

    const-string v0, "ConnectionService"

    invoke-static {v0, p5}, Lio/rong/common/rlog/RLog;->d(Ljava/lang/String;Ljava/lang/String;)I

    const/4 p5, 0x5

    const/4 v0, 0x4

    const/4 v1, 0x2

    const-string v2, "P-connect-R"

    const/4 v3, 0x3

    const/4 v4, 0x0

    const/4 v5, 0x1

    if-nez p1, :cond_6d

    .line 2
    new-array p5, p5, [Ljava/lang/Object;

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

    move-result-object v6

    aput-object v6, p5, v4

    aput-object p2, p5, v5

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

    move-result-object p3

    aput-object p3, p5, v1

    invoke-static {p4}, Ljava/lang/Short;->valueOf(S)Ljava/lang/Short;

    move-result-object p3

    aput-object p3, p5, v3

    iget-object p3, p0, Lio/rong/imlib/ConnectionService;->mContext:Landroid/content/Context;

    invoke-static {p3}, Lio/rong/imlib/common/DeviceUtils;->getNetworkType(Landroid/content/Context;)Ljava/lang/String;

    move-result-object p3

    aput-object p3, p5, v0

    const-string p3, "status_code|user_id|native_code|duration|network"

    .line 4
    invoke-static {v3, v5, v2, p3, p5}, Lio/rong/common/fwlog/FwLog;->write(IILjava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V

    .line 5
    invoke-virtual {p0}, Lio/rong/imlib/ConnectionService;->resetReconnectCount()V

    .line 6
    invoke-direct {p0}, Lio/rong/imlib/ConnectionService;->stopRetry()V

    .line 7
    iget-object p3, p0, Lio/rong/imlib/ConnectionService;->mConnectionState:Lio/rong/imlib/ConnectionState;

    invoke-virtual {p3, p1}, Lio/rong/imlib/ConnectionState;->onEvent(I)V

    .line 8
    invoke-static {}, Lio/rong/imlib/NativeClient;->getInstance()Lio/rong/imlib/NativeClient;

    move-result-object p3

    invoke-virtual {p3, p2}, Lio/rong/imlib/NativeClient;->setCurrentUserId(Ljava/lang/String;)V

    .line 9
    iget-object p3, p0, Lio/rong/imlib/ConnectionService;->mContext:Landroid/content/Context;

    invoke-static {p3, p2}, Lio/rong/imlib/navigation/NavigationCacheHelper;->saveUserId(Landroid/content/Context;Ljava/lang/String;)V

    .line 10
    invoke-direct {p0, p2}, Lio/rong/imlib/ConnectionService;->responseConnectSuccessBlock(Ljava/lang/String;)V

    .line 11
    invoke-static {}, Lio/rong/imlib/CMPStrategy;->getInstance()Lio/rong/imlib/CMPStrategy;

    move-result-object p2

    invoke-virtual {p2}, Lio/rong/imlib/CMPStrategy;->onConnected()V

    goto :goto_b5

    :cond_6d
    const/4 v6, 0x6

    .line 12
    new-array v6, v6, [Ljava/lang/Object;

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

    move-result-object v7

    aput-object v7, v6, v4

    aput-object p2, v6, v5

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

    move-result-object p2

    aput-object p2, v6, v1

    invoke-static {p4}, Ljava/lang/Short;->valueOf(S)Ljava/lang/Short;

    move-result-object p2

    aput-object p2, v6, v3

    iget-object p2, p0, Lio/rong/imlib/ConnectionService;->mContext:Landroid/content/Context;

    invoke-static {p2}, Lio/rong/imlib/common/DeviceUtils;->getNetworkType(Landroid/content/Context;)Ljava/lang/String;

    move-result-object p2

    aput-object p2, v6, v0

    iget-boolean p2, p0, Lio/rong/imlib/ConnectionService;->mIsForeground:Z

    if-eqz p2, :cond_93

    const-string p2, "false"

    goto :goto_95

    :cond_93
    const-string p2, "true"

    :goto_95
    aput-object p2, v6, p5

    const-string p2, "status_code|user_id|native_code|duration|network|bg"

    .line 14
    invoke-static {v5, v5, v2, p2, v6}, Lio/rong/common/fwlog/FwLog;->write(IILjava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V

    .line 15
    iget-object p2, p0, Lio/rong/imlib/ConnectionService;->mConnectionState:Lio/rong/imlib/ConnectionState;

    invoke-virtual {p2, p1}, Lio/rong/imlib/ConnectionState;->onEvent(I)V

    .line 16
    iget-object p2, p0, Lio/rong/imlib/ConnectionService;->mConnectionState:Lio/rong/imlib/ConnectionState;

    invoke-virtual {p2}, Lio/rong/imlib/ConnectionState;->getCurrentStatus()Lio/rong/imlib/RongIMClient$ConnectionStatusListener$ConnectionStatus;

    move-result-object p2

    sget-object p4, Lio/rong/imlib/RongIMClient$ConnectionStatusListener$ConnectionStatus;->SUSPEND:Lio/rong/imlib/RongIMClient$ConnectionStatusListener$ConnectionStatus;

    invoke-virtual {p2, p4}, Ljava/lang/Enum;->equals(Ljava/lang/Object;)Z

    move-result p2

    if-nez p2, :cond_b2

    .line 17
    invoke-direct {p0, p1}, Lio/rong/imlib/ConnectionService;->responseConnectErrorBlock(I)V

    .line 18
    :cond_b2
    invoke-virtual {p0, p1, p3}, Lio/rong/imlib/ConnectionService;->disposeReconnectByErrorCode(II)Z

    .line 19
    :goto_b5
    invoke-static {}, Lio/rong/imlib/navigation/NavigationClient;->getInstance()Lio/rong/imlib/navigation/NavigationClient;

    move-result-object p2

    invoke-virtual {p2}, Lio/rong/imlib/navigation/NavigationClient;->isFetching()Z

    move-result p2

    .line 20
    invoke-static {}, Lio/rong/imlib/navigation/NavigationClient;->getInstance()Lio/rong/imlib/navigation/NavigationClient;

    move-result-object p3

    iget-object p4, p0, Lio/rong/imlib/ConnectionService;->mContext:Landroid/content/Context;

    iget-object p5, p0, Lio/rong/imlib/ConnectionService;->mAppKey:Ljava/lang/String;

    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mToken:Ljava/lang/String;

    invoke-virtual {p3, p4, p5, v0}, Lio/rong/imlib/navigation/NavigationClient;->isNaviCacheValid(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)Z

    move-result p3

    if-nez p3, :cond_e8

    if-nez p2, :cond_e8

    invoke-direct {p0, p1}, Lio/rong/imlib/ConnectionService;->needClearNavi(I)Z

    move-result p1

    if-nez p1, :cond_e8

    iget-object p1, p0, Lio/rong/imlib/ConnectionService;->mToken:Ljava/lang/String;

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

    move-result p1

    if-nez p1, :cond_e8

    .line 22
    invoke-static {}, Lio/rong/imlib/navigation/NavigationClient;->getInstance()Lio/rong/imlib/navigation/NavigationClient;

    move-result-object p1

    iget-object p2, p0, Lio/rong/imlib/ConnectionService;->mAppKey:Ljava/lang/String;

    iget-object p3, p0, Lio/rong/imlib/ConnectionService;->mToken:Ljava/lang/String;

    invoke-virtual {p1, p2, p3, v4}, Lio/rong/imlib/navigation/NavigationClient;->requestNavi(Ljava/lang/String;Ljava/lang/String;Z)V

    :cond_e8
    return-void
.end method

.method private OnProtocolRmtpDisconnected(IILjava/lang/String;)V
    .registers 5

    .line 1
    new-instance p3, Ljava/lang/StringBuilder;

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

    const-string v0, "ExceptionListener onError. errorCode: "

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

    invoke-virtual {p3, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

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

    move-result-object p3

    const-string v0, "ConnectionService"

    invoke-static {v0, p3}, Lio/rong/common/rlog/RLog;->i(Ljava/lang/String;Ljava/lang/String;)I

    .line 2
    invoke-virtual {p0, p1, p2}, Lio/rong/imlib/ConnectionService;->disposeReconnectByErrorCode(II)Z

    return-void
.end method

.method private OnProtocolTcpComplete(Lio/rong/imlib/NativeObject$ConnectionEntry;)V
    .registers 8

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

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

    const-string v1, "connectionCollection onComplete:"

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

    invoke-virtual {p1}, Lio/rong/imlib/NativeObject$ConnectionEntry;->getHost()Ljava/lang/String;

    move-result-object v1

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

    const-string v1, " "

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

    invoke-virtual {p1}, Lio/rong/imlib/NativeObject$ConnectionEntry;->getPort()I

    move-result v2

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

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

    invoke-virtual {p1}, Lio/rong/imlib/NativeObject$ConnectionEntry;->getError()I

    move-result v2

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

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

    invoke-virtual {p1}, Lio/rong/imlib/NativeObject$ConnectionEntry;->getDuration()I

    move-result v1

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

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

    move-result-object v0

    const-string v1, "ConnectionService"

    invoke-static {v1, v0}, Lio/rong/common/rlog/RLog;->e(Ljava/lang/String;Ljava/lang/String;)I

    .line 2
    invoke-virtual {p1}, Lio/rong/imlib/NativeObject$ConnectionEntry;->getError()I

    move-result v0

    const/4 v1, 0x2

    const-string v2, ":"

    const/4 v3, 0x3

    if-nez v0, :cond_67

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

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

    invoke-virtual {p1}, Lio/rong/imlib/NativeObject$ConnectionEntry;->getHost()Ljava/lang/String;

    move-result-object v4

    invoke-virtual {v0, v4}, 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 {p1}, Lio/rong/imlib/NativeObject$ConnectionEntry;->getPort()I

    move-result v4

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

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

    move-result-object v0

    .line 4
    invoke-static {}, Lio/rong/imlib/CMPStrategy;->getInstance()Lio/rong/imlib/CMPStrategy;

    move-result-object v4

    invoke-virtual {v4, v0}, Lio/rong/imlib/CMPStrategy;->setMainCMP(Ljava/lang/String;)V

    :goto_65
    const/4 v0, 0x3

    goto :goto_70

    .line 5
    :cond_67
    invoke-virtual {p1}, Lio/rong/imlib/NativeObject$ConnectionEntry;->getError()I

    move-result v0

    const/4 v4, -0x1

    if-ne v0, v4, :cond_6f

    goto :goto_65

    :cond_6f
    const/4 v0, 0x2

    .line 6
    :goto_70
    new-array v3, v3, [Ljava/lang/Object;

    const/4 v4, 0x0

    .line 7
    invoke-virtual {p1}, Lio/rong/imlib/NativeObject$ConnectionEntry;->getError()I

    move-result v5

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

    move-result-object v5

    aput-object v5, v3, v4

    new-instance v4, Ljava/lang/StringBuilder;

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

    invoke-virtual {p1}, Lio/rong/imlib/NativeObject$ConnectionEntry;->getHost()Ljava/lang/String;

    move-result-object v5

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

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

    invoke-virtual {p1}, Lio/rong/imlib/NativeObject$ConnectionEntry;->getPort()I

    move-result v2

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

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

    move-result-object v2

    const/4 v4, 0x1

    aput-object v2, v3, v4

    invoke-virtual {p1}, Lio/rong/imlib/NativeObject$ConnectionEntry;->getDuration()I

    move-result p1

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

    move-result-object p1

    aput-object p1, v3, v1

    const-string p1, "P-connect_entry-S"

    const-string v1, "code|cmp|duration"

    .line 8
    invoke-static {v0, v4, p1, v1, v3}, Lio/rong/common/fwlog/FwLog;->write(IILjava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V

    return-void
.end method

.method static synthetic access$1000(Lio/rong/imlib/ConnectionService;)Ljava/util/concurrent/Executor;
    .registers 1

    .line 1
    iget-object p0, p0, Lio/rong/imlib/ConnectionService;->mCallBackExecutor:Ljava/util/concurrent/Executor;

    return-object p0
.end method

.method static synthetic access$1100(Lio/rong/imlib/ConnectionService;ILjava/lang/String;ISLjava/lang/String;)V
    .registers 6

    .line 1
    invoke-direct/range {p0 .. p5}, Lio/rong/imlib/ConnectionService;->OnProtocolRmtpComplete(ILjava/lang/String;ISLjava/lang/String;)V

    return-void
.end method

.method static synthetic access$1200(Lio/rong/imlib/ConnectionService;IILjava/lang/String;)V
    .registers 4

    .line 1
    invoke-direct {p0, p1, p2, p3}, Lio/rong/imlib/ConnectionService;->OnProtocolRmtpDisconnected(IILjava/lang/String;)V

    return-void
.end method

.method static synthetic access$1300(Lio/rong/imlib/ConnectionService;)V
    .registers 1

    .line 1
    invoke-direct {p0}, Lio/rong/imlib/ConnectionService;->OnProtocolPongReceived()V

    return-void
.end method

.method static synthetic access$1400(Lio/rong/imlib/ConnectionService;I)V
    .registers 2

    .line 1
    invoke-direct {p0, p1}, Lio/rong/imlib/ConnectionService;->OnProtocolDBOpened(I)V

    return-void
.end method

.method static synthetic access$1500(Lio/rong/imlib/ConnectionService;)Ljava/lang/String;
    .registers 1

    .line 1
    iget-object p0, p0, Lio/rong/imlib/ConnectionService;->mToken:Ljava/lang/String;

    return-object p0
.end method

.method static synthetic access$1600(Lio/rong/imlib/ConnectionService;)Lio/rong/imlib/NativeClient$IConnectResultCallback;
    .registers 1

    .line 1
    iget-object p0, p0, Lio/rong/imlib/ConnectionService;->mConnectCallback:Lio/rong/imlib/NativeClient$IConnectResultCallback;

    return-object p0
.end method

.method static synthetic access$1702(Lio/rong/imlib/ConnectionService;Lio/rong/imlib/ConnectionService$ReconnectRunnable;)Lio/rong/imlib/ConnectionService$ReconnectRunnable;
    .registers 2

    .line 1
    iput-object p1, p0, Lio/rong/imlib/ConnectionService;->mReconnectRunnable:Lio/rong/imlib/ConnectionService$ReconnectRunnable;

    return-object p1
.end method

.method static synthetic access$200(Lio/rong/imlib/ConnectionService;Ljava/lang/String;ZZLio/rong/imlib/NativeClient$IConnectResultCallback;)V
    .registers 5

    .line 1
    invoke-direct {p0, p1, p2, p3, p4}, Lio/rong/imlib/ConnectionService;->connectServer(Ljava/lang/String;ZZLio/rong/imlib/NativeClient$IConnectResultCallback;)V

    return-void
.end method

.method static synthetic access$300(Lio/rong/imlib/ConnectionService;)Landroid/content/Context;
    .registers 1

    .line 1
    iget-object p0, p0, Lio/rong/imlib/ConnectionService;->mContext:Landroid/content/Context;

    return-object p0
.end method

.method static synthetic access$400(Lio/rong/imlib/ConnectionService;)Lio/rong/imlib/NativeObject;
    .registers 1

    .line 1
    iget-object p0, p0, Lio/rong/imlib/ConnectionService;->mNativeObj:Lio/rong/imlib/NativeObject;

    return-object p0
.end method

.method static synthetic access$500(Lio/rong/imlib/ConnectionService;Ljava/lang/String;Ljava/lang/String;ZZLio/rong/imlib/NativeClient$IConnectResultCallback;)V
    .registers 6

    .line 1
    invoke-direct/range {p0 .. p5}, Lio/rong/imlib/ConnectionService;->internalConnect(Ljava/lang/String;Ljava/lang/String;ZZLio/rong/imlib/NativeClient$IConnectResultCallback;)V

    return-void
.end method

.method static synthetic access$600(Lio/rong/imlib/ConnectionService;)Ljava/util/concurrent/atomic/AtomicInteger;
    .registers 1

    .line 1
    iget-object p0, p0, Lio/rong/imlib/ConnectionService;->mRcRetryCount:Ljava/util/concurrent/atomic/AtomicInteger;

    return-object p0
.end method

.method static synthetic access$700(Lio/rong/imlib/ConnectionService;)Lio/rong/imlib/ConnectionState;
    .registers 1

    .line 1
    iget-object p0, p0, Lio/rong/imlib/ConnectionService;->mConnectionState:Lio/rong/imlib/ConnectionState;

    return-object p0
.end method

.method static synthetic access$800(Lio/rong/imlib/ConnectionService;I)V
    .registers 2

    .line 1
    invoke-direct {p0, p1}, Lio/rong/imlib/ConnectionService;->responseConnectErrorBlock(I)V

    return-void
.end method

.method static synthetic access$900(Lio/rong/imlib/ConnectionService;Lio/rong/imlib/NativeObject$ConnectionEntry;)V
    .registers 2

    .line 1
    invoke-direct {p0, p1}, Lio/rong/imlib/ConnectionService;->OnProtocolTcpComplete(Lio/rong/imlib/NativeObject$ConnectionEntry;)V

    return-void
.end method

.method private canReconnect()Z
    .registers 5

    .line 1
    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mConnectionState:Lio/rong/imlib/ConnectionState;

    invoke-virtual {v0}, Lio/rong/imlib/ConnectionState;->isTerminate()Z

    move-result v0

    const-string v1, "ConnectionService"

    const/4 v2, 0x0

    if-eqz v0, :cond_17

    const-string v0, "globalConnectionState can not reconnect"

    .line 2
    invoke-static {v1, v0}, Lio/rong/common/rlog/RLog;->e(Ljava/lang/String;Ljava/lang/String;)I

    const/4 v0, 0x0

    .line 3
    iput-object v0, p0, Lio/rong/imlib/ConnectionService;->mToken:Ljava/lang/String;

    .line 4
    invoke-direct {p0}, Lio/rong/imlib/ConnectionService;->stopRetry()V

    return v2

    .line 5
    :cond_17
    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mConnectionState:Lio/rong/imlib/ConnectionState;

    invoke-virtual {v0}, Lio/rong/imlib/ConnectionState;->getCurrentStatus()Lio/rong/imlib/RongIMClient$ConnectionStatusListener$ConnectionStatus;

    move-result-object v0

    sget-object v3, Lio/rong/imlib/RongIMClient$ConnectionStatusListener$ConnectionStatus;->CONNECTED:Lio/rong/imlib/RongIMClient$ConnectionStatusListener$ConnectionStatus;

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

    move-result v0

    if-eqz v0, :cond_2b

    const-string v0, "already connected. ignore this connect event."

    .line 6
    invoke-static {v1, v0}, Lio/rong/common/rlog/RLog;->i(Ljava/lang/String;Ljava/lang/String;)I

    return v2

    .line 7
    :cond_2b
    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mToken:Ljava/lang/String;

    if-nez v0, :cond_35

    const-string v0, "mToken is cleared for terminal reconnect reason"

    .line 8
    invoke-static {v1, v0}, Lio/rong/common/rlog/RLog;->e(Ljava/lang/String;Ljava/lang/String;)I

    return v2

    .line 9
    :cond_35
    invoke-direct {p0}, Lio/rong/imlib/ConnectionService;->isNetworkAvailable()Z

    move-result v0

    if-nez v0, :cond_44

    .line 10
    invoke-virtual {p0}, Lio/rong/imlib/ConnectionService;->resetReconnectCount()V

    .line 11
    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mConnectionState:Lio/rong/imlib/ConnectionState;

    invoke-virtual {v0}, Lio/rong/imlib/ConnectionState;->networkUnavailable()V

    return v2

    :cond_44
    const/4 v0, 0x1

    return v0
.end method

.method private connectServer(Ljava/lang/String;ZZLio/rong/imlib/NativeClient$IConnectResultCallback;)V
    .registers 13
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Ljava/lang/String;",
            "ZZ",
            "Lio/rong/imlib/NativeClient$IConnectResultCallback<",
            "Ljava/lang/String;",
            ">;)V"
        }
    .end annotation

    const-string v0, "ConnectionService"

    if-eqz p2, :cond_25

    .line 1
    invoke-direct {p0}, Lio/rong/imlib/ConnectionService;->canReconnect()Z

    move-result v1

    if-nez v1, :cond_27

    .line 2
    new-instance p1, Ljava/lang/StringBuilder;

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

    const-string p2, "[connect] can\'t connect status "

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

    iget-object p2, p0, Lio/rong/imlib/ConnectionService;->mConnectionState:Lio/rong/imlib/ConnectionState;

    invoke-virtual {p2}, Lio/rong/imlib/ConnectionState;->getCurrentStatus()Lio/rong/imlib/RongIMClient$ConnectionStatusListener$ConnectionStatus;

    move-result-object p2

    invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;

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

    move-result-object p1

    invoke-static {v0, p1}, Lio/rong/common/rlog/RLog;->i(Ljava/lang/String;Ljava/lang/String;)I

    return-void

    .line 3
    :cond_25
    iput-object p1, p0, Lio/rong/imlib/ConnectionService;->mToken:Ljava/lang/String;

    .line 4
    :cond_27
    invoke-static {p1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z

    move-result v1

    if-eqz v1, :cond_3e

    const-string p1, "connectServer token is null"

    .line 5
    invoke-static {v0, p1}, Lio/rong/common/rlog/RLog;->e(Ljava/lang/String;Ljava/lang/String;)I

    if-eqz p4, :cond_3d

    .line 6
    sget-object p1, Lio/rong/imlib/RongIMClient$ErrorCode;->PARAMETER_ERROR:Lio/rong/imlib/RongIMClient$ErrorCode;

    invoke-virtual {p1}, Lio/rong/imlib/RongIMClient$ErrorCode;->getValue()I

    move-result p1

    invoke-interface {p4, p1}, Lio/rong/imlib/NativeClient$IResultCallback;->onError(I)V

    :cond_3d
    return-void

    .line 7
    :cond_3e
    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mConnectionState:Lio/rong/imlib/ConnectionState;

    invoke-virtual {v0}, Lio/rong/imlib/ConnectionState;->connecting()V

    .line 8
    invoke-direct {p0}, Lio/rong/imlib/ConnectionService;->stopRetry()V

    .line 9
    invoke-static {}, Lio/rong/imlib/navigation/NavigationClient;->getInstance()Lio/rong/imlib/navigation/NavigationClient;

    move-result-object v0

    new-instance v7, Lio/rong/imlib/ConnectionService$4;

    move-object v1, v7

    move-object v2, p0

    move-object v3, p1

    move v4, p2

    move v5, p3

    move-object v6, p4

    invoke-direct/range {v1 .. v6}, Lio/rong/imlib/ConnectionService$4;-><init>(Lio/rong/imlib/ConnectionService;Ljava/lang/String;ZZLio/rong/imlib/NativeClient$IConnectResultCallback;)V

    invoke-virtual {v0, v7}, Lio/rong/imlib/navigation/NavigationClient;->addObserver(Lio/rong/imlib/navigation/NavigationObserver;)V

    .line 10
    invoke-static {}, Lio/rong/imlib/navigation/NavigationClient;->getInstance()Lio/rong/imlib/navigation/NavigationClient;

    move-result-object p2

    iget-object p3, p0, Lio/rong/imlib/ConnectionService;->mContext:Landroid/content/Context;

    iget-object p4, p0, Lio/rong/imlib/ConnectionService;->mAppKey:Ljava/lang/String;

    invoke-virtual {p2, p3, p4, p1}, Lio/rong/imlib/navigation/NavigationClient;->getCMPServerString(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)V

    return-void
.end method

.method private getConnectionEntries(Ljava/util/List;)[Lio/rong/imlib/NativeObject$ConnectionEntry;
    .registers 9
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Ljava/util/List<",
            "Ljava/net/URL;",
            ">;)[",
            "Lio/rong/imlib/NativeObject$ConnectionEntry;"
        }
    .end annotation

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

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

    if-eqz p1, :cond_50

    .line 2
    invoke-interface {p1}, Ljava/util/List;->size()I

    move-result v1

    if-gtz v1, :cond_e

    goto :goto_50

    .line 3
    :cond_e
    invoke-interface {p1}, Ljava/util/List;->iterator()Ljava/util/Iterator;

    move-result-object v1

    :goto_12
    invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z

    move-result v2

    if-eqz v2, :cond_43

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

    move-result-object v2

    check-cast v2, Ljava/net/URL;

    .line 4
    new-instance v3, Lio/rong/imlib/NativeObject$ConnectionEntry;

    invoke-direct {v3}, Lio/rong/imlib/NativeObject$ConnectionEntry;-><init>()V

    .line 5
    invoke-virtual {v2}, Ljava/net/URL;->getHost()Ljava/lang/String;

    move-result-object v4

    const-string v5, ""

    const-string v6, "["

    invoke-virtual {v4, v6, v5}, Ljava/lang/String;->replace(Ljava/lang/CharSequence;Ljava/lang/CharSequence;)Ljava/lang/String;

    move-result-object v4

    const-string v6, "]"

    invoke-virtual {v4, v6, v5}, Ljava/lang/String;->replace(Ljava/lang/CharSequence;Ljava/lang/CharSequence;)Ljava/lang/String;

    move-result-object v4

    .line 6
    invoke-virtual {v3, v4}, Lio/rong/imlib/NativeObject$ConnectionEntry;->setHost(Ljava/lang/String;)V

    .line 7
    invoke-virtual {v2}, Ljava/net/URL;->getPort()I

    move-result v2

    invoke-virtual {v3, v2}, Lio/rong/imlib/NativeObject$ConnectionEntry;->setPort(I)V

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

    goto :goto_12

    .line 9
    :cond_43
    invoke-interface {p1}, Ljava/util/List;->size()I

    move-result p1

    new-array p1, p1, [Lio/rong/imlib/NativeObject$ConnectionEntry;

    invoke-interface {v0, p1}, Ljava/util/List;->toArray([Ljava/lang/Object;)[Ljava/lang/Object;

    move-result-object p1

    check-cast p1, [Lio/rong/imlib/NativeObject$ConnectionEntry;

    return-object p1

    :cond_50
    :goto_50
    const/4 p1, 0x0

    .line 10
    new-array p1, p1, [Lio/rong/imlib/NativeObject$ConnectionEntry;

    invoke-interface {v0, p1}, Ljava/util/List;->toArray([Ljava/lang/Object;)[Ljava/lang/Object;

    move-result-object p1

    check-cast p1, [Lio/rong/imlib/NativeObject$ConnectionEntry;

    return-object p1
.end method

.method static getInstance()Lio/rong/imlib/ConnectionService;
    .registers 1

    .line 1
    sget-object v0, Lio/rong/imlib/ConnectionService$SingleHolder;->instance:Lio/rong/imlib/ConnectionService;

    return-object v0
.end method

.method private getLegalCmpList(Ljava/util/List;)Ljava/util/List;
    .registers 7
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Ljava/util/List<",
            "Ljava/lang/String;",
            ">;)",
            "Ljava/util/List<",
            "Ljava/net/URL;",
            ">;"
        }
    .end annotation

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

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

    .line 2
    new-instance v1, Ljava/util/ArrayList;

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

    .line 3
    invoke-interface {v1}, Ljava/util/List;->iterator()Ljava/util/Iterator;

    move-result-object p1

    .line 4
    :goto_e
    invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z

    move-result v1

    if-eqz v1, :cond_32

    .line 5
    invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v1

    check-cast v1, Ljava/lang/String;

    const/4 v2, 0x1

    .line 6
    invoke-static {v1, v2}, Lio/rong/common/SystemUtils;->getLegalServer(Ljava/lang/String;Z)Ljava/net/URL;

    move-result-object v3

    if-eqz v3, :cond_25

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

    goto :goto_e

    .line 8
    :cond_25
    new-array v3, v2, [Ljava/lang/Object;

    const/4 v4, 0x0

    aput-object v1, v3, v4

    const-string v1, "L-check_cmp-S"

    const-string v4, "cmp"

    invoke-static {v2, v2, v1, v4, v3}, Lio/rong/common/fwlog/FwLog;->write(IILjava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V

    goto :goto_e

    :cond_32
    return-object v0
.end method

.method private handleSuspend(I)V
    .registers 3

    .line 1
    sget-object v0, Lio/rong/imlib/RongIMClient$ErrorCode;->RC_CONNECTION_RESET_BY_PEER:Lio/rong/imlib/RongIMClient$ErrorCode;

    invoke-virtual {v0}, Lio/rong/imlib/RongIMClient$ErrorCode;->getValue()I

    move-result v0

    if-eq p1, v0, :cond_37

    sget-object v0, Lio/rong/imlib/RongIMClient$ErrorCode;->RC_CONN_ACK_TIMEOUT:Lio/rong/imlib/RongIMClient$ErrorCode;

    .line 2
    invoke-virtual {v0}, Lio/rong/imlib/RongIMClient$ErrorCode;->getValue()I

    move-result v0

    if-ne p1, v0, :cond_11

    goto :goto_37

    .line 3
    :cond_11
    sget-object v0, Lio/rong/imlib/RongIMClient$ErrorCode;->RC_PONG_RECV_FAIL:Lio/rong/imlib/RongIMClient$ErrorCode;

    invoke-virtual {v0}, Lio/rong/imlib/RongIMClient$ErrorCode;->getValue()I

    move-result v0

    if-ne p1, v0, :cond_27

    invoke-direct {p0}, Lio/rong/imlib/ConnectionService;->isNetworkAvailable()Z

    move-result v0

    if-eqz v0, :cond_27

    .line 4
    invoke-static {}, Lio/rong/imlib/CMPStrategy;->getInstance()Lio/rong/imlib/CMPStrategy;

    move-result-object p1

    invoke-virtual {p1}, Lio/rong/imlib/CMPStrategy;->updateCmpList()V

    goto :goto_3e

    .line 5
    :cond_27
    invoke-direct {p0, p1}, Lio/rong/imlib/ConnectionService;->needClearNavi(I)Z

    move-result p1

    if-eqz p1, :cond_3e

    .line 6
    invoke-static {}, Lio/rong/imlib/CMPStrategy;->getInstance()Lio/rong/imlib/CMPStrategy;

    move-result-object p1

    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mContext:Landroid/content/Context;

    invoke-virtual {p1, v0}, Lio/rong/imlib/CMPStrategy;->clearCache(Landroid/content/Context;)V

    goto :goto_3e

    .line 7
    :cond_37
    :goto_37
    invoke-static {}, Lio/rong/imlib/CMPStrategy;->getInstance()Lio/rong/imlib/CMPStrategy;

    move-result-object p1

    invoke-virtual {p1}, Lio/rong/imlib/CMPStrategy;->updateCmpList()V

    .line 8
    :cond_3e
    :goto_3e
    invoke-direct {p0}, Lio/rong/imlib/ConnectionService;->retry()V

    return-void
.end method

.method private incrementCount()V
    .registers 2

    .line 1
    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mRcRetryCount:Ljava/util/concurrent/atomic/AtomicInteger;

    invoke-virtual {v0}, Ljava/util/concurrent/atomic/AtomicInteger;->incrementAndGet()I

    return-void
.end method

.method private internalConnect(Ljava/lang/String;Ljava/lang/String;ZZLio/rong/imlib/NativeClient$IConnectResultCallback;)V
    .registers 12
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Ljava/lang/String;",
            "Ljava/lang/String;",
            "ZZ",
            "Lio/rong/imlib/NativeClient$IConnectResultCallback<",
            "Ljava/lang/String;",
            ">;)V"
        }
    .end annotation

    if-eqz p3, :cond_5

    const-string v0, "L-reconnect-T"

    goto :goto_7

    :cond_5
    const-string v0, "L-connect-T"

    :goto_7
    const/4 v1, 0x1

    .line 1
    new-array v2, v1, [Ljava/lang/Object;

    const/4 v4, 0x0

    iget-object v5, p0, Lio/rong/imlib/ConnectionService;->mRcRetryCount:Ljava/util/concurrent/atomic/AtomicInteger;

    invoke-virtual {v5}, Ljava/util/concurrent/atomic/AtomicInteger;->get()I

    move-result v5

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

    move-result-object v5

    aput-object v5, v2, v4

    const/4 v4, 0x3

    const-string v5, "sequences"

    invoke-static {v4, v1, v0, v5, v2}, Lio/rong/common/fwlog/FwLog;->write(IILjava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V

    .line 2
    iput-object p1, p0, Lio/rong/imlib/ConnectionService;->mToken:Ljava/lang/String;

    .line 3
    new-instance v5, Lio/rong/imlib/ConnectionService$5;

    invoke-direct {v5, p0, p3, p5}, Lio/rong/imlib/ConnectionService$5;-><init>(Lio/rong/imlib/ConnectionService;ZLio/rong/imlib/NativeClient$IConnectResultCallback;)V

    move-object v0, p0

    move-object v1, p1

    move-object v2, p2

    move v3, p3

    move v4, p4

    invoke-direct/range {v0 .. v5}, Lio/rong/imlib/ConnectionService;->tryConnect(Ljava/lang/String;Ljava/lang/String;ZZLio/rong/imlib/NativeClient$IConnectResultCallback;)V

    return-void
.end method

.method private isNetworkAvailable()Z
    .registers 3

    .line 1
    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mContext:Landroid/content/Context;

    const-string v1, "connectivity"

    invoke-virtual {v0, v1}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Landroid/net/ConnectivityManager;

    .line 2
    invoke-virtual {v0}, Landroid/net/ConnectivityManager;->getActiveNetworkInfo()Landroid/net/NetworkInfo;

    move-result-object v0

    if-eqz v0, :cond_19

    .line 3
    invoke-virtual {v0}, Landroid/net/NetworkInfo;->isAvailable()Z

    move-result v0

    if-nez v0, :cond_17

    goto :goto_19

    :cond_17
    const/4 v0, 0x1

    return v0

    :cond_19
    :goto_19
    const/4 v0, 0x0

    return v0
.end method

.method private needClearNavi(I)Z
    .registers 3

    .line 1
    sget-object v0, Lio/rong/imlib/RongIMClient$ErrorCode;->RC_CONN_REDIRECTED:Lio/rong/imlib/RongIMClient$ErrorCode;

    invoke-virtual {v0}, Lio/rong/imlib/RongIMClient$ErrorCode;->getValue()I

    move-result v0

    if-eq p1, v0, :cond_1b

    sget-object v0, Lio/rong/imlib/RongIMClient$ErrorCode;->PARAMETER_ERROR:Lio/rong/imlib/RongIMClient$ErrorCode;

    .line 2
    invoke-virtual {v0}, Lio/rong/imlib/RongIMClient$ErrorCode;->getValue()I

    move-result v0

    if-eq p1, v0, :cond_1b

    sget-object v0, Lio/rong/imlib/RongIMClient$ErrorCode;->RC_CONN_REFUSED:Lio/rong/imlib/RongIMClient$ErrorCode;

    .line 3
    invoke-virtual {v0}, Lio/rong/imlib/RongIMClient$ErrorCode;->getValue()I

    move-result v0

    if-ne p1, v0, :cond_19

    goto :goto_1b

    :cond_19
    const/4 p1, 0x0

    return p1

    :cond_1b
    :goto_1b
    const/4 p1, 0x1

    return p1
.end method

.method private responseConnectErrorBlock(I)V
    .registers 3

    .line 1
    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mConnectCallback:Lio/rong/imlib/NativeClient$IConnectResultCallback;

    if-eqz v0, :cond_7

    .line 2
    invoke-interface {v0, p1}, Lio/rong/imlib/NativeClient$IResultCallback;->onError(I)V

    :cond_7
    return-void
.end method

.method private responseConnectSuccessBlock(Ljava/lang/String;)V
    .registers 3

    .line 1
    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mConnectCallback:Lio/rong/imlib/NativeClient$IConnectResultCallback;

    if-eqz v0, :cond_7

    .line 2
    invoke-interface {v0, p1}, Lio/rong/imlib/NativeClient$IResultCallback;->onSuccess(Ljava/lang/Object;)V

    :cond_7
    return-void
.end method

.method private responseDBOpenBlock(I)V
    .registers 4

    const-string v0, "ConnectionService"

    const-string v1, "onDatabaseOpened."

    .line 1
    invoke-static {v0, v1}, Lio/rong/common/rlog/RLog;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 2
    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mConnectCallback:Lio/rong/imlib/NativeClient$IConnectResultCallback;

    if-eqz v0, :cond_e

    .line 3
    invoke-interface {v0, p1}, Lio/rong/imlib/NativeClient$IConnectResultCallback;->OnDatabaseOpened(I)V

    :cond_e
    return-void
.end method

.method private retry()V
    .registers 7

    .line 1
    invoke-direct {p0}, Lio/rong/imlib/ConnectionService;->canReconnect()Z

    move-result v0

    if-eqz v0, :cond_70

    .line 2
    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mReconnectInterval:[Ljava/lang/String;

    array-length v0, v0

    const/4 v1, 0x1

    sub-int/2addr v0, v1

    .line 3
    iget-object v2, p0, Lio/rong/imlib/ConnectionService;->mRcRetryCount:Ljava/util/concurrent/atomic/AtomicInteger;

    invoke-virtual {v2}, Ljava/util/concurrent/atomic/AtomicInteger;->get()I

    move-result v2

    const/high16 v3, 0x447a0000    # 1000.0f

    if-ltz v2, :cond_2c

    iget-object v2, p0, Lio/rong/imlib/ConnectionService;->mRcRetryCount:Ljava/util/concurrent/atomic/AtomicInteger;

    invoke-virtual {v2}, Ljava/util/concurrent/atomic/AtomicInteger;->get()I

    move-result v2

    if-gt v2, v0, :cond_2c

    .line 4
    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mReconnectInterval:[Ljava/lang/String;

    iget-object v2, p0, Lio/rong/imlib/ConnectionService;->mRcRetryCount:Ljava/util/concurrent/atomic/AtomicInteger;

    invoke-virtual {v2}, Ljava/util/concurrent/atomic/AtomicInteger;->get()I

    move-result v2

    aget-object v0, v0, v2

    invoke-static {v0}, Ljava/lang/Float;->parseFloat(Ljava/lang/String;)F

    move-result v0

    goto :goto_34

    .line 5
    :cond_2c
    iget-object v2, p0, Lio/rong/imlib/ConnectionService;->mReconnectInterval:[Ljava/lang/String;

    aget-object v0, v2, v0

    invoke-static {v0}, Ljava/lang/Float;->parseFloat(Ljava/lang/String;)F

    move-result v0

    :goto_34
    mul-float v0, v0, v3

    float-to-int v0, v0

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

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

    const-string v3, "onStatusChange, Will reconnect after "

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

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

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

    move-result-object v2

    const-string v3, "ConnectionService"

    invoke-static {v3, v2}, Lio/rong/common/rlog/RLog;->d(Ljava/lang/String;Ljava/lang/String;)I

    const/4 v2, 0x4

    .line 7
    new-array v3, v1, [Ljava/lang/Object;

    const/4 v4, 0x0

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

    move-result-object v5

    aput-object v5, v3, v4

    const-string v4, "L-reconnect-S"

    const-string v5, "retry_after"

    invoke-static {v2, v1, v4, v5, v3}, Lio/rong/common/fwlog/FwLog;->write(IILjava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V

    .line 8
    new-instance v1, Lio/rong/imlib/ConnectionService$ReconnectRunnable;

    invoke-direct {v1, p0}, Lio/rong/imlib/ConnectionService$ReconnectRunnable;-><init>(Lio/rong/imlib/ConnectionService;)V

    iput-object v1, p0, Lio/rong/imlib/ConnectionService;->mReconnectRunnable:Lio/rong/imlib/ConnectionService$ReconnectRunnable;

    .line 9
    iget-object v1, p0, Lio/rong/imlib/ConnectionService;->mHandler:Landroid/os/Handler;

    iget-object v2, p0, Lio/rong/imlib/ConnectionService;->mReconnectRunnable:Lio/rong/imlib/ConnectionService$ReconnectRunnable;

    int-to-long v3, v0

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

    .line 10
    invoke-direct {p0}, Lio/rong/imlib/ConnectionService;->incrementCount()V

    :cond_70
    return-void
.end method

.method private setHeartBeatListener()V
    .registers 3

    .line 1
    invoke-static {}, Lio/rong/imlib/HeartBeatManager;->getInstance()Lio/rong/imlib/HeartBeatManager;

    move-result-object v0

    new-instance v1, Lio/rong/imlib/ConnectionService$2;

    invoke-direct {v1, p0}, Lio/rong/imlib/ConnectionService$2;-><init>(Lio/rong/imlib/ConnectionService;)V

    invoke-virtual {v0, v1}, Lio/rong/imlib/HeartBeatManager;->setHeartBeatListener(Lio/rong/imlib/HeartBeatManager$HeartBeatListener;)V

    return-void
.end method

.method private stopRetry()V
    .registers 3

    .line 1
    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mReconnectRunnable:Lio/rong/imlib/ConnectionService$ReconnectRunnable;

    if-eqz v0, :cond_c

    .line 2
    iget-object v1, p0, Lio/rong/imlib/ConnectionService;->mHandler:Landroid/os/Handler;

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

    const/4 v0, 0x0

    .line 3
    iput-object v0, p0, Lio/rong/imlib/ConnectionService;->mReconnectRunnable:Lio/rong/imlib/ConnectionService$ReconnectRunnable;

    :cond_c
    return-void
.end method

.method private tryConnect(Ljava/lang/String;Ljava/lang/String;ZZLio/rong/imlib/NativeClient$IConnectResultCallback;)V
    .registers 21
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Ljava/lang/String;",
            "Ljava/lang/String;",
            "ZZ",
            "Lio/rong/imlib/NativeClient$IConnectResultCallback<",
            "Ljava/lang/String;",
            ">;)V"
        }
    .end annotation

    move-object v1, p0

    const-string v2, "ConnectionService"

    move/from16 v0, p4

    .line 1
    iput-boolean v0, v1, Lio/rong/imlib/ConnectionService;->mIsForeground:Z

    move-object/from16 v0, p5

    .line 2
    iput-object v0, v1, Lio/rong/imlib/ConnectionService;->mConnectCallback:Lio/rong/imlib/NativeClient$IConnectResultCallback;

    const-string v3, ""

    if-nez p2, :cond_11

    move-object v4, v3

    goto :goto_13

    :cond_11
    move-object/from16 v4, p2

    .line 3
    :goto_13
    invoke-static {}, Lio/rong/imlib/CMPStrategy;->getInstance()Lio/rong/imlib/CMPStrategy;

    move-result-object v0

    invoke-virtual {v0}, Lio/rong/imlib/CMPStrategy;->getCmpList()Ljava/util/List;

    move-result-object v5

    .line 4
    invoke-direct {p0, v5}, Lio/rong/imlib/ConnectionService;->getLegalCmpList(Ljava/util/List;)Ljava/util/List;

    move-result-object v0

    if-eqz v0, :cond_155

    .line 5
    invoke-interface {v0}, Ljava/util/List;->size()I

    move-result v6

    if-gtz v6, :cond_29

    goto/16 :goto_155

    .line 6
    :cond_29
    invoke-direct {p0, v0}, Lio/rong/imlib/ConnectionService;->getConnectionEntries(Ljava/util/List;)[Lio/rong/imlib/NativeObject$ConnectionEntry;

    move-result-object v6

    .line 7
    invoke-static {}, Lio/rong/imlib/NativeClient;->getInstance()Lio/rong/imlib/NativeClient;

    move-result-object v0

    invoke-virtual {v0, v4}, Lio/rong/imlib/NativeClient;->setCurrentUserId(Ljava/lang/String;)V

    .line 8
    invoke-static {}, Lio/rong/imlib/navigation/NavigationClient;->getInstance()Lio/rong/imlib/navigation/NavigationClient;

    move-result-object v0

    iget-object v7, v1, Lio/rong/imlib/ConnectionService;->mContext:Landroid/content/Context;

    invoke-virtual {v0, v7}, Lio/rong/imlib/navigation/NavigationClient;->isMPOpened(Landroid/content/Context;)Z

    move-result v7

    .line 9
    invoke-static {}, Lio/rong/imlib/navigation/NavigationClient;->getInstance()Lio/rong/imlib/navigation/NavigationClient;

    move-result-object v0

    iget-object v8, v1, Lio/rong/imlib/ConnectionService;->mContext:Landroid/content/Context;

    invoke-virtual {v0, v8}, Lio/rong/imlib/navigation/NavigationClient;->isUSOpened(Landroid/content/Context;)Z

    move-result v8

    .line 10
    invoke-static {}, Lio/rong/imlib/navigation/NavigationClient;->getInstance()Lio/rong/imlib/navigation/NavigationClient;

    move-result-object v0

    iget-object v9, v1, Lio/rong/imlib/ConnectionService;->mContext:Landroid/content/Context;

    invoke-virtual {v0, v9}, Lio/rong/imlib/navigation/NavigationClient;->isGROpened(Landroid/content/Context;)Z

    move-result v9

    .line 11
    iget-object v0, v1, Lio/rong/imlib/ConnectionService;->mContext:Landroid/content/Context;

    invoke-static {v0}, Lio/rong/imlib/navigation/NavigationCacheHelper;->isKvStorageEnabled(Landroid/content/Context;)Z

    move-result v10

    .line 12
    :try_start_58
    iget-object v0, v1, Lio/rong/imlib/ConnectionService;->mContext:Landroid/content/Context;

    const-string v11, "phone"

    invoke-virtual {v0, v11}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Landroid/telephony/TelephonyManager;

    if-eqz v0, :cond_6f

    .line 13
    invoke-virtual {v0}, Landroid/telephony/TelephonyManager;->getNetworkOperator()Ljava/lang/String;

    move-result-object v0
    :try_end_68
    .catch Ljava/lang/SecurityException; {:try_start_58 .. :try_end_68} :catch_69

    goto :goto_70

    :catch_69
    move-exception v0

    const-string v11, "tryConnect SecurityException"

    .line 14
    invoke-static {v2, v11, v0}, Lio/rong/common/rlog/RLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I

    :cond_6f
    move-object v0, v3

    .line 15
    :goto_70
    iget-object v11, v1, Lio/rong/imlib/ConnectionService;->mContext:Landroid/content/Context;

    invoke-static {v11}, Lio/rong/imlib/common/DeviceUtils;->getNetworkType(Landroid/content/Context;)Ljava/lang/String;

    move-result-object v11

    .line 16
    new-instance v12, Ljava/lang/StringBuilder;

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

    const-string v13, "[connect] device info: "

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

    sget-object v13, Landroid/os/Build;->MANUFACTURER:Ljava/lang/String;

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

    const-string v13, ", "

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

    sget-object v14, Landroid/os/Build;->MODEL:Ljava/lang/String;

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

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

    sget v14, Landroid/os/Build$VERSION;->SDK_INT:I

    invoke-virtual {v12, v14}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

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

    const-string v14, "4.1.0"

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

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

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

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

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

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

    move-result-object v0

    invoke-static {v2, v0}, Lio/rong/common/rlog/RLog;->d(Ljava/lang/String;Ljava/lang/String;)I

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

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

    const-string v11, "[connect] tryConnect::cmp:"

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

    invoke-static {v5}, Lio/rong/common/SystemUtils;->listToString(Ljava/util/List;)Ljava/lang/String;

    move-result-object v11

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

    const-string v11, ", userId : "

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

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

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

    move-result-object v0

    invoke-static {v2, v0}, Lio/rong/common/rlog/RLog;->d(Ljava/lang/String;Ljava/lang/String;)I

    const/4 v0, 0x3

    .line 18
    new-array v2, v0, [Ljava/lang/Object;

    const/4 v11, 0x0

    const-string v12, "parallel"

    aput-object v12, v2, v11

    .line 19
    invoke-static {v5}, Lio/rong/common/SystemUtils;->listToString(Ljava/util/List;)Ljava/lang/String;

    move-result-object v12

    const/4 v13, 0x1

    aput-object v12, v2, v13

    const/4 v12, 0x2

    invoke-static {v5}, Lio/rong/common/SystemUtils;->listToString(Ljava/util/List;)Ljava/lang/String;

    move-result-object v5

    aput-object v5, v2, v12

    const-string v5, "P-connect-T"

    const-string v12, "strategy|cached|use"

    .line 20
    invoke-static {v0, v13, v5, v12, v2}, Lio/rong/common/fwlog/FwLog;->write(IILjava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V

    .line 21
    iget-boolean v0, v1, Lio/rong/imlib/ConnectionService;->mEnableReconnectKick:Z

    if-eqz v0, :cond_f6

    if-eqz p3, :cond_f6

    goto :goto_f7

    :cond_f6
    const/4 v13, 0x0

    :goto_f7
    if-eqz v9, :cond_104

    .line 22
    invoke-static {}, Lio/rong/imlib/navigation/NavigationClient;->getInstance()Lio/rong/imlib/navigation/NavigationClient;

    move-result-object v0

    iget-object v2, v1, Lio/rong/imlib/ConnectionService;->mContext:Landroid/content/Context;

    invoke-virtual {v0, v2}, Lio/rong/imlib/navigation/NavigationClient;->getGroupMessageLimit(Landroid/content/Context;)I

    move-result v0

    goto :goto_105

    :cond_104
    const/4 v0, 0x0

    .line 23
    :goto_105
    iget-object v2, v1, Lio/rong/imlib/ConnectionService;->mContext:Landroid/content/Context;

    invoke-static {v2}, Lio/rong/imlib/navigation/NavigationCacheHelper;->getClientIp(Landroid/content/Context;)Ljava/lang/String;

    move-result-object v2

    .line 24
    invoke-static {v2}, Lio/rong/common/SystemUtils;->isLegalServer(Ljava/lang/String;)Z

    move-result v5

    if-nez v5, :cond_112

    move-object v2, v3

    .line 25
    :cond_112
    new-instance v3, Lio/rong/imlib/NativeObject$UserProfile;

    invoke-direct {v3}, Lio/rong/imlib/NativeObject$UserProfile;-><init>()V

    .line 26
    invoke-virtual {v3, v11}, Lio/rong/imlib/NativeObject$UserProfile;->setIpv6Preferred(Z)V

    .line 27
    invoke-virtual {v3, v7}, Lio/rong/imlib/NativeObject$UserProfile;->setPublicService(Z)V

    .line 28
    invoke-virtual {v3, v8}, Lio/rong/imlib/NativeObject$UserProfile;->setPushSetting(Z)V

    .line 29
    invoke-virtual {v3, v13}, Lio/rong/imlib/NativeObject$UserProfile;->setSdkReconnect(Z)V

    .line 30
    invoke-virtual {v3, v0}, Lio/rong/imlib/NativeObject$UserProfile;->setGroupMessageLimit(I)V

    .line 31
    invoke-virtual {v3, v2}, Lio/rong/imlib/NativeObject$UserProfile;->setClientIp(Ljava/lang/String;)V

    .line 32
    invoke-virtual {v3, v10}, Lio/rong/imlib/NativeObject$UserProfile;->setKvStorageOpened(Z)V

    .line 33
    iget-object v0, v1, Lio/rong/imlib/ConnectionService;->mContext:Landroid/content/Context;

    invoke-static {v0}, Lio/rong/imlib/common/SignatureUtils;->getAppSignatureSHA1(Landroid/content/Context;)Ljava/lang/String;

    move-result-object v0

    invoke-virtual {v3, v0}, Lio/rong/imlib/NativeObject$UserProfile;->setIdentification(Ljava/lang/String;)V

    .line 34
    invoke-static {}, Lio/rong/imlib/navigation/NavigationClient;->getInstance()Lio/rong/imlib/navigation/NavigationClient;

    move-result-object v0

    move-object/from16 v2, p1

    invoke-virtual {v0, v2}, Lio/rong/imlib/navigation/NavigationClient;->getTokenExceptNavi(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    .line 35
    iget-object v2, v1, Lio/rong/imlib/ConnectionService;->mNativeObj:Lio/rong/imlib/NativeObject;

    invoke-virtual {v2, v0, v6, v4, v3}, Lio/rong/imlib/NativeObject;->Connect(Ljava/lang/String;[Lio/rong/imlib/NativeObject$ConnectionEntry;Ljava/lang/String;Lio/rong/imlib/NativeObject$UserProfile;)I

    move-result v8

    if-eqz v8, :cond_154

    .line 36
    iget-object v7, v1, Lio/rong/imlib/ConnectionService;->mConnectListener:Lio/rong/imlib/ConnectionService$ConnectStatusListener;

    if-eqz v7, :cond_154

    const/4 v10, -0x1

    const/4 v11, 0x0

    const-string v9, ""

    const-string v12, ""

    .line 37
    invoke-virtual/range {v7 .. v12}, Lio/rong/imlib/ConnectionService$ConnectStatusListener;->OnRmtpComplete(ILjava/lang/String;ISLjava/lang/String;)V

    :cond_154
    return-void

    .line 38
    :cond_155
    :goto_155
    invoke-static {}, Lio/rong/imlib/CMPStrategy;->getInstance()Lio/rong/imlib/CMPStrategy;

    move-result-object v0

    iget-object v2, v1, Lio/rong/imlib/ConnectionService;->mContext:Landroid/content/Context;

    invoke-virtual {v0, v2}, Lio/rong/imlib/CMPStrategy;->clearCache(Landroid/content/Context;)V

    .line 39
    iget-object v3, v1, Lio/rong/imlib/ConnectionService;->mConnectListener:Lio/rong/imlib/ConnectionService$ConnectStatusListener;

    sget-object v0, Lio/rong/imlib/RongIMClient$ErrorCode;->RC_NODE_NOT_FOUND:Lio/rong/imlib/RongIMClient$ErrorCode;

    invoke-virtual {v0}, Lio/rong/imlib/RongIMClient$ErrorCode;->getValue()I

    move-result v4

    const/4 v6, 0x0

    const/4 v7, 0x0

    const-string v5, ""

    const-string v8, ""

    invoke-virtual/range {v3 .. v8}, Lio/rong/imlib/ConnectionService$ConnectStatusListener;->OnRmtpComplete(ILjava/lang/String;ISLjava/lang/String;)V

    return-void
.end method


# virtual methods
.method connect(Ljava/lang/String;ZZLio/rong/imlib/NativeClient$IConnectResultCallback;)V
    .registers 13
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Ljava/lang/String;",
            "ZZ",
            "Lio/rong/imlib/NativeClient$IConnectResultCallback<",
            "Ljava/lang/String;",
            ">;)V"
        }
    .end annotation

    .line 1
    invoke-virtual {p0}, Lio/rong/imlib/ConnectionService;->resetReconnectCount()V

    .line 2
    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mHandler:Landroid/os/Handler;

    new-instance v7, Lio/rong/imlib/ConnectionService$3;

    move-object v1, v7

    move-object v2, p0

    move-object v3, p1

    move v4, p2

    move v5, p3

    move-object v6, p4

    invoke-direct/range {v1 .. v6}, Lio/rong/imlib/ConnectionService$3;-><init>(Lio/rong/imlib/ConnectionService;Ljava/lang/String;ZZLio/rong/imlib/NativeClient$IConnectResultCallback;)V

    invoke-virtual {v0, v7}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z

    return-void
.end method

.method disconnect(Z)V
    .registers 4

    .line 1
    invoke-virtual {p0}, Lio/rong/imlib/ConnectionService;->resetReconnectCount()V

    .line 2
    invoke-direct {p0}, Lio/rong/imlib/ConnectionService;->stopRetry()V

    .line 3
    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mNativeObj:Lio/rong/imlib/NativeObject;

    if-eqz v0, :cond_33

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

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

    const-string v1, "[connect] disconnect:"

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

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

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

    move-result-object v0

    const-string v1, "ConnectionService"

    invoke-static {v1, v0}, Lio/rong/common/rlog/RLog;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 5
    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mConnectionState:Lio/rong/imlib/ConnectionState;

    invoke-virtual {v0}, Lio/rong/imlib/ConnectionState;->signUp()V

    const/4 v0, 0x0

    .line 6
    iput-object v0, p0, Lio/rong/imlib/ConnectionService;->mToken:Ljava/lang/String;

    .line 7
    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mNativeObj:Lio/rong/imlib/NativeObject;

    if-eqz p1, :cond_2e

    const/4 p1, 0x2

    goto :goto_2f

    :cond_2e
    const/4 p1, 0x4

    :goto_2f
    invoke-virtual {v0, p1}, Lio/rong/imlib/NativeObject;->Disconnect(I)V

    return-void

    .line 8
    :cond_33
    new-instance p1, Ljava/lang/RuntimeException;

    const-string v0, "NativeClient \u5c1a\u672a\u521d\u59cb\u5316!"

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

    throw p1
.end method

.method disposeReconnectByErrorCode(II)Z
    .registers 8

    const/4 v0, 0x2

    .line 1
    new-array v0, v0, [Ljava/lang/Object;

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

    move-result-object v1

    const/4 v2, 0x0

    aput-object v1, v0, v2

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

    move-result-object p2

    const/4 v1, 0x1

    aput-object p2, v0, v1

    const/4 p2, 0x4

    const-string v3, "P-connect-S"

    const-string v4, "status_code|native_code"

    invoke-static {p2, v1, v3, v4, v0}, Lio/rong/common/fwlog/FwLog;->write(IILjava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V

    .line 2
    iget-object p2, p0, Lio/rong/imlib/ConnectionService;->mConnectionState:Lio/rong/imlib/ConnectionState;

    invoke-virtual {p2, p1}, Lio/rong/imlib/ConnectionState;->onEvent(I)V

    .line 3
    iget-object p2, p0, Lio/rong/imlib/ConnectionService;->mConnectionState:Lio/rong/imlib/ConnectionState;

    invoke-virtual {p2}, Lio/rong/imlib/ConnectionState;->getCurrentStatus()Lio/rong/imlib/RongIMClient$ConnectionStatusListener$ConnectionStatus;

    move-result-object p2

    .line 4
    sget-object v0, Lio/rong/imlib/RongIMClient$ConnectionStatusListener$ConnectionStatus;->CONNECTED:Lio/rong/imlib/RongIMClient$ConnectionStatusListener$ConnectionStatus;

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

    move-result v0

    if-eqz v0, :cond_30

    .line 5
    invoke-direct {p0}, Lio/rong/imlib/ConnectionService;->stopRetry()V

    goto :goto_66

    .line 6
    :cond_30
    sget-object v0, Lio/rong/imlib/RongIMClient$ConnectionStatusListener$ConnectionStatus;->SUSPEND:Lio/rong/imlib/RongIMClient$ConnectionStatusListener$ConnectionStatus;

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

    move-result v0

    if-eqz v0, :cond_3c

    .line 7
    invoke-direct {p0, p1}, Lio/rong/imlib/ConnectionService;->handleSuspend(I)V

    goto :goto_67

    .line 8
    :cond_3c
    new-instance p1, Ljava/lang/StringBuilder;

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

    const-string v0, "disposeReconnectByErrorCode cannot reconnect : status = "

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

    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mConnectionState:Lio/rong/imlib/ConnectionState;

    invoke-virtual {v0}, Lio/rong/imlib/ConnectionState;->getCurrentStatus()Lio/rong/imlib/RongIMClient$ConnectionStatusListener$ConnectionStatus;

    move-result-object v0

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

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

    move-result-object p1

    const-string v0, "ConnectionService"

    invoke-static {v0, p1}, Lio/rong/common/rlog/RLog;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 9
    sget-object p1, Lio/rong/imlib/RongIMClient$ConnectionStatusListener$ConnectionStatus;->TIMEOUT:Lio/rong/imlib/RongIMClient$ConnectionStatusListener$ConnectionStatus;

    invoke-virtual {p2, p1}, Ljava/lang/Enum;->equals(Ljava/lang/Object;)Z

    move-result p1

    if-eqz p1, :cond_63

    .line 10
    invoke-virtual {p0, v2}, Lio/rong/imlib/ConnectionService;->disconnect(Z)V

    .line 11
    :cond_63
    invoke-direct {p0}, Lio/rong/imlib/ConnectionService;->stopRetry()V

    :goto_66
    const/4 v1, 0x0

    :goto_67
    return v1
.end method

.method getConnectionState()Lio/rong/imlib/ConnectionState;
    .registers 2

    .line 1
    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mConnectionState:Lio/rong/imlib/ConnectionState;

    return-object v0
.end method

.method initIPCEnviroment(Ljava/lang/String;I)V
    .registers 5

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

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

    const-string v1, "initConnectToken "

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

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

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

    move-result-object v0

    const-string v1, "ConnectionService"

    invoke-static {v1, v0}, Lio/rong/common/rlog/RLog;->i(Ljava/lang/String;Ljava/lang/String;)I

    .line 2
    iput-object p1, p0, Lio/rong/imlib/ConnectionService;->mToken:Ljava/lang/String;

    .line 3
    iget-object p1, p0, Lio/rong/imlib/ConnectionService;->mConnectionState:Lio/rong/imlib/ConnectionState;

    invoke-virtual {p1, p2}, Lio/rong/imlib/ConnectionState;->initConnectStatus(I)V

    return-void
.end method

.method initService(Landroid/content/Context;Lio/rong/imlib/NativeObject;Ljava/lang/String;)V
    .registers 6

    const-string v0, "ConnectionService"

    .line 1
    iput-object p1, p0, Lio/rong/imlib/ConnectionService;->mContext:Landroid/content/Context;

    .line 2
    iput-object p2, p0, Lio/rong/imlib/ConnectionService;->mNativeObj:Lio/rong/imlib/NativeObject;

    .line 3
    iput-object p3, p0, Lio/rong/imlib/ConnectionService;->mAppKey:Ljava/lang/String;

    .line 4
    new-instance p2, Lio/rong/imlib/ConnectionService$ConnectStatusListener;

    const/4 p3, 0x0

    invoke-direct {p2, p0, p3}, Lio/rong/imlib/ConnectionService$ConnectStatusListener;-><init>(Lio/rong/imlib/ConnectionService;Lio/rong/imlib/ConnectionService$1;)V

    iput-object p2, p0, Lio/rong/imlib/ConnectionService;->mConnectListener:Lio/rong/imlib/ConnectionService$ConnectStatusListener;

    .line 5
    iget-object p2, p0, Lio/rong/imlib/ConnectionService;->mNativeObj:Lio/rong/imlib/NativeObject;

    iget-object p3, p0, Lio/rong/imlib/ConnectionService;->mConnectListener:Lio/rong/imlib/ConnectionService$ConnectStatusListener;

    invoke-virtual {p2, p3}, Lio/rong/imlib/NativeObject;->SetConnectionStatusListener(Lio/rong/imlib/NativeObject$ConnectionStatusListener;)V

    .line 6
    invoke-static {}, Lio/rong/imlib/CMPStrategy;->getInstance()Lio/rong/imlib/CMPStrategy;

    move-result-object p2

    iget-object p3, p0, Lio/rong/imlib/ConnectionService;->mContext:Landroid/content/Context;

    invoke-virtual {p2, p3}, Lio/rong/imlib/CMPStrategy;->setEnvironment(Landroid/content/Context;)V

    .line 7
    :try_start_20
    invoke-virtual {p1}, Landroid/content/Context;->getResources()Landroid/content/res/Resources;

    move-result-object p2

    const-string p3, "rc_reconnect_interval"

    const-string v1, "array"

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

    move-result-object p1

    invoke-virtual {p2, p3, v1, p1}, Landroid/content/res/Resources;->getIdentifier(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)I

    move-result p1

    invoke-virtual {p2, p1}, Landroid/content/res/Resources;->getStringArray(I)[Ljava/lang/String;

    move-result-object p1

    iput-object p1, p0, Lio/rong/imlib/ConnectionService;->mReconnectInterval:[Ljava/lang/String;

    .line 9
    iget-object p1, p0, Lio/rong/imlib/ConnectionService;->mReconnectInterval:[Ljava/lang/String;

    array-length p1, p1

    .line 10
    new-instance p2, Ljava/lang/StringBuilder;

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

    const-string p3, "mReconnectInterval "

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

    invoke-virtual {p2, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

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

    move-result-object p2

    invoke-static {v0, p2}, Lio/rong/common/rlog/RLog;->i(Ljava/lang/String;Ljava/lang/String;)I

    if-eqz p1, :cond_77

    .line 11
    iget-object p2, p0, Lio/rong/imlib/ConnectionService;->mReconnectInterval:[Ljava/lang/String;

    const/4 p3, 0x0

    aget-object p2, p2, p3

    if-eqz p2, :cond_77

    const/16 p2, 0xa

    if-gt p1, p2, :cond_6f

    .line 12
    iget-object p1, p0, Lio/rong/imlib/ConnectionService;->mReconnectInterval:[Ljava/lang/String;

    array-length p2, p1

    :goto_5d
    if-ge p3, p2, :cond_84

    aget-object v1, p1, p3
    :try_end_61
    .catch Landroid/content/res/Resources$NotFoundException; {:try_start_20 .. :try_end_61} :catch_7f

    .line 13
    :try_start_61
    invoke-static {v1}, Ljava/lang/Float;->parseFloat(Ljava/lang/String;)F
    :try_end_64
    .catch Ljava/lang/NumberFormatException; {:try_start_61 .. :try_end_64} :catch_67
    .catch Landroid/content/res/Resources$NotFoundException; {:try_start_61 .. :try_end_64} :catch_7f

    add-int/lit8 p3, p3, 0x1

    goto :goto_5d

    .line 14
    :catch_67
    :try_start_67
    new-instance p1, Ljava/lang/IllegalArgumentException;

    const-string p2, "The value of the field must be digits"

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

    throw p1

    .line 15
    :cond_6f
    new-instance p1, Ljava/lang/IllegalArgumentException;

    const-string p2, "The numbers of rc_reconnect_interval must less than 10"

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

    throw p1

    .line 16
    :cond_77
    new-instance p1, Ljava/lang/IllegalArgumentException;

    const-string p2, "rc_reconnect_interval must have a value and the type of the field must be string-array"

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

    throw p1
    :try_end_7f
    .catch Landroid/content/res/Resources$NotFoundException; {:try_start_67 .. :try_end_7f} :catch_7f

    :catch_7f
    const-string p1, "Not found rc_reconnect_interval in rc_configuration.xml, use default config"

    .line 17
    invoke-static {v0, p1}, Lio/rong/common/rlog/RLog;->i(Ljava/lang/String;Ljava/lang/String;)I

    .line 18
    :cond_84
    invoke-direct {p0}, Lio/rong/imlib/ConnectionService;->setHeartBeatListener()V

    return-void
.end method

.method resetReconnectCount()V
    .registers 3

    const-string v0, "ConnectionService"

    const-string v1, "reset reconnectCount"

    .line 1
    invoke-static {v0, v1}, Lio/rong/common/rlog/RLog;->i(Ljava/lang/String;Ljava/lang/String;)I

    .line 2
    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mRcRetryCount:Ljava/util/concurrent/atomic/AtomicInteger;

    const/4 v1, 0x0

    invoke-virtual {v0, v1}, Ljava/util/concurrent/atomic/AtomicInteger;->set(I)V

    return-void
.end method

.method setIpcConnectTimeOut()V
    .registers 3

    .line 1
    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mCallBackExecutor:Ljava/util/concurrent/Executor;

    new-instance v1, Lio/rong/imlib/ConnectionService$6;

    invoke-direct {v1, p0}, Lio/rong/imlib/ConnectionService$6;-><init>(Lio/rong/imlib/ConnectionService;)V

    invoke-interface {v0, v1}, Ljava/util/concurrent/Executor;->execute(Ljava/lang/Runnable;)V

    return-void
.end method

.method setMainProgressConnectionStatusListener(Lio/rong/imlib/NativeClient$ICodeListener;)V
    .registers 3

    .line 1
    iget-object v0, p0, Lio/rong/imlib/ConnectionService;->mConnectionState:Lio/rong/imlib/ConnectionState;

    invoke-virtual {v0, p1}, Lio/rong/imlib/ConnectionState;->setConnectionStatusListener(Lio/rong/imlib/NativeClient$ICodeListener;)V

    return-void
.end method

.method setReconnectKickEnable(Z)V
    .registers 2

    .line 1
    iput-boolean p1, p0, Lio/rong/imlib/ConnectionService;->mEnableReconnectKick:Z

    return-void
.end method