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