RLogFileProcessor.smali

.class public Lio/rong/common/rlog/RLogFileProcessor;
.super Ljava/lang/Object;
.source "RLogFileProcessor.java"


# static fields
.field private static final TAG:Ljava/lang/String; = "RLogFileProcessor"


# instance fields
.field fileSize:I

.field private volatile isUploading:Z

.field private mCompressor:Lio/rong/common/rlog/Compressor;

.field private mConfig:Lio/rong/common/rlog/RLogConfig;

.field private mLogFileWriter:Lio/rong/common/rlog/LogFileWriter;

.field private mReporter:Lio/rong/common/rlog/RLogReporter;


# direct methods
.method private constructor <init>(Lio/rong/common/rlog/RLogConfig;)V
    .registers 4

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

    const/4 v0, 0x0

    .line 2
    iput-boolean v0, p0, Lio/rong/common/rlog/RLogFileProcessor;->isUploading:Z

    .line 3
    iput v0, p0, Lio/rong/common/rlog/RLogFileProcessor;->fileSize:I

    .line 4
    iput-object p1, p0, Lio/rong/common/rlog/RLogFileProcessor;->mConfig:Lio/rong/common/rlog/RLogConfig;

    .line 5
    new-instance v0, Lio/rong/common/rlog/RLogReporter;

    invoke-direct {v0}, Lio/rong/common/rlog/RLogReporter;-><init>()V

    iput-object v0, p0, Lio/rong/common/rlog/RLogFileProcessor;->mReporter:Lio/rong/common/rlog/RLogReporter;

    .line 6
    new-instance v0, Lio/rong/common/rlog/LogFileWriter;

    invoke-virtual {p1}, Lio/rong/common/rlog/RLogConfig;->getFilePath()Ljava/lang/String;

    move-result-object p1

    new-instance v1, Lio/rong/common/rlog/RLogFileProcessor$1;

    invoke-direct {v1, p0}, Lio/rong/common/rlog/RLogFileProcessor$1;-><init>(Lio/rong/common/rlog/RLogFileProcessor;)V

    invoke-direct {v0, p1, v1}, Lio/rong/common/rlog/LogFileWriter;-><init>(Ljava/lang/String;Lio/rong/common/rlog/LogFileWriter$IWriterListener;)V

    iput-object v0, p0, Lio/rong/common/rlog/RLogFileProcessor;->mLogFileWriter:Lio/rong/common/rlog/LogFileWriter;

    .line 7
    new-instance p1, Lio/rong/common/rlog/Compressor;

    new-instance v0, Lio/rong/common/rlog/RLogFileProcessor$2;

    invoke-direct {v0, p0}, Lio/rong/common/rlog/RLogFileProcessor$2;-><init>(Lio/rong/common/rlog/RLogFileProcessor;)V

    invoke-direct {p1, v0}, Lio/rong/common/rlog/Compressor;-><init>(Lio/rong/common/rlog/Compressor$ICompressListener;)V

    iput-object p1, p0, Lio/rong/common/rlog/RLogFileProcessor;->mCompressor:Lio/rong/common/rlog/Compressor;

    return-void
.end method

.method static synthetic access$000(Lio/rong/common/rlog/RLogFileProcessor;)Lio/rong/common/rlog/RLogConfig;
    .registers 1

    .line 1
    iget-object p0, p0, Lio/rong/common/rlog/RLogFileProcessor;->mConfig:Lio/rong/common/rlog/RLogConfig;

    return-object p0
.end method

.method static synthetic access$100(Lio/rong/common/rlog/RLogFileProcessor;)Lio/rong/common/rlog/LogFileWriter;
    .registers 1

    .line 1
    iget-object p0, p0, Lio/rong/common/rlog/RLogFileProcessor;->mLogFileWriter:Lio/rong/common/rlog/LogFileWriter;

    return-object p0
.end method

.method static synthetic access$200(Lio/rong/common/rlog/RLogFileProcessor;)Lio/rong/common/rlog/Compressor;
    .registers 1

    .line 1
    iget-object p0, p0, Lio/rong/common/rlog/RLogFileProcessor;->mCompressor:Lio/rong/common/rlog/Compressor;

    return-object p0
.end method

.method static synthetic access$300(Lio/rong/common/rlog/RLogFileProcessor;ZLjava/lang/String;Ljava/lang/String;Z)V
    .registers 5

    .line 1
    invoke-direct {p0, p1, p2, p3, p4}, Lio/rong/common/rlog/RLogFileProcessor;->processCompressFinish(ZLjava/lang/String;Ljava/lang/String;Z)V

    return-void
.end method

.method static synthetic access$402(Lio/rong/common/rlog/RLogFileProcessor;Z)Z
    .registers 2

    .line 1
    iput-boolean p1, p0, Lio/rong/common/rlog/RLogFileProcessor;->isUploading:Z

    return p1
.end method

.method public static init(Lio/rong/common/rlog/RLogConfig;)Lio/rong/common/rlog/RLogFileProcessor;
    .registers 2

    .line 1
    new-instance v0, Lio/rong/common/rlog/RLogFileProcessor;

    invoke-direct {v0, p0}, Lio/rong/common/rlog/RLogFileProcessor;-><init>(Lio/rong/common/rlog/RLogConfig;)V

    return-object v0
.end method

.method private processCompressFinish(ZLjava/lang/String;Ljava/lang/String;Z)V
    .registers 11

    const-string v0, "processCompressFinish file is:"

    const-string v1, "RLogFileProcessor"

    if-eqz p1, :cond_84

    .line 1
    new-instance p1, Ljava/io/File;

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

    invoke-virtual {p1}, Ljava/io/File;->delete()Z

    move-result p1

    if-nez p1, :cond_23

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

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

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

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

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

    move-result-object p1

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

    .line 3
    :cond_23
    iget-boolean p1, p0, Lio/rong/common/rlog/RLogFileProcessor;->isUploading:Z

    if-nez p1, :cond_be

    .line 4
    iget-object p1, p0, Lio/rong/common/rlog/RLogFileProcessor;->mConfig:Lio/rong/common/rlog/RLogConfig;

    invoke-virtual {p1}, Lio/rong/common/rlog/RLogConfig;->getZipConfig()Lio/rong/common/rlog/RLogConfig$ZipConfig;

    move-result-object p1

    if-eqz p1, :cond_be

    .line 5
    new-instance p2, Ljava/io/File;

    invoke-direct {p2, p3}, Ljava/io/File;-><init>(Ljava/lang/String;)V

    .line 6
    invoke-virtual {p1}, Lio/rong/common/rlog/RLogConfig$ZipConfig;->getCurrentSize()J

    move-result-wide v2

    invoke-virtual {p2}, Ljava/io/File;->length()J

    move-result-wide v4

    add-long/2addr v2, v4

    invoke-virtual {p1, v2, v3}, Lio/rong/common/rlog/RLogConfig$ZipConfig;->setCurrentSize(J)V

    .line 7
    invoke-virtual {p1, p2}, Lio/rong/common/rlog/RLogConfig$ZipConfig;->addFile(Ljava/io/File;)V

    .line 8
    :cond_43
    :goto_43
    invoke-virtual {p1}, Lio/rong/common/rlog/RLogConfig$ZipConfig;->getCurrentSize()J

    move-result-wide p2

    iget-object v2, p0, Lio/rong/common/rlog/RLogFileProcessor;->mConfig:Lio/rong/common/rlog/RLogConfig;

    invoke-virtual {v2}, Lio/rong/common/rlog/RLogConfig;->getZipMaxSize()J

    move-result-wide v2

    cmp-long v4, p2, v2

    if-lez v4, :cond_be

    .line 9
    invoke-virtual {p1}, Lio/rong/common/rlog/RLogConfig$ZipConfig;->getZipFiles()Ljava/util/TreeSet;

    move-result-object p2

    invoke-virtual {p2}, Ljava/util/TreeSet;->pollFirst()Ljava/lang/Object;

    move-result-object p2

    check-cast p2, Ljava/io/File;

    .line 10
    invoke-virtual {p1}, Lio/rong/common/rlog/RLogConfig$ZipConfig;->getCurrentSize()J

    move-result-wide v2

    invoke-virtual {p2}, Ljava/io/File;->length()J

    move-result-wide v4

    sub-long/2addr v2, v4

    invoke-virtual {p1, v2, v3}, Lio/rong/common/rlog/RLogConfig$ZipConfig;->setCurrentSize(J)V

    .line 11
    invoke-virtual {p2}, Ljava/io/File;->delete()Z

    move-result p3

    if-nez p3, :cond_43

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

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

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

    invoke-virtual {p2}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;

    move-result-object p2

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

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

    move-result-object p2

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

    goto :goto_43

    .line 13
    :cond_84
    new-instance p1, Ljava/io/File;

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

    invoke-virtual {p1}, Ljava/io/File;->delete()Z

    move-result p1

    if-nez p1, :cond_a1

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

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

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

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

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

    move-result-object p1

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

    .line 15
    :cond_a1
    new-instance p1, Ljava/io/File;

    invoke-direct {p1, p3}, Ljava/io/File;-><init>(Ljava/lang/String;)V

    invoke-virtual {p1}, Ljava/io/File;->delete()Z

    move-result p1

    if-nez p1, :cond_be

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

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

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

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

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

    move-result-object p1

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

    :cond_be
    if-eqz p4, :cond_c3

    .line 17
    invoke-direct {p0}, Lio/rong/common/rlog/RLogFileProcessor;->uploadLog()V

    :cond_c3
    return-void
.end method

.method private uploadLog()V
    .registers 15

    .line 1
    iget-boolean v0, p0, Lio/rong/common/rlog/RLogFileProcessor;->isUploading:Z

    if-eqz v0, :cond_5

    return-void

    .line 2
    :cond_5
    iget-object v0, p0, Lio/rong/common/rlog/RLogFileProcessor;->mConfig:Lio/rong/common/rlog/RLogConfig;

    invoke-virtual {v0}, Lio/rong/common/rlog/RLogConfig;->getZipConfig()Lio/rong/common/rlog/RLogConfig$ZipConfig;

    move-result-object v0

    if-nez v0, :cond_e

    return-void

    .line 3
    :cond_e
    invoke-virtual {v0}, Lio/rong/common/rlog/RLogConfig$ZipConfig;->getZipFiles()Ljava/util/TreeSet;

    move-result-object v0

    .line 4
    invoke-virtual {v0}, Ljava/util/TreeSet;->size()I

    move-result v1

    iput v1, p0, Lio/rong/common/rlog/RLogFileProcessor;->fileSize:I

    const/4 v1, 0x1

    .line 5
    iput-boolean v1, p0, Lio/rong/common/rlog/RLogFileProcessor;->isUploading:Z

    .line 6
    invoke-virtual {v0}, Ljava/util/TreeSet;->iterator()Ljava/util/Iterator;

    move-result-object v0

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

    move-result v2

    if-eqz v2, :cond_71

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

    move-result-object v2

    check-cast v2, Ljava/io/File;

    .line 7
    invoke-virtual {v2}, Ljava/io/File;->getName()Ljava/lang/String;

    move-result-object v3

    .line 8
    invoke-virtual {v3}, Ljava/lang/String;->length()I

    move-result v4

    add-int/lit8 v4, v4, -0x3

    const/4 v5, 0x0

    invoke-virtual {v3, v5, v4}, Ljava/lang/String;->substring(II)Ljava/lang/String;

    move-result-object v3

    const-string v4, "_"

    .line 9
    invoke-virtual {v3, v4}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String;

    move-result-object v3

    .line 10
    new-instance v4, Lio/rong/common/rlog/RLogReporter$UploadConfig;

    iget-object v6, p0, Lio/rong/common/rlog/RLogFileProcessor;->mConfig:Lio/rong/common/rlog/RLogConfig;

    invoke-virtual {v6}, Lio/rong/common/rlog/RLogConfig;->getUploadUrl()Ljava/lang/String;

    move-result-object v7

    .line 11
    invoke-virtual {v2}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;

    move-result-object v8

    aget-object v9, v3, v5

    aget-object v10, v3, v1

    iget-object v2, p0, Lio/rong/common/rlog/RLogFileProcessor;->mConfig:Lio/rong/common/rlog/RLogConfig;

    .line 12
    invoke-virtual {v2}, Lio/rong/common/rlog/RLogConfig;->getSdkVersion()Ljava/lang/String;

    move-result-object v11

    iget-object v2, p0, Lio/rong/common/rlog/RLogFileProcessor;->mConfig:Lio/rong/common/rlog/RLogConfig;

    .line 13
    invoke-virtual {v2}, Lio/rong/common/rlog/RLogConfig;->getAppKey()Ljava/lang/String;

    move-result-object v12

    iget-object v2, p0, Lio/rong/common/rlog/RLogFileProcessor;->mConfig:Lio/rong/common/rlog/RLogConfig;

    .line 14
    invoke-virtual {v2}, Lio/rong/common/rlog/RLogConfig;->getUserId()Ljava/lang/String;

    move-result-object v13

    move-object v6, v4

    invoke-direct/range {v6 .. v13}, Lio/rong/common/rlog/RLogReporter$UploadConfig;-><init>(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    .line 15
    iget-object v2, p0, Lio/rong/common/rlog/RLogFileProcessor;->mReporter:Lio/rong/common/rlog/RLogReporter;

    new-instance v3, Lio/rong/common/rlog/RLogFileProcessor$3;

    invoke-direct {v3, p0}, Lio/rong/common/rlog/RLogFileProcessor$3;-><init>(Lio/rong/common/rlog/RLogFileProcessor;)V

    invoke-virtual {v2, v4, v3}, Lio/rong/common/rlog/RLogReporter;->report(Lio/rong/common/rlog/RLogReporter$UploadConfig;Lio/rong/common/rlog/RLogReporter$IUploadListener;)V

    goto :goto_1f

    :cond_71
    return-void
.end method


# virtual methods
.method public upload()V
    .registers 3

    .line 1
    new-instance v0, Lio/rong/common/rlog/RLogFileProcessor$4;

    invoke-direct {v0, p0}, Lio/rong/common/rlog/RLogFileProcessor$4;-><init>(Lio/rong/common/rlog/RLogFileProcessor;)V

    .line 2
    iget-object v1, p0, Lio/rong/common/rlog/RLogFileProcessor;->mLogFileWriter:Lio/rong/common/rlog/LogFileWriter;

    invoke-virtual {v1, v0}, Lio/rong/common/rlog/LogFileWriter;->stopWrite(Lio/rong/common/rlog/LogFileWriter$IWriterOnStopListener;)V

    return-void
.end method

.method public write(Ljava/lang/String;)V
    .registers 3

    .line 1
    iget-object v0, p0, Lio/rong/common/rlog/RLogFileProcessor;->mLogFileWriter:Lio/rong/common/rlog/LogFileWriter;

    invoke-virtual {v0, p1}, Lio/rong/common/rlog/LogFileWriter;->write(Ljava/lang/String;)V

    return-void
.end method