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