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