RtLogUploadManager.smali
.class public Lio/rong/rtlog/upload/RtLogUploadManager;
.super Ljava/lang/Object;
.source "RtLogUploadManager.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lio/rong/rtlog/upload/RtLogUploadManager$SingletonHolder;
}
.end annotation
# static fields
.field private static final FULL_UPLOAD_SENDER_USER_ID:Ljava/lang/String; = "rongcloudsystem"
.field private static final TAG:Ljava/lang/String; = "RtLogUploadManager"
# instance fields
.field private context:Landroid/content/Context;
.field private fullUploadCenter:Lio/rong/rtlog/upload/FullUploadTaskScheduleCenter;
.field private lastInBackgroundTimeMillis:J
.field private timingUploadCenter:Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;
.field private workExecutor:Lio/rong/rtlog/upload/LimitAliveSingleTaskExecutor;
# direct methods
.method static constructor <clinit>()V
.registers 0
return-void
.end method
.method private constructor <init>()V
.registers 3
.line 2
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 3
new-instance v0, Lio/rong/rtlog/upload/LimitAliveSingleTaskExecutor;
invoke-direct {v0}, Lio/rong/rtlog/upload/LimitAliveSingleTaskExecutor;-><init>()V
iput-object v0, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->workExecutor:Lio/rong/rtlog/upload/LimitAliveSingleTaskExecutor;
const-wide/16 v0, -0x1
.line 4
iput-wide v0, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->lastInBackgroundTimeMillis:J
return-void
.end method
.method synthetic constructor <init>(Lio/rong/rtlog/upload/RtLogUploadManager$1;)V
.registers 2
.line 1
invoke-direct {p0}, Lio/rong/rtlog/upload/RtLogUploadManager;-><init>()V
return-void
.end method
.method static synthetic access$200(Lio/rong/rtlog/upload/RtLogUploadManager;Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
.registers 5
.line 1
invoke-direct {p0, p1, p2, p3, p4}, Lio/rong/rtlog/upload/RtLogUploadManager;->internalInit(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method
.method static synthetic access$300(Lio/rong/rtlog/upload/RtLogUploadManager;)Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;
.registers 1
.line 1
iget-object p0, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->timingUploadCenter:Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;
return-object p0
.end method
.method static synthetic access$400(Lio/rong/rtlog/upload/RtLogUploadManager;)J
.registers 3
.line 1
iget-wide v0, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->lastInBackgroundTimeMillis:J
return-wide v0
.end method
.method static synthetic access$402(Lio/rong/rtlog/upload/RtLogUploadManager;J)J
.registers 3
.line 1
iput-wide p1, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->lastInBackgroundTimeMillis:J
return-wide p1
.end method
.method static synthetic access$500(Lio/rong/rtlog/upload/RtLogUploadManager;)Landroid/content/Context;
.registers 1
.line 1
iget-object p0, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->context:Landroid/content/Context;
return-object p0
.end method
.method static synthetic access$600(Lio/rong/rtlog/upload/RtLogUploadManager;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;JJ)V
.registers 8
.line 1
invoke-direct/range {p0 .. p7}, Lio/rong/rtlog/upload/RtLogUploadManager;->addFullUploadTask(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;JJ)V
return-void
.end method
.method private addFullUploadTask(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;JJ)V
.registers 16
.line 1
iget-object v0, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->fullUploadCenter:Lio/rong/rtlog/upload/FullUploadTaskScheduleCenter;
if-eqz v0, :cond_d
move-object v1, p1
move-object v2, p2
move-object v3, p3
move-wide v4, p4
move-wide v6, p6
.line 2
invoke-virtual/range {v0 .. v7}, Lio/rong/rtlog/upload/FullUploadTaskScheduleCenter;->addTask(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;JJ)V
goto :goto_14
.line 3
:cond_d
sget-object p1, Lio/rong/rtlog/upload/RtLogUploadManager;->TAG:Ljava/lang/String;
const-string p2, "addFullUploadTask - fullUploadCenter is null, may not init."
invoke-static {p1, p2}, Lio/rong/common/rlog/RLog;->d(Ljava/lang/String;Ljava/lang/String;)I
:goto_14
return-void
.end method
.method public static getInstance()Lio/rong/rtlog/upload/RtLogUploadManager;
.registers 1
.line 1
# getter for: Lio/rong/rtlog/upload/RtLogUploadManager$SingletonHolder;->instance:Lio/rong/rtlog/upload/RtLogUploadManager;
invoke-static {}, Lio/rong/rtlog/upload/RtLogUploadManager$SingletonHolder;->access$100()Lio/rong/rtlog/upload/RtLogUploadManager;
move-result-object v0
return-object v0
.end method
.method private getSessionId()Ljava/lang/String;
.registers 6
const-string v0, ""
.line 1
invoke-static {}, Ljava/util/UUID;->randomUUID()Ljava/util/UUID;
move-result-object v1
.line 2
invoke-virtual {v1}, Ljava/util/UUID;->toString()Ljava/lang/String;
move-result-object v2
:try_start_a
const-string v3, "MD5"
.line 3
invoke-static {v3}, Ljava/security/MessageDigest;->getInstance(Ljava/lang/String;)Ljava/security/MessageDigest;
move-result-object v3
.line 4
invoke-virtual {v1}, Ljava/util/UUID;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/String;->getBytes()[B
move-result-object v1
invoke-virtual {v3, v1}, Ljava/security/MessageDigest;->update([B)V
.line 5
invoke-virtual {v3}, Ljava/security/MessageDigest;->digest()[B
move-result-object v1
const/4 v3, 0x0
.line 6
invoke-static {v1, v3}, Landroid/util/Base64;->encode([BI)[B
move-result-object v1
.line 7
new-instance v3, Ljava/lang/String;
invoke-direct {v3, v1}, Ljava/lang/String;-><init>([B)V
:try_end_29
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_a .. :try_end_29} :catch_48
:try_start_29
const-string v1, "="
.line 8
invoke-virtual {v3, v1, v0}, Ljava/lang/String;->replace(Ljava/lang/CharSequence;Ljava/lang/CharSequence;)Ljava/lang/String;
move-result-object v1
const-string v2, "+"
const-string v4, "-"
invoke-virtual {v1, v2, v4}, Ljava/lang/String;->replace(Ljava/lang/CharSequence;Ljava/lang/CharSequence;)Ljava/lang/String;
move-result-object v1
const-string v2, "/"
const-string v4, "_"
invoke-virtual {v1, v2, v4}, Ljava/lang/String;->replace(Ljava/lang/CharSequence;Ljava/lang/CharSequence;)Ljava/lang/String;
move-result-object v1
const-string v2, "\n"
invoke-virtual {v1, v2, v0}, Ljava/lang/String;->replace(Ljava/lang/CharSequence;Ljava/lang/CharSequence;)Ljava/lang/String;
move-result-object v0
:try_end_45
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_29 .. :try_end_45} :catch_46
goto :goto_49
:catch_46
move-object v0, v3
goto :goto_49
:catch_48
move-object v0, v2
:goto_49
return-object v0
.end method
.method private getUploadFileCacheDir()Ljava/lang/String;
.registers 4
.line 1
iget-object v0, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->context:Landroid/content/Context;
const/4 v1, 0x0
if-eqz v0, :cond_1e
.line 2
invoke-virtual {v0}, Landroid/content/Context;->getExternalCacheDir()Ljava/io/File;
move-result-object v0
if-eqz v0, :cond_10
.line 3
invoke-virtual {v0}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v0
return-object v0
.line 4
:cond_10
iget-object v0, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->context:Landroid/content/Context;
invoke-virtual {v0}, Landroid/content/Context;->getCacheDir()Ljava/io/File;
move-result-object v0
if-eqz v0, :cond_1d
.line 5
invoke-virtual {v0}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v0
return-object v0
:cond_1d
return-object v1
.line 6
:cond_1e
sget-object v0, Lio/rong/rtlog/upload/RtLogUploadManager;->TAG:Ljava/lang/String;
const-string v2, "getUploadFileCacheDir - context is null, may not init."
invoke-static {v0, v2}, Lio/rong/common/rlog/RLog;->d(Ljava/lang/String;Ljava/lang/String;)I
return-object v1
.end method
.method private internalInit(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
.registers 14
.line 1
invoke-virtual {p1}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;
move-result-object v0
iput-object v0, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->context:Landroid/content/Context;
.line 2
new-instance v0, Lio/rong/rtlog/upload/RtFwLogConsolePrinter;
iget-object v1, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->context:Landroid/content/Context;
invoke-direct {v0, v1}, Lio/rong/rtlog/upload/RtFwLogConsolePrinter;-><init>(Landroid/content/Context;)V
invoke-static {v0}, Lio/rong/common/fwlog/FwLog;->setLogConsolePrinter(Lio/rong/common/fwlog/IFwLogConsolePrinter;)V
.line 3
invoke-static {p1}, Lio/rong/common/fwlog/FwLog;->listenUncaughtException(Landroid/content/Context;)V
.line 4
new-instance v0, Lio/rong/rtlog/upload/RtLogCache;
iget-object v1, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->context:Landroid/content/Context;
invoke-direct {v0, v1, p4}, Lio/rong/rtlog/upload/RtLogCache;-><init>(Landroid/content/Context;Ljava/lang/String;)V
.line 5
iget-object v1, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->fullUploadCenter:Lio/rong/rtlog/upload/FullUploadTaskScheduleCenter;
if-eqz v1, :cond_21
.line 6
invoke-virtual {v1}, Lio/rong/rtlog/upload/FullUploadTaskScheduleCenter;->endSchedule()V
.line 7
:cond_21
new-instance v1, Lio/rong/rtlog/upload/FullUploadTaskScheduleCenter;
invoke-direct {p0}, Lio/rong/rtlog/upload/RtLogUploadManager;->getUploadFileCacheDir()Ljava/lang/String;
move-result-object v7
move-object v2, v1
move-object v3, p2
move-object v4, p3
move-object v5, p4
move-object v6, v0
invoke-direct/range {v2 .. v7}, Lio/rong/rtlog/upload/FullUploadTaskScheduleCenter;-><init>(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Lio/rong/rtlog/upload/RtLogCache;Ljava/lang/String;)V
iput-object v1, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->fullUploadCenter:Lio/rong/rtlog/upload/FullUploadTaskScheduleCenter;
.line 8
iget-object v1, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->fullUploadCenter:Lio/rong/rtlog/upload/FullUploadTaskScheduleCenter;
invoke-virtual {v1}, Lio/rong/rtlog/upload/FullUploadTaskScheduleCenter;->loadCacheTaskAndStart()V
.line 9
new-instance v1, Ljava/io/File;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {p1}, Landroid/content/Context;->getFilesDir()Ljava/io/File;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
sget-object v3, Ljava/io/File;->separator:Ljava/lang/String;
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v3, Ljava/io/File;->separator:Ljava/lang/String;
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, "rclog"
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-direct {v1, v2}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 10
invoke-virtual {v1}, Ljava/io/File;->exists()Z
move-result v2
if-nez v2, :cond_71
.line 11
invoke-virtual {v1}, Ljava/io/File;->mkdirs()Z
move-result v2
if-nez v2, :cond_71
.line 12
sget-object p1, Lio/rong/rtlog/upload/RtLogUploadManager;->TAG:Ljava/lang/String;
const-string p2, "create log db directory failed. Write log will not available."
invoke-static {p1, p2}, Lio/rong/common/rlog/RLog;->e(Ljava/lang/String;Ljava/lang/String;)I
return-void
.line 13
:cond_71
invoke-virtual {v1}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v1
invoke-direct {p0}, Lio/rong/rtlog/upload/RtLogUploadManager;->getSessionId()Ljava/lang/String;
move-result-object v2
invoke-static {p1, v1, p4, v2}, Lio/rong/rtlog/upload/RtLogNativeProxy;->initialize(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Z
move-result v1
if-nez v1, :cond_86
.line 14
sget-object v1, Lio/rong/rtlog/upload/RtLogUploadManager;->TAG:Ljava/lang/String;
const-string v2, "RtLogNative initialize failed. Write log will not available."
invoke-static {v1, v2}, Lio/rong/common/rlog/RLog;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 15
:cond_86
new-instance v1, Lio/rong/rtlog/upload/RtFwLogWriter;
invoke-direct {v1, p1}, Lio/rong/rtlog/upload/RtFwLogWriter;-><init>(Landroid/content/Context;)V
invoke-static {v1}, Lio/rong/common/fwlog/FwLog;->setDirectWriter(Lio/rong/common/fwlog/IFwLogWriter;)V
.line 16
iget-object v1, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->timingUploadCenter:Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;
if-eqz v1, :cond_95
.line 17
invoke-virtual {v1}, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->endSchedule()V
.line 18
:cond_95
new-instance v1, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;
invoke-direct {p0}, Lio/rong/rtlog/upload/RtLogUploadManager;->getUploadFileCacheDir()Ljava/lang/String;
move-result-object v8
move-object v2, v1
move-object v3, p1
move-object v4, p2
move-object v5, p3
move-object v6, p4
move-object v7, v0
invoke-direct/range {v2 .. v8}, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;-><init>(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Lio/rong/rtlog/upload/RtLogCache;Ljava/lang/String;)V
iput-object v1, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->timingUploadCenter:Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;
.line 19
iget-object p1, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->timingUploadCenter:Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;
iget-wide p2, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->lastInBackgroundTimeMillis:J
invoke-virtual {p1, p2, p3}, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->setToBackgroundTime(J)V
return-void
.end method
# virtual methods
.method public createFullUploadTask(Lio/rong/imlib/model/Message;)V
.registers 4
.line 1
iget-object v0, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->workExecutor:Lio/rong/rtlog/upload/LimitAliveSingleTaskExecutor;
new-instance v1, Lio/rong/rtlog/upload/RtLogUploadManager$5;
invoke-direct {v1, p0, p1}, Lio/rong/rtlog/upload/RtLogUploadManager$5;-><init>(Lio/rong/rtlog/upload/RtLogUploadManager;Lio/rong/imlib/model/Message;)V
invoke-virtual {v0, v1}, Lio/rong/rtlog/upload/LimitAliveSingleTaskExecutor;->execute(Ljava/lang/Runnable;)V
return-void
.end method
.method public declared-synchronized init(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
.registers 13
monitor-enter p0
if-eqz p1, :cond_17
.line 1
:try_start_3
iget-object v0, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->workExecutor:Lio/rong/rtlog/upload/LimitAliveSingleTaskExecutor;
new-instance v7, Lio/rong/rtlog/upload/RtLogUploadManager$1;
move-object v1, v7
move-object v2, p0
move-object v3, p1
move-object v4, p2
move-object v5, p3
move-object v6, p4
invoke-direct/range {v1 .. v6}, Lio/rong/rtlog/upload/RtLogUploadManager$1;-><init>(Lio/rong/rtlog/upload/RtLogUploadManager;Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
invoke-virtual {v0, v7}, Lio/rong/rtlog/upload/LimitAliveSingleTaskExecutor;->execute(Ljava/lang/Runnable;)V
:try_end_13
.catchall {:try_start_3 .. :try_end_13} :catchall_14
goto :goto_17
:catchall_14
move-exception p1
monitor-exit p0
throw p1
.line 2
:cond_17
:goto_17
monitor-exit p0
return-void
.end method
.method public setIsBackgroundMode(Z)V
.registers 4
.line 1
iget-object v0, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->workExecutor:Lio/rong/rtlog/upload/LimitAliveSingleTaskExecutor;
new-instance v1, Lio/rong/rtlog/upload/RtLogUploadManager$3;
invoke-direct {v1, p0, p1}, Lio/rong/rtlog/upload/RtLogUploadManager$3;-><init>(Lio/rong/rtlog/upload/RtLogUploadManager;Z)V
invoke-virtual {v0, v1}, Lio/rong/rtlog/upload/LimitAliveSingleTaskExecutor;->execute(Ljava/lang/Runnable;)V
return-void
.end method
.method public startTimingUploadTask()V
.registers 3
.line 1
iget-object v0, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->timingUploadCenter:Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;
if-eqz v0, :cond_f
.line 2
iget-object v0, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->workExecutor:Lio/rong/rtlog/upload/LimitAliveSingleTaskExecutor;
new-instance v1, Lio/rong/rtlog/upload/RtLogUploadManager$2;
invoke-direct {v1, p0}, Lio/rong/rtlog/upload/RtLogUploadManager$2;-><init>(Lio/rong/rtlog/upload/RtLogUploadManager;)V
invoke-virtual {v0, v1}, Lio/rong/rtlog/upload/LimitAliveSingleTaskExecutor;->execute(Ljava/lang/Runnable;)V
goto :goto_16
.line 3
:cond_f
sget-object v0, Lio/rong/rtlog/upload/RtLogUploadManager;->TAG:Ljava/lang/String;
const-string v1, "startTimingUploadTask - timingUploadCenter is null, may not init."
invoke-static {v0, v1}, Lio/rong/common/rlog/RLog;->d(Ljava/lang/String;Ljava/lang/String;)I
:goto_16
return-void
.end method
.method public updateTimingUploadConfig(Ljava/lang/String;)V
.registers 4
.line 1
iget-object v0, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->timingUploadCenter:Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;
if-eqz v0, :cond_f
.line 2
iget-object v0, p0, Lio/rong/rtlog/upload/RtLogUploadManager;->workExecutor:Lio/rong/rtlog/upload/LimitAliveSingleTaskExecutor;
new-instance v1, Lio/rong/rtlog/upload/RtLogUploadManager$4;
invoke-direct {v1, p0, p1}, Lio/rong/rtlog/upload/RtLogUploadManager$4;-><init>(Lio/rong/rtlog/upload/RtLogUploadManager;Ljava/lang/String;)V
invoke-virtual {v0, v1}, Lio/rong/rtlog/upload/LimitAliveSingleTaskExecutor;->execute(Ljava/lang/Runnable;)V
goto :goto_16
.line 3
:cond_f
sget-object p1, Lio/rong/rtlog/upload/RtLogUploadManager;->TAG:Ljava/lang/String;
const-string v0, "updateConfig - timingUploadCenter is null, may not init."
invoke-static {p1, v0}, Lio/rong/common/rlog/RLog;->d(Ljava/lang/String;Ljava/lang/String;)I
:goto_16
return-void
.end method