KSupportBatchReporter.smali

.class Lcom/cmcm/support/KSupportBatchReporter;
.super Ljava/lang/Object;
.source "KSupportBatchReporter.java"


# static fields
.field private static final BATCHTABLENAME:Ljava/lang/String; = "batchdata_table_"

.field static ICH_FILE_PATTERN:Ljava/util/regex/Pattern; = null

.field private static final MAX_BATCH_BUFFER_LENGTH:I = 0x2328

.field private static final REPORT_RESULT_FAIL_DATA:I = -0x2

.field static final REPORT_RESULT_FAIL_NETWORK:I = -0x1


# instance fields
.field private final isDebugMode:Z

.field private final mPoster:Lcom/cmcm/support/http/KHttpPoster;


# direct methods
.method static constructor <clinit>()V
    .registers 1

    .prologue
    .line 419
    const-string v0, ".*_(\\d+).ich"

    invoke-static {v0}, Ljava/util/regex/Pattern;->compile(Ljava/lang/String;)Ljava/util/regex/Pattern;

    move-result-object v0

    sput-object v0, Lcom/cmcm/support/KSupportBatchReporter;->ICH_FILE_PATTERN:Ljava/util/regex/Pattern;

    return-void
.end method

.method constructor <init>(Z)V
    .registers 3

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

    .line 29
    new-instance v0, Lcom/cmcm/support/http/KHttpPoster;

    invoke-direct {v0, p1}, Lcom/cmcm/support/http/KHttpPoster;-><init>(Z)V

    iput-object v0, p0, Lcom/cmcm/support/KSupportBatchReporter;->mPoster:Lcom/cmcm/support/http/KHttpPoster;

    .line 30
    iput-boolean p1, p0, Lcom/cmcm/support/KSupportBatchReporter;->isDebugMode:Z

    .line 31
    return-void
.end method

.method private static IsNormalTable(Ljava/lang/String;)Z
    .registers 2

    .prologue
    .line 436
    const-string v0, "kav_event"

    invoke-virtual {p0, v0}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z

    move-result v0

    if-nez v0, :cond_a

    const/4 v0, 0x1

    :goto_9
    return v0

    :cond_a
    const/4 v0, 0x0

    goto :goto_9
.end method

.method private createBatchReportBin([B[BII)[B
    .registers 7

    .prologue
    .line 388
    invoke-static {p1, p2}, Lcom/cmcm/support/KSupportBatchReporter;->join([B[B)[B

    move-result-object v0

    .line 389
    array-length v1, v0

    invoke-static {v0, v1, p3, p4}, Lcom/cmcm/support/jni/i;->d([BIII)[B

    move-result-object v0

    return-object v0
.end method

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

    .prologue
    .line 352
    iget-boolean v0, p0, Lcom/cmcm/support/KSupportBatchReporter;->isDebugMode:Z

    if-eqz v0, :cond_9

    .line 353
    const-string v0, "KSupport"

    invoke-static {v0, p1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 355
    :cond_9
    return-void
.end method

.method static getCreateTime(Ljava/lang/String;)J
    .registers 5

    .prologue
    const-wide/16 v0, 0x0

    .line 422
    .line 424
    :try_start_2
    sget-object v2, Lcom/cmcm/support/KSupportBatchReporter;->ICH_FILE_PATTERN:Ljava/util/regex/Pattern;

    invoke-virtual {v2, p0}, Ljava/util/regex/Pattern;->matcher(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher;

    move-result-object v2

    .line 425
    invoke-virtual {v2}, Ljava/util/regex/Matcher;->matches()Z

    move-result v3

    if-eqz v3, :cond_17

    .line 426
    const/4 v3, 0x1

    invoke-virtual {v2, v3}, Ljava/util/regex/Matcher;->group(I)Ljava/lang/String;

    move-result-object v2

    invoke-static {v2}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
    :try_end_16
    .catch Ljava/lang/Exception; {:try_start_2 .. :try_end_16} :catch_18

    move-result-wide v0

    .line 432
    :cond_17
    :goto_17
    return-wide v0

    .line 428
    :catch_18
    move-exception v2

    .line 429
    invoke-virtual {v2}, Ljava/lang/Exception;->printStackTrace()V

    goto :goto_17
.end method

.method public static isEmpty([B)Z
    .registers 2

    .prologue
    .line 78
    if-eqz p0, :cond_5

    array-length v0, p0

    if-nez v0, :cond_7

    :cond_5
    const/4 v0, 0x1

    :goto_6
    return v0

    :cond_7
    const/4 v0, 0x0

    goto :goto_6
.end method

.method public static isExpired(JI)Z
    .registers 7

    .prologue
    .line 416
    const-wide/16 v0, 0x0

    cmp-long v0, p0, v0

    if-lez v0, :cond_f

    invoke-static {p0, p1}, Lcom/cmcm/support/KSupportUtil;->getDayDiff(J)J

    move-result-wide v0

    int-to-long v2, p2

    cmp-long v0, v0, v2

    if-ltz v0, :cond_11

    :cond_f
    const/4 v0, 0x1

    :goto_10
    return v0

    :cond_11
    const/4 v0, 0x0

    goto :goto_10
.end method

.method public static join([B[B)[B
    .registers 4

    .prologue
    .line 400
    array-length v0, p0

    array-length v1, p1

    add-int/2addr v0, v1

    invoke-static {v0}, Ljava/nio/ByteBuffer;->allocate(I)Ljava/nio/ByteBuffer;

    move-result-object v0

    .line 401
    invoke-virtual {v0, p0}, Ljava/nio/ByteBuffer;->put([B)Ljava/nio/ByteBuffer;

    .line 402
    invoke-virtual {v0, p1}, Ljava/nio/ByteBuffer;->put([B)Ljava/nio/ByteBuffer;

    .line 403
    invoke-virtual {v0}, Ljava/nio/ByteBuffer;->array()[B

    move-result-object v0

    return-object v0
.end method

.method private reportAutoTable(Ljava/lang/String;[Ljava/io/File;IILcom/cmcm/support/base/KLog;Lcom/cmcm/support/KSupportEncryptKey;Ljava/lang/String;)I
    .registers 23

    .prologue
    .line 89
    invoke-static/range {p7 .. p7}, Lcom/cmcm/support/KSupportUtil;->encodeAutoHeader(Ljava/lang/String;)[B

    move-result-object v9

    .line 90
    invoke-static {v9}, Lcom/cmcm/support/KSupportBatchReporter;->isEmpty([B)Z

    move-result v2

    if-eqz v2, :cond_c

    .line 91
    const/4 v2, -0x2

    .line 175
    :goto_b
    return v2

    .line 93
    :cond_c
    iget-boolean v2, p0, Lcom/cmcm/support/KSupportBatchReporter;->isDebugMode:Z

    if-eqz v2, :cond_33

    new-instance v2, Ljava/lang/StringBuilder;

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

    const-string v3, " * ENCODED HEADER : "

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

    move-result-object v2

    array-length v3, v9

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

    move-result-object v2

    const-string v3, " LIMIT="

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

    move-result-object v2

    const/16 v3, 0x2328

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

    move-result-object v2

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

    move-result-object v2

    invoke-direct {p0, v2}, Lcom/cmcm/support/KSupportBatchReporter;->d(Ljava/lang/String;)V

    .line 97
    :cond_33
    new-instance v10, Ljava/util/ArrayList;

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

    .line 98
    new-instance v7, Ljava/util/ArrayList;

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

    .line 99
    array-length v2, v9

    rsub-int v4, v2, 0x2328

    .line 100
    invoke-static {v4}, Ljava/nio/ByteBuffer;->allocate(I)Ljava/nio/ByteBuffer;

    move-result-object v5

    .line 102
    const/4 v3, 0x0

    .line 104
    move-object/from16 v0, p2

    array-length v6, v0

    const/4 v2, 0x0

    move v14, v2

    move v2, v3

    move v3, v4

    move v4, v14

    :goto_4d
    if-ge v4, v6, :cond_5c

    aget-object v8, p2, v4

    .line 106
    if-gtz v3, :cond_6d

    .line 107
    iget-boolean v3, p0, Lcom/cmcm/support/KSupportBatchReporter;->isDebugMode:Z

    if-eqz v3, :cond_5c

    const-string v3, " * REACH LIMITAIONS @BREAK"

    invoke-direct {p0, v3}, Lcom/cmcm/support/KSupportBatchReporter;->d(Ljava/lang/String;)V

    .line 139
    :cond_5c
    invoke-virtual {v10}, Ljava/util/ArrayList;->isEmpty()Z

    move-result v3

    if-eqz v3, :cond_f2

    .line 140
    iget-boolean v2, p0, Lcom/cmcm/support/KSupportBatchReporter;->isDebugMode:Z

    if-eqz v2, :cond_6b

    const-string v2, " * NO ICHS NEED REPORT"

    invoke-direct {p0, v2}, Lcom/cmcm/support/KSupportBatchReporter;->d(Ljava/lang/String;)V

    .line 141
    :cond_6b
    const/4 v2, 0x0

    goto :goto_b

    .line 111
    :cond_6d
    invoke-virtual {v8}, Ljava/io/File;->isFile()Z

    move-result v11

    if-nez v11, :cond_76

    .line 104
    :cond_73
    :goto_73
    add-int/lit8 v4, v4, 0x1

    goto :goto_4d

    .line 116
    :cond_76
    invoke-virtual {v8}, Ljava/io/File;->getName()Ljava/lang/String;

    move-result-object v11

    invoke-static {v11}, Lcom/cmcm/support/KSupportBatchReporter;->getCreateTime(Ljava/lang/String;)J

    move-result-wide v12

    move/from16 v0, p4

    invoke-static {v12, v13, v0}, Lcom/cmcm/support/KSupportBatchReporter;->isExpired(JI)Z

    move-result v11

    if-eqz v11, :cond_a8

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

    .line 118
    iget-boolean v11, p0, Lcom/cmcm/support/KSupportBatchReporter;->isDebugMode:Z

    if-eqz v11, :cond_73

    new-instance v11, Ljava/lang/StringBuilder;

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

    const-string v12, " * IS EXPIRED : "

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

    move-result-object v11

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

    move-result-object v8

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

    move-result-object v8

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

    move-result-object v8

    invoke-direct {p0, v8}, Lcom/cmcm/support/KSupportBatchReporter;->d(Ljava/lang/String;)V

    goto :goto_73

    .line 123
    :cond_a8
    invoke-direct {p0, v8, v3}, Lcom/cmcm/support/KSupportBatchReporter;->safeReadIch(Ljava/io/File;I)[B

    move-result-object v11

    .line 124
    invoke-static {v11}, Lcom/cmcm/support/KSupportBatchReporter;->isEmpty([B)Z

    move-result v12

    if-eqz v12, :cond_d1

    .line 125
    iget-boolean v11, p0, Lcom/cmcm/support/KSupportBatchReporter;->isDebugMode:Z

    if-eqz v11, :cond_73

    new-instance v11, Ljava/lang/StringBuilder;

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

    const-string v12, " * EMPTY DATA : "

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

    move-result-object v11

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

    move-result-object v8

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

    move-result-object v8

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

    move-result-object v8

    invoke-direct {p0, v8}, Lcom/cmcm/support/KSupportBatchReporter;->d(Ljava/lang/String;)V

    goto :goto_73

    .line 129
    :cond_d1
    array-length v12, v11

    sub-int/2addr v3, v12

    .line 130
    array-length v12, v11

    add-int/2addr v2, v12

    .line 131
    invoke-virtual {v5, v11}, Ljava/nio/ByteBuffer;->put([B)Ljava/nio/ByteBuffer;

    .line 132
    invoke-virtual {v10, v8}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z

    .line 133
    array-length v11, v11

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

    move-result-object v11

    invoke-virtual {v7, v11}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z

    .line 134
    if-eqz p5, :cond_73

    .line 135
    const/4 v11, 0x1

    const-string v12, "ich_cache"

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

    move-result-object v8

    move-object/from16 v0, p5

    invoke-virtual {v0, v11, v12, v8}, Lcom/cmcm/support/base/KLog;->Log(ZLjava/lang/String;Ljava/lang/String;)V

    goto :goto_73

    .line 144
    :cond_f2
    invoke-virtual {v5}, Ljava/nio/ByteBuffer;->rewind()Ljava/nio/Buffer;

    .line 145
    new-array v11, v2, [B

    .line 146
    invoke-virtual {v5, v11}, Ljava/nio/ByteBuffer;->get([B)Ljava/nio/ByteBuffer;

    .line 148
    invoke-virtual {v10}, Ljava/util/ArrayList;->size()I

    move-result v2

    add-int/lit8 v5, v2, 0x1

    .line 149
    invoke-virtual {v7}, Ljava/util/ArrayList;->size()I

    move-result v2

    new-array v6, v2, [I

    .line 150
    const/4 v2, 0x0

    move v3, v2

    :goto_108
    array-length v2, v6

    if-ge v3, v2, :cond_11b

    .line 151
    invoke-virtual {v7, v3}, Ljava/util/ArrayList;->get(I)Ljava/lang/Object;

    move-result-object v2

    check-cast v2, Ljava/lang/Integer;

    invoke-virtual {v2}, Ljava/lang/Integer;->intValue()I

    move-result v2

    aput v2, v6, v3

    .line 150
    add-int/lit8 v2, v3, 0x1

    move v3, v2

    goto :goto_108

    .line 154
    :cond_11b
    move/from16 v0, p3

    invoke-direct {p0, v9, v11, v5, v0}, Lcom/cmcm/support/KSupportBatchReporter;->createBatchReportBin([B[BII)[B

    move-result-object v4

    array-length v7, v9

    move-object v2, p0

    move-object/from16 v3, p1

    move-object/from16 v8, p6

    .line 153
    invoke-direct/range {v2 .. v8}, Lcom/cmcm/support/KSupportBatchReporter;->reprotData(Ljava/lang/String;[BI[IILcom/cmcm/support/KSupportEncryptKey;)Z

    move-result v2

    .line 162
    if-eqz v2, :cond_16d

    .line 163
    invoke-static {v10}, Lcom/cmcm/support/KSupportBatchReporter;->rm(Ljava/util/List;)Z

    .line 164
    iget-boolean v2, p0, Lcom/cmcm/support/KSupportBatchReporter;->isDebugMode:Z

    if-eqz v2, :cond_165

    new-instance v2, Ljava/lang/StringBuilder;

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

    const-string v3, " * REPORT SUCCESS : DC+H="

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

    move-result-object v2

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

    move-result-object v2

    const-string v3, " DC="

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

    move-result-object v2

    .line 168
    invoke-virtual {v10}, Ljava/util/ArrayList;->size()I

    move-result v3

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

    move-result-object v2

    const-string v3, " SIZE="

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

    move-result-object v2

    array-length v3, v9

    array-length v4, v11

    add-int/2addr v3, v4

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

    move-result-object v2

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

    move-result-object v2

    .line 164
    invoke-direct {p0, v2}, Lcom/cmcm/support/KSupportBatchReporter;->d(Ljava/lang/String;)V

    .line 174
    :cond_165
    const-wide/16 v2, 0x7d0

    invoke-static {v2, v3}, Lcom/cmcm/support/KSupportBatchReporter;->sleepx(J)V

    .line 175
    const/4 v2, 0x0

    goto/16 :goto_b

    .line 172
    :cond_16d
    const/4 v2, -0x1

    goto/16 :goto_b
.end method

.method private reportNormalTable(Ljava/lang/String;[Ljava/io/File;Ljava/lang/String;Ljava/lang/String;ILjava/lang/String;ILcom/cmcm/support/base/KLog;Lcom/cmcm/support/KSupportEncryptKey;)I
    .registers 25

    .prologue
    .line 188
    invoke-static/range {p3 .. p6}, Lcom/cmcm/support/KSupportUtil;->encodeHeader(Ljava/lang/String;Ljava/lang/String;ILjava/lang/String;)[B

    move-result-object v9

    .line 192
    invoke-static {v9}, Lcom/cmcm/support/KSupportBatchReporter;->isEmpty([B)Z

    move-result v2

    if-eqz v2, :cond_c

    .line 193
    const/4 v2, -0x2

    .line 277
    :goto_b
    return v2

    .line 195
    :cond_c
    iget-boolean v2, p0, Lcom/cmcm/support/KSupportBatchReporter;->isDebugMode:Z

    if-eqz v2, :cond_33

    new-instance v2, Ljava/lang/StringBuilder;

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

    const-string v3, " * ENCODED HEADER : "

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

    move-result-object v2

    array-length v3, v9

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

    move-result-object v2

    const-string v3, " LIMIT="

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

    move-result-object v2

    const/16 v3, 0x2328

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

    move-result-object v2

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

    move-result-object v2

    invoke-direct {p0, v2}, Lcom/cmcm/support/KSupportBatchReporter;->d(Ljava/lang/String;)V

    .line 199
    :cond_33
    new-instance v10, Ljava/util/ArrayList;

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

    .line 200
    new-instance v7, Ljava/util/ArrayList;

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

    .line 201
    array-length v2, v9

    rsub-int v4, v2, 0x2328

    .line 202
    invoke-static {v4}, Ljava/nio/ByteBuffer;->allocate(I)Ljava/nio/ByteBuffer;

    move-result-object v5

    .line 204
    const/4 v3, 0x0

    .line 206
    move-object/from16 v0, p2

    array-length v6, v0

    const/4 v2, 0x0

    move v14, v2

    move v2, v3

    move v3, v4

    move v4, v14

    :goto_4d
    if-ge v4, v6, :cond_5c

    aget-object v8, p2, v4

    .line 208
    if-gtz v3, :cond_6d

    .line 209
    iget-boolean v3, p0, Lcom/cmcm/support/KSupportBatchReporter;->isDebugMode:Z

    if-eqz v3, :cond_5c

    const-string v3, " * REACH LIMITAIONS @BREAK"

    invoke-direct {p0, v3}, Lcom/cmcm/support/KSupportBatchReporter;->d(Ljava/lang/String;)V

    .line 241
    :cond_5c
    invoke-virtual {v10}, Ljava/util/ArrayList;->isEmpty()Z

    move-result v3

    if-eqz v3, :cond_f2

    .line 242
    iget-boolean v2, p0, Lcom/cmcm/support/KSupportBatchReporter;->isDebugMode:Z

    if-eqz v2, :cond_6b

    const-string v2, " * NO ICHS NEED REPORT"

    invoke-direct {p0, v2}, Lcom/cmcm/support/KSupportBatchReporter;->d(Ljava/lang/String;)V

    .line 243
    :cond_6b
    const/4 v2, 0x0

    goto :goto_b

    .line 213
    :cond_6d
    invoke-virtual {v8}, Ljava/io/File;->isFile()Z

    move-result v11

    if-nez v11, :cond_76

    .line 206
    :cond_73
    :goto_73
    add-int/lit8 v4, v4, 0x1

    goto :goto_4d

    .line 218
    :cond_76
    invoke-virtual {v8}, Ljava/io/File;->getName()Ljava/lang/String;

    move-result-object v11

    invoke-static {v11}, Lcom/cmcm/support/KSupportBatchReporter;->getCreateTime(Ljava/lang/String;)J

    move-result-wide v12

    move/from16 v0, p7

    invoke-static {v12, v13, v0}, Lcom/cmcm/support/KSupportBatchReporter;->isExpired(JI)Z

    move-result v11

    if-eqz v11, :cond_a8

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

    .line 220
    iget-boolean v11, p0, Lcom/cmcm/support/KSupportBatchReporter;->isDebugMode:Z

    if-eqz v11, :cond_73

    new-instance v11, Ljava/lang/StringBuilder;

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

    const-string v12, " * IS EXPIRED : "

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

    move-result-object v11

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

    move-result-object v8

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

    move-result-object v8

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

    move-result-object v8

    invoke-direct {p0, v8}, Lcom/cmcm/support/KSupportBatchReporter;->d(Ljava/lang/String;)V

    goto :goto_73

    .line 225
    :cond_a8
    invoke-direct {p0, v8, v3}, Lcom/cmcm/support/KSupportBatchReporter;->safeReadIch(Ljava/io/File;I)[B

    move-result-object v11

    .line 226
    invoke-static {v11}, Lcom/cmcm/support/KSupportBatchReporter;->isEmpty([B)Z

    move-result v12

    if-eqz v12, :cond_d1

    .line 227
    iget-boolean v11, p0, Lcom/cmcm/support/KSupportBatchReporter;->isDebugMode:Z

    if-eqz v11, :cond_73

    new-instance v11, Ljava/lang/StringBuilder;

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

    const-string v12, " * EMPTY DATA : "

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

    move-result-object v11

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

    move-result-object v8

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

    move-result-object v8

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

    move-result-object v8

    invoke-direct {p0, v8}, Lcom/cmcm/support/KSupportBatchReporter;->d(Ljava/lang/String;)V

    goto :goto_73

    .line 231
    :cond_d1
    array-length v12, v11

    sub-int/2addr v3, v12

    .line 232
    array-length v12, v11

    add-int/2addr v2, v12

    .line 233
    invoke-virtual {v5, v11}, Ljava/nio/ByteBuffer;->put([B)Ljava/nio/ByteBuffer;

    .line 234
    invoke-virtual {v10, v8}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z

    .line 235
    array-length v11, v11

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

    move-result-object v11

    invoke-virtual {v7, v11}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z

    .line 236
    if-eqz p8, :cond_73

    .line 237
    const/4 v11, 0x1

    const-string v12, "ich_cache"

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

    move-result-object v8

    move-object/from16 v0, p8

    invoke-virtual {v0, v11, v12, v8}, Lcom/cmcm/support/base/KLog;->Log(ZLjava/lang/String;Ljava/lang/String;)V

    goto :goto_73

    .line 246
    :cond_f2
    invoke-virtual {v5}, Ljava/nio/ByteBuffer;->rewind()Ljava/nio/Buffer;

    .line 247
    new-array v11, v2, [B

    .line 248
    invoke-virtual {v5, v11}, Ljava/nio/ByteBuffer;->get([B)Ljava/nio/ByteBuffer;

    .line 250
    invoke-virtual {v10}, Ljava/util/ArrayList;->size()I

    move-result v2

    add-int/lit8 v5, v2, 0x1

    .line 251
    invoke-virtual {v7}, Ljava/util/ArrayList;->size()I

    move-result v2

    new-array v6, v2, [I

    .line 252
    const/4 v2, 0x0

    move v3, v2

    :goto_108
    array-length v2, v6

    if-ge v3, v2, :cond_11b

    .line 253
    invoke-virtual {v7, v3}, Ljava/util/ArrayList;->get(I)Ljava/lang/Object;

    move-result-object v2

    check-cast v2, Ljava/lang/Integer;

    invoke-virtual {v2}, Ljava/lang/Integer;->intValue()I

    move-result v2

    aput v2, v6, v3

    .line 252
    add-int/lit8 v2, v3, 0x1

    move v3, v2

    goto :goto_108

    .line 256
    :cond_11b
    move/from16 v0, p5

    invoke-direct {p0, v9, v11, v5, v0}, Lcom/cmcm/support/KSupportBatchReporter;->createBatchReportBin([B[BII)[B

    move-result-object v4

    array-length v7, v9

    move-object v2, p0

    move-object/from16 v3, p1

    move-object/from16 v8, p9

    .line 255
    invoke-direct/range {v2 .. v8}, Lcom/cmcm/support/KSupportBatchReporter;->reprotData(Ljava/lang/String;[BI[IILcom/cmcm/support/KSupportEncryptKey;)Z

    move-result v2

    .line 264
    if-eqz v2, :cond_16d

    .line 265
    invoke-static {v10}, Lcom/cmcm/support/KSupportBatchReporter;->rm(Ljava/util/List;)Z

    .line 266
    iget-boolean v2, p0, Lcom/cmcm/support/KSupportBatchReporter;->isDebugMode:Z

    if-eqz v2, :cond_165

    new-instance v2, Ljava/lang/StringBuilder;

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

    const-string v3, " * REPORT SUCCESS : DC+H="

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

    move-result-object v2

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

    move-result-object v2

    const-string v3, " DC="

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

    move-result-object v2

    .line 270
    invoke-virtual {v10}, Ljava/util/ArrayList;->size()I

    move-result v3

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

    move-result-object v2

    const-string v3, " SIZE="

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

    move-result-object v2

    array-length v3, v9

    array-length v4, v11

    add-int/2addr v3, v4

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

    move-result-object v2

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

    move-result-object v2

    .line 266
    invoke-direct {p0, v2}, Lcom/cmcm/support/KSupportBatchReporter;->d(Ljava/lang/String;)V

    .line 276
    :cond_165
    const-wide/16 v2, 0x7d0

    invoke-static {v2, v3}, Lcom/cmcm/support/KSupportBatchReporter;->sleepx(J)V

    .line 277
    const/4 v2, 0x0

    goto/16 :goto_b

    .line 274
    :cond_16d
    const/4 v2, -0x1

    goto/16 :goto_b
.end method

.method private reprotData(Ljava/lang/String;[BI[IILcom/cmcm/support/KSupportEncryptKey;)Z
    .registers 11

    .prologue
    const/4 v0, 0x0

    .line 34
    if-eqz p2, :cond_5

    if-nez p4, :cond_6

    .line 47
    :cond_5
    :goto_5
    return v0

    .line 38
    :cond_6
    invoke-virtual {p6}, Lcom/cmcm/support/KSupportEncryptKey;->getKey()Lcom/cmcm/support/KSupportEncryptKey$Key;

    move-result-object v1

    .line 39
    invoke-virtual {v1}, Lcom/cmcm/support/KSupportEncryptKey$Key;->getLastTime()J

    move-result-wide v2

    long-to-int v2, v2

    invoke-virtual {v1}, Lcom/cmcm/support/KSupportEncryptKey$Key;->getKey()[B

    move-result-object v1

    invoke-static {p2, v2, v1, p5, p4}, Lcom/cmcm/support/jni/i;->c2([BI[BI[I)[B

    move-result-object v1

    .line 40
    if-eqz v1, :cond_5

    .line 41
    new-instance v0, Lcom/cmcm/support/http/KHttpData;

    invoke-direct {v0}, Lcom/cmcm/support/http/KHttpData;-><init>()V

    .line 42
    invoke-virtual {v0, p2}, Lcom/cmcm/support/http/KHttpData;->setData([B)V

    .line 43
    invoke-virtual {v0, v1}, Lcom/cmcm/support/http/KHttpData;->setEncryptData([B)V

    .line 44
    new-instance v1, Ljava/lang/StringBuilder;

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

    const-string v2, "batchdata_table_"

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

    move-result-object v1

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

    move-result-object v2

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

    move-result-object v1

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

    move-result-object v1

    invoke-virtual {v0, v1}, Lcom/cmcm/support/http/KHttpData;->setTableName(Ljava/lang/String;)V

    .line 45
    iget-object v1, p0, Lcom/cmcm/support/KSupportBatchReporter;->mPoster:Lcom/cmcm/support/http/KHttpPoster;

    const/4 v2, 0x0

    invoke-virtual {v1, v0, p1, v2}, Lcom/cmcm/support/http/KHttpPoster;->httpPost(Lcom/cmcm/support/http/KHttpData;Ljava/lang/String;Lcom/cmcm/support/http/IHttpSender$OnResultListener;)Z

    move-result v0

    goto :goto_5
.end method

.method public static rm(Ljava/util/List;)Z
    .registers 6
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Ljava/util/List",
            "<",
            "Ljava/io/File;",
            ">;)Z"
        }
    .end annotation

    .prologue
    const/4 v3, 0x1

    const/4 v2, 0x0

    .line 358
    .line 359
    if-eqz p0, :cond_1f

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

    move-result-object v4

    move v1, v2

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

    move-result v0

    if-eqz v0, :cond_21

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

    move-result-object v0

    check-cast v0, Ljava/io/File;

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

    move-result v0

    if-eqz v0, :cond_29

    .line 362
    add-int/lit8 v0, v1, 0x1

    :goto_1d
    move v1, v0

    .line 364
    goto :goto_9

    :cond_1f
    move v2, v3

    .line 368
    :cond_20
    :goto_20
    return v2

    :cond_21
    invoke-interface {p0}, Ljava/util/List;->size()I

    move-result v0

    if-ne v1, v0, :cond_20

    move v2, v3

    goto :goto_20

    :cond_29
    move v0, v1

    goto :goto_1d
.end method

.method private safeReadIch(Ljava/io/File;I)[B
    .registers 7

    .prologue
    const/4 v0, 0x0

    .line 59
    .line 62
    :try_start_1
    invoke-static {p1}, Lcom/cmcm/support/base/KFile;->readBuffer(Ljava/io/File;)[B
    :try_end_4
    .catch Ljava/io/IOException; {:try_start_1 .. :try_end_4} :catch_8

    move-result-object v1

    .line 67
    :goto_5
    if-nez v1, :cond_e

    .line 74
    :cond_7
    :goto_7
    return-object v0

    .line 63
    :catch_8
    move-exception v1

    .line 64
    invoke-virtual {v1}, Ljava/io/IOException;->printStackTrace()V

    move-object v1, v0

    goto :goto_5

    .line 71
    :cond_e
    array-length v2, v1

    invoke-static {p2}, Ljava/lang/Math;->abs(I)I

    move-result v3

    if-gt v2, v3, :cond_7

    move-object v0, v1

    .line 74
    goto :goto_7
.end method

.method private static sleepx(J)V
    .registers 4

    .prologue
    .line 52
    :try_start_0
    invoke-static {p0, p1}, Ljava/lang/Thread;->sleep(J)V
    :try_end_3
    .catch Ljava/lang/InterruptedException; {:try_start_0 .. :try_end_3} :catch_4

    .line 56
    :goto_3
    return-void

    .line 53
    :catch_4
    move-exception v0

    .line 54
    invoke-virtual {v0}, Ljava/lang/InterruptedException;->printStackTrace()V

    goto :goto_3
.end method


# virtual methods
.method public startReport(Ljava/lang/String;[Ljava/io/File;Ljava/lang/String;Ljava/lang/String;ILjava/lang/String;ILcom/cmcm/support/base/KLog;Lcom/cmcm/support/KSupportEncryptKey;Ljava/lang/String;)I
    .registers 24

    .prologue
    .line 290
    if-eqz p1, :cond_12

    if-eqz p2, :cond_12

    array-length v1, p2

    if-eqz v1, :cond_12

    if-eqz p4, :cond_12

    const/4 v1, -0x1

    move/from16 v0, p5

    if-eq v1, v0, :cond_12

    if-eqz p6, :cond_12

    if-nez p10, :cond_14

    .line 297
    :cond_12
    const/4 v1, -0x2

    .line 348
    :cond_13
    :goto_13
    return v1

    .line 300
    :cond_14
    const/4 v3, 0x0

    .line 301
    const/4 v2, 0x0

    .line 302
    const/4 v11, 0x0

    .line 303
    array-length v5, p2

    const/4 v1, 0x0

    move v4, v1

    :goto_1a
    if-ge v4, v5, :cond_33

    aget-object v1, p2, v4

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

    move-result-object v1

    invoke-static {v1}, Lcom/cmcm/support/KSupportBatchReporter;->IsNormalTable(Ljava/lang/String;)Z

    move-result v1

    if-eqz v1, :cond_30

    .line 305
    add-int/lit8 v1, v2, 0x1

    move v2, v1

    move v1, v11

    .line 303
    :goto_2c
    add-int/lit8 v4, v4, 0x1

    move v11, v1

    goto :goto_1a

    .line 307
    :cond_30
    add-int/lit8 v1, v11, 0x1

    goto :goto_2c

    .line 311
    :cond_33
    if-lez v2, :cond_97

    .line 312
    new-array v3, v2, [Ljava/io/File;

    .line 313
    const/4 v2, 0x0

    .line 314
    array-length v4, p2

    const/4 v1, 0x0

    move v12, v1

    move v1, v2

    move v2, v12

    :goto_3d
    if-ge v2, v4, :cond_52

    aget-object v5, p2, v2

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

    move-result-object v6

    invoke-static {v6}, Lcom/cmcm/support/KSupportBatchReporter;->IsNormalTable(Ljava/lang/String;)Z

    move-result v6

    if-eqz v6, :cond_4f

    .line 316
    aput-object v5, v3, v1

    .line 317
    add-int/lit8 v1, v1, 0x1

    .line 314
    :cond_4f
    add-int/lit8 v2, v2, 0x1

    goto :goto_3d

    :cond_52
    move-object v1, p0

    move-object v2, p1

    move-object/from16 v4, p3

    move-object/from16 v5, p4

    move/from16 v6, p5

    move-object/from16 v7, p6

    move/from16 v8, p7

    move-object/from16 v9, p8

    move-object/from16 v10, p9

    .line 320
    invoke-direct/range {v1 .. v10}, Lcom/cmcm/support/KSupportBatchReporter;->reportNormalTable(Ljava/lang/String;[Ljava/io/File;Ljava/lang/String;Ljava/lang/String;ILjava/lang/String;ILcom/cmcm/support/base/KLog;Lcom/cmcm/support/KSupportEncryptKey;)I

    move-result v1

    .line 331
    :goto_66
    if-lez v11, :cond_13

    .line 332
    new-array v3, v11, [Ljava/io/File;

    .line 333
    const/4 v2, 0x0

    .line 334
    array-length v4, p2

    const/4 v1, 0x0

    move v12, v1

    move v1, v2

    move v2, v12

    :goto_70
    if-ge v2, v4, :cond_85

    aget-object v5, p2, v2

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

    move-result-object v6

    invoke-static {v6}, Lcom/cmcm/support/KSupportBatchReporter;->IsNormalTable(Ljava/lang/String;)Z

    move-result v6

    if-nez v6, :cond_82

    .line 336
    aput-object v5, v3, v1

    .line 337
    add-int/lit8 v1, v1, 0x1

    .line 334
    :cond_82
    add-int/lit8 v2, v2, 0x1

    goto :goto_70

    :cond_85
    move-object v1, p0

    move-object v2, p1

    move/from16 v4, p5

    move/from16 v5, p7

    move-object/from16 v6, p8

    move-object/from16 v7, p9

    move-object/from16 v8, p10

    .line 340
    invoke-direct/range {v1 .. v8}, Lcom/cmcm/support/KSupportBatchReporter;->reportAutoTable(Ljava/lang/String;[Ljava/io/File;IILcom/cmcm/support/base/KLog;Lcom/cmcm/support/KSupportEncryptKey;Ljava/lang/String;)I

    move-result v1

    goto/16 :goto_13

    :cond_97
    move v1, v3

    goto :goto_66
.end method