KSupportBatchManager.smali

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


# annotations
.annotation system Ldalvik/annotation/MemberClasses;
    value = {
        Lcom/cmcm/support/KSupportBatchManager$CacheFile;
    }
.end annotation


# static fields
.field private static CacheFileComparator:Ljava/util/Comparator;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/Comparator",
            "<",
            "Lcom/cmcm/support/KSupportBatchManager$CacheFile;",
            ">;"
        }
    .end annotation
.end field

.field private static MIN_BATCH_REPORT_FILE_COUNT:I


# instance fields
.field private final mBatchRep:Lcom/cmcm/support/KSupportBatchReporter;

.field private mClient:Lcom/cmcm/support/KSupportClient;

.field private mConfig:Lcom/cmcm/support/KSupportConfig;

.field private mContext:Landroid/content/Context;

.field private mControl:Lcom/cmcm/support/KSupportControl;

.field private mExpireDay:I

.field private volatile mIsReporting:Z

.field private mKfmtPath:Ljava/lang/String;

.field private mProduceId:I

.field private mReportTask:Ljava/util/TimerTask;

.field private mReportTimer:Ljava/util/Timer;

.field private mSupportContext:Lcom/cmcm/support/ISupportContext;

.field private final mSyncObj:Ljava/lang/Object;

.field private final mTimerSync:Ljava/lang/Object;


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

    .prologue
    .line 32
    const/16 v0, 0x1e

    sput v0, Lcom/cmcm/support/KSupportBatchManager;->MIN_BATCH_REPORT_FILE_COUNT:I

    .line 283
    new-instance v0, Lcom/cmcm/support/KSupportBatchManager$3;

    invoke-direct {v0}, Lcom/cmcm/support/KSupportBatchManager$3;-><init>()V

    sput-object v0, Lcom/cmcm/support/KSupportBatchManager;->CacheFileComparator:Ljava/util/Comparator;

    return-void
.end method

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

    .prologue
    const/4 v2, 0x0

    const/4 v1, 0x0

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

    .line 16
    iput-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    .line 17
    iput-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mControl:Lcom/cmcm/support/KSupportControl;

    .line 19
    iput-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mConfig:Lcom/cmcm/support/KSupportConfig;

    .line 20
    const/4 v0, -0x1

    iput v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mProduceId:I

    .line 21
    iput v2, p0, Lcom/cmcm/support/KSupportBatchManager;->mExpireDay:I

    .line 22
    iput-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mKfmtPath:Ljava/lang/String;

    .line 23
    iput-boolean v2, p0, Lcom/cmcm/support/KSupportBatchManager;->mIsReporting:Z

    .line 24
    new-instance v0, Ljava/lang/Object;

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

    iput-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mSyncObj:Ljava/lang/Object;

    .line 25
    iput-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mSupportContext:Lcom/cmcm/support/ISupportContext;

    .line 26
    iput-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mContext:Landroid/content/Context;

    .line 28
    iput-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mReportTimer:Ljava/util/Timer;

    .line 29
    iput-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mReportTask:Ljava/util/TimerTask;

    .line 30
    new-instance v0, Ljava/lang/Object;

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

    iput-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mTimerSync:Ljava/lang/Object;

    .line 35
    new-instance v0, Lcom/cmcm/support/KSupportBatchReporter;

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

    iput-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mBatchRep:Lcom/cmcm/support/KSupportBatchReporter;

    .line 36
    return-void
.end method

.method static synthetic access$000(Lcom/cmcm/support/KSupportBatchManager;)V
    .registers 1

    .prologue
    .line 15
    invoke-direct {p0}, Lcom/cmcm/support/KSupportBatchManager;->reportBatchRun()V

    return-void
.end method

.method private clearTimer()V
    .registers 4

    .prologue
    .line 161
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    invoke-virtual {v0}, Lcom/cmcm/support/KSupportClient;->getKLog()Lcom/cmcm/support/base/KLog;

    move-result-object v0

    if-eqz v0, :cond_15

    .line 162
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    invoke-virtual {v0}, Lcom/cmcm/support/KSupportClient;->getKLog()Lcom/cmcm/support/base/KLog;

    move-result-object v0

    const-string v1, "KSupport"

    const-string v2, "clear batch timer"

    invoke-virtual {v0, v1, v2}, Lcom/cmcm/support/base/KLog;->D(Ljava/lang/String;Ljava/lang/String;)V

    .line 164
    :cond_15
    iget-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mTimerSync:Ljava/lang/Object;

    monitor-enter v1

    .line 165
    :try_start_18
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mReportTask:Ljava/util/TimerTask;

    if-eqz v0, :cond_24

    .line 166
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mReportTask:Ljava/util/TimerTask;

    invoke-virtual {v0}, Ljava/util/TimerTask;->cancel()Z

    .line 167
    const/4 v0, 0x0

    iput-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mReportTask:Ljava/util/TimerTask;

    .line 170
    :cond_24
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mReportTimer:Ljava/util/Timer;

    if-eqz v0, :cond_35

    .line 171
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mReportTimer:Ljava/util/Timer;

    invoke-virtual {v0}, Ljava/util/Timer;->purge()I

    .line 172
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mReportTimer:Ljava/util/Timer;

    invoke-virtual {v0}, Ljava/util/Timer;->cancel()V

    .line 173
    const/4 v0, 0x0

    iput-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mReportTimer:Ljava/util/Timer;

    .line 175
    :cond_35
    monitor-exit v1

    .line 176
    return-void

    .line 175
    :catchall_37
    move-exception v0

    monitor-exit v1
    :try_end_39
    .catchall {:try_start_18 .. :try_end_39} :catchall_37

    throw v0
.end method

.method private getInterval()J
    .registers 7

    .prologue
    .line 135
    .line 136
    const-wide/16 v0, -0x1

    .line 137
    iget-object v2, p0, Lcom/cmcm/support/KSupportBatchManager;->mContext:Landroid/content/Context;

    invoke-static {v2}, Lcom/cmcm/support/KSupportCommon;->getNetworkType(Landroid/content/Context;)I

    move-result v2

    .line 138
    const/4 v3, 0x2

    if-ne v2, v3, :cond_2d

    .line 139
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    invoke-virtual {v0}, Lcom/cmcm/support/KSupportClient;->getEnv()Lcom/cmcm/support/KSupportEnv$Environment;

    move-result-object v0

    invoke-interface {v0}, Lcom/cmcm/support/KSupportEnv$Environment;->getIntervalWifiNet()I

    move-result v0

    int-to-long v0, v0

    .line 148
    :goto_16
    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v2

    .line 149
    iget-object v4, p0, Lcom/cmcm/support/KSupportBatchManager;->mConfig:Lcom/cmcm/support/KSupportConfig;

    invoke-virtual {v4}, Lcom/cmcm/support/KSupportConfig;->getLastBatchReportTime()J

    move-result-wide v4

    .line 150
    sub-long/2addr v2, v4

    sub-long v2, v0, v2

    const-wide/16 v4, 0x1388

    add-long/2addr v2, v4

    .line 153
    const-wide/16 v4, 0x0

    cmp-long v4, v2, v4

    if-gtz v4, :cond_44

    .line 157
    :cond_2c
    :goto_2c
    return-wide v0

    .line 140
    :cond_2d
    const/4 v3, 0x4

    if-eq v2, v3, :cond_38

    const/16 v3, 0x8

    if-eq v2, v3, :cond_38

    const/16 v3, 0x10

    if-ne v2, v3, :cond_2c

    .line 143
    :cond_38
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    invoke-virtual {v0}, Lcom/cmcm/support/KSupportClient;->getEnv()Lcom/cmcm/support/KSupportEnv$Environment;

    move-result-object v0

    invoke-interface {v0}, Lcom/cmcm/support/KSupportEnv$Environment;->getIntervalMobileNet()I

    move-result v0

    int-to-long v0, v0

    goto :goto_16

    :cond_44
    move-wide v0, v2

    .line 157
    goto :goto_2c
.end method

.method private getServerUrl(I)Ljava/lang/String;
    .registers 3

    .prologue
    .line 179
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mControl:Lcom/cmcm/support/KSupportControl;

    if-nez v0, :cond_6

    .line 180
    const/4 v0, 0x0

    .line 182
    :goto_5
    return-object v0

    :cond_6
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mControl:Lcom/cmcm/support/KSupportControl;

    invoke-virtual {v0, p1}, Lcom/cmcm/support/KSupportControl;->getServerUrl(I)Ljava/lang/String;

    move-result-object v0

    goto :goto_5
.end method

.method private needBatchReport()Z
    .registers 7

    .prologue
    const/4 v4, 0x1

    const/4 v5, 0x0

    .line 93
    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v2

    .line 95
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mConfig:Lcom/cmcm/support/KSupportConfig;

    if-eqz v0, :cond_42

    .line 96
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mConfig:Lcom/cmcm/support/KSupportConfig;

    invoke-virtual {v0}, Lcom/cmcm/support/KSupportConfig;->getLastBatchReportTime()J

    move-result-wide v0

    .line 98
    :goto_10
    sub-long v0, v2, v0

    iget-object v2, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    invoke-virtual {v2}, Lcom/cmcm/support/KSupportClient;->getEnv()Lcom/cmcm/support/KSupportEnv$Environment;

    move-result-object v2

    invoke-interface {v2}, Lcom/cmcm/support/KSupportEnv$Environment;->getIntervalWifiNet()I

    move-result v2

    int-to-long v2, v2

    cmp-long v0, v0, v2

    if-ltz v0, :cond_23

    move v0, v4

    .line 107
    :goto_22
    return v0

    :cond_23
    move v0, v5

    .line 101
    :goto_24
    const/4 v1, 0x2

    if-ge v0, v1, :cond_40

    .line 102
    iget-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mContext:Landroid/content/Context;

    iget-object v2, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    .line 103
    invoke-virtual {v2}, Lcom/cmcm/support/KSupportClient;->getEnv()Lcom/cmcm/support/KSupportEnv$Environment;

    move-result-object v2

    invoke-interface {v2}, Lcom/cmcm/support/KSupportEnv$Environment;->getCacheDirectoryName()Ljava/lang/String;

    move-result-object v2

    .line 102
    invoke-static {v1, v0, v2}, Lcom/cmcm/support/KSupportUtil;->getIchCount_CACHE_DIR(Landroid/content/Context;ILjava/lang/String;)I

    move-result v1

    sget v2, Lcom/cmcm/support/KSupportBatchManager;->MIN_BATCH_REPORT_FILE_COUNT:I

    if-lt v1, v2, :cond_3d

    move v0, v4

    .line 104
    goto :goto_22

    .line 101
    :cond_3d
    add-int/lit8 v0, v0, 0x1

    goto :goto_24

    :cond_40
    move v0, v5

    .line 107
    goto :goto_22

    :cond_42
    move-wide v0, v2

    goto :goto_10
.end method

.method private onStartReport()V
    .registers 5

    .prologue
    .line 76
    invoke-direct {p0}, Lcom/cmcm/support/KSupportBatchManager;->needBatchReport()Z

    move-result v0

    if-eqz v0, :cond_21

    .line 77
    iget-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mSyncObj:Ljava/lang/Object;

    monitor-enter v1

    .line 78
    :try_start_9
    iget-boolean v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mIsReporting:Z

    if-nez v0, :cond_1d

    .line 79
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mConfig:Lcom/cmcm/support/KSupportConfig;

    if-eqz v0, :cond_1a

    .line 80
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mConfig:Lcom/cmcm/support/KSupportConfig;

    .line 81
    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v2

    .line 80
    invoke-virtual {v0, v2, v3}, Lcom/cmcm/support/KSupportConfig;->setLastBatchReportTime(J)Z

    .line 83
    :cond_1a
    invoke-direct {p0}, Lcom/cmcm/support/KSupportBatchManager;->reportBatchData()V

    .line 85
    :cond_1d
    monitor-exit v1
    :try_end_1e
    .catchall {:try_start_9 .. :try_end_1e} :catchall_25

    .line 86
    invoke-direct {p0}, Lcom/cmcm/support/KSupportBatchManager;->clearTimer()V

    .line 89
    :cond_21
    invoke-direct {p0}, Lcom/cmcm/support/KSupportBatchManager;->setNextReportTimer()V

    .line 90
    return-void

    .line 85
    :catchall_25
    move-exception v0

    :try_start_26
    monitor-exit v1
    :try_end_27
    .catchall {:try_start_26 .. :try_end_27} :catchall_25

    throw v0
.end method

.method private removeOvermuchCache(I)V
    .registers 10

    .prologue
    .line 291
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mContext:Landroid/content/Context;

    iget-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    .line 292
    invoke-virtual {v1}, Lcom/cmcm/support/KSupportClient;->getEnv()Lcom/cmcm/support/KSupportEnv$Environment;

    move-result-object v1

    .line 293
    invoke-interface {v1}, Lcom/cmcm/support/KSupportEnv$Environment;->getCacheDirectoryName()Ljava/lang/String;

    move-result-object v1

    .line 292
    invoke-static {v0, p1, v1}, Lcom/cmcm/support/KSupportUtil;->getExisted_CACHE_DIR(Landroid/content/Context;ILjava/lang/String;)Ljava/io/File;

    move-result-object v0

    .line 294
    if-nez v0, :cond_13

    .line 322
    :cond_12
    return-void

    .line 298
    :cond_13
    invoke-virtual {v0}, Ljava/io/File;->listFiles()[Ljava/io/File;

    move-result-object v1

    .line 299
    if-eqz v1, :cond_12

    array-length v0, v1

    iget-object v2, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    invoke-virtual {v2}, Lcom/cmcm/support/KSupportClient;->getEnv()Lcom/cmcm/support/KSupportEnv$Environment;

    move-result-object v2

    invoke-interface {v2}, Lcom/cmcm/support/KSupportEnv$Environment;->getMaxCacheCount()I

    move-result v2

    if-lt v0, v2, :cond_12

    .line 304
    new-instance v2, Ljava/util/PriorityQueue;

    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    invoke-virtual {v0}, Lcom/cmcm/support/KSupportClient;->getEnv()Lcom/cmcm/support/KSupportEnv$Environment;

    move-result-object v0

    .line 305
    invoke-interface {v0}, Lcom/cmcm/support/KSupportEnv$Environment;->getMaxCacheCount()I

    move-result v0

    sget-object v3, Lcom/cmcm/support/KSupportBatchManager;->CacheFileComparator:Ljava/util/Comparator;

    invoke-direct {v2, v0, v3}, Ljava/util/PriorityQueue;-><init>(ILjava/util/Comparator;)V

    .line 307
    array-length v3, v1

    const/4 v0, 0x0

    :goto_39
    if-ge v0, v3, :cond_57

    aget-object v4, v1, v0

    .line 308
    invoke-virtual {v4}, Ljava/io/File;->isFile()Z

    move-result v5

    if-nez v5, :cond_46

    .line 307
    :goto_43
    add-int/lit8 v0, v0, 0x1

    goto :goto_39

    .line 311
    :cond_46
    new-instance v5, Lcom/cmcm/support/KSupportBatchManager$CacheFile;

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

    move-result-object v6

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

    move-result-wide v6

    invoke-direct {v5, p0, v6, v7, v4}, Lcom/cmcm/support/KSupportBatchManager$CacheFile;-><init>(Lcom/cmcm/support/KSupportBatchManager;JLjava/io/File;)V

    .line 311
    invoke-interface {v2, v5}, Ljava/util/Queue;->add(Ljava/lang/Object;)Z

    goto :goto_43

    .line 314
    :cond_57
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    invoke-virtual {v0}, Lcom/cmcm/support/KSupportClient;->getEnv()Lcom/cmcm/support/KSupportEnv$Environment;

    move-result-object v0

    invoke-interface {v0}, Lcom/cmcm/support/KSupportEnv$Environment;->getDeleteCacheNum()I

    move-result v0

    move v1, v0

    .line 315
    :goto_62
    if-lez v1, :cond_12

    .line 316
    invoke-interface {v2}, Ljava/util/Queue;->poll()Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lcom/cmcm/support/KSupportBatchManager$CacheFile;

    .line 317
    if-eqz v0, :cond_12

    .line 319
    invoke-virtual {v0}, Lcom/cmcm/support/KSupportBatchManager$CacheFile;->getFile()Ljava/io/File;

    move-result-object v0

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

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

    move v1, v0

    .line 321
    goto :goto_62
.end method

.method private reportBatchData()V
    .registers 3

    .prologue
    .line 186
    iget-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mSyncObj:Ljava/lang/Object;

    monitor-enter v1

    .line 187
    const/4 v0, 0x1

    :try_start_4
    iput-boolean v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mIsReporting:Z

    .line 188
    monitor-exit v1
    :try_end_7
    .catchall {:try_start_4 .. :try_end_7} :catchall_10

    .line 190
    new-instance v0, Lcom/cmcm/support/KSupportBatchManager$2;

    invoke-direct {v0, p0}, Lcom/cmcm/support/KSupportBatchManager$2;-><init>(Lcom/cmcm/support/KSupportBatchManager;)V

    invoke-static {v0}, Lcom/cmcm/support/util/KinfocThreadManager;->execute(Ljava/lang/Runnable;)V

    .line 196
    return-void

    .line 188
    :catchall_10
    move-exception v0

    :try_start_11
    monitor-exit v1
    :try_end_12
    .catchall {:try_start_11 .. :try_end_12} :catchall_10

    throw v0
.end method

.method private reportBatchRun()V
    .registers 14

    .prologue
    const/4 v11, -0x1

    const/4 v0, 0x0

    .line 199
    :try_start_2
    iget-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mSupportContext:Lcom/cmcm/support/ISupportContext;

    invoke-interface {v1}, Lcom/cmcm/support/ISupportContext;->getPublicData()Ljava/lang/String;

    move-result-object v4

    .line 200
    iget-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    invoke-virtual {v1}, Lcom/cmcm/support/KSupportClient;->getKLog()Lcom/cmcm/support/base/KLog;

    move-result-object v1

    if-eqz v1, :cond_1d

    .line 201
    iget-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    invoke-virtual {v1}, Lcom/cmcm/support/KSupportClient;->getKLog()Lcom/cmcm/support/base/KLog;

    move-result-object v1

    const-string v2, "KSupport"

    const-string v3, " BATCH REPORTER STARTED ........"

    invoke-virtual {v1, v2, v3}, Lcom/cmcm/support/base/KLog;->D(Ljava/lang/String;Ljava/lang/String;)V

    :cond_1d
    move v12, v0

    .line 203
    :goto_1e
    const/4 v0, 0x2

    if-ge v12, v0, :cond_b7

    .line 204
    invoke-direct {p0, v12}, Lcom/cmcm/support/KSupportBatchManager;->removeOvermuchCache(I)V

    .line 206
    if-eqz v12, :cond_32

    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mContext:Landroid/content/Context;

    .line 207
    invoke-static {v0}, Lcom/cmcm/support/KSupportCommon;->isWiFiActive(Landroid/content/Context;)Z

    move-result v0

    if-nez v0, :cond_32

    .line 203
    :cond_2e
    add-int/lit8 v0, v12, 0x1

    move v12, v0

    goto :goto_1e

    .line 210
    :cond_32
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mContext:Landroid/content/Context;

    iget-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    .line 213
    invoke-virtual {v1}, Lcom/cmcm/support/KSupportClient;->getEnv()Lcom/cmcm/support/KSupportEnv$Environment;

    move-result-object v1

    .line 214
    invoke-interface {v1}, Lcom/cmcm/support/KSupportEnv$Environment;->getCacheDirectoryName()Ljava/lang/String;

    move-result-object v1

    .line 211
    invoke-static {v0, v12, v1}, Lcom/cmcm/support/KSupportUtil;->getExisted_CACHE_DIR(Landroid/content/Context;ILjava/lang/String;)Ljava/io/File;

    move-result-object v0

    .line 215
    if-eqz v0, :cond_2e

    .line 219
    invoke-virtual {v0}, Ljava/io/File;->listFiles()[Ljava/io/File;

    move-result-object v2

    .line 220
    if-eqz v2, :cond_2e

    array-length v1, v2

    if-eqz v1, :cond_2e

    .line 224
    iget-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    invoke-virtual {v1}, Lcom/cmcm/support/KSupportClient;->getKLog()Lcom/cmcm/support/base/KLog;

    move-result-object v1

    if-eqz v1, :cond_77

    .line 225
    iget-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    invoke-virtual {v1}, Lcom/cmcm/support/KSupportClient;->getKLog()Lcom/cmcm/support/base/KLog;

    move-result-object v1

    const-string v3, "KSupport"

    new-instance v5, Ljava/lang/StringBuilder;

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

    const-string v6, " -> ICH DIR : "

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

    move-result-object v5

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

    move-result-object v0

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

    move-result-object v0

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

    move-result-object v0

    invoke-virtual {v1, v3, v0}, Lcom/cmcm/support/base/KLog;->D(Ljava/lang/String;Ljava/lang/String;)V

    .line 227
    :cond_77
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    if-eqz v0, :cond_f7

    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    invoke-virtual {v0}, Lcom/cmcm/support/KSupportClient;->isInited()Z

    move-result v0

    if-eqz v0, :cond_f7

    .line 228
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    invoke-virtual {v0}, Lcom/cmcm/support/KSupportClient;->isDebugMode()Ljava/lang/Boolean;

    move-result-object v0

    invoke-virtual {v0}, Ljava/lang/Boolean;->booleanValue()Z

    move-result v0

    if-eqz v0, :cond_bf

    .line 229
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mBatchRep:Lcom/cmcm/support/KSupportBatchReporter;

    const-string v1, "http://118.89.55.235/nep/v1/"

    iget-object v3, p0, Lcom/cmcm/support/KSupportBatchManager;->mControl:Lcom/cmcm/support/KSupportControl;

    .line 232
    invoke-virtual {v3}, Lcom/cmcm/support/KSupportControl;->getPublicTable()Ljava/lang/String;

    move-result-object v3

    iget v5, p0, Lcom/cmcm/support/KSupportBatchManager;->mProduceId:I

    iget-object v6, p0, Lcom/cmcm/support/KSupportBatchManager;->mKfmtPath:Ljava/lang/String;

    iget v7, p0, Lcom/cmcm/support/KSupportBatchManager;->mExpireDay:I

    iget-object v8, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    .line 237
    invoke-virtual {v8}, Lcom/cmcm/support/KSupportClient;->getKLog()Lcom/cmcm/support/base/KLog;

    move-result-object v8

    iget-object v9, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    .line 238
    invoke-virtual {v9}, Lcom/cmcm/support/KSupportClient;->getEncryptKey()Lcom/cmcm/support/KSupportEncryptKey;

    move-result-object v9

    iget-object v10, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    .line 239
    invoke-virtual {v10}, Lcom/cmcm/support/KSupportClient;->getAutoPublicData()Ljava/lang/String;

    move-result-object v10

    .line 230
    invoke-virtual/range {v0 .. v10}, Lcom/cmcm/support/KSupportBatchReporter;->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
    :try_end_b4
    .catchall {:try_start_2 .. :try_end_b4} :catchall_eb

    move-result v0

    .line 254
    :goto_b5
    if-ne v0, v11, :cond_2e

    .line 259
    :cond_b7
    iget-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mSyncObj:Ljava/lang/Object;

    monitor-enter v1

    .line 260
    const/4 v0, 0x0

    :try_start_bb
    iput-boolean v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mIsReporting:Z

    .line 261
    monitor-exit v1
    :try_end_be
    .catchall {:try_start_bb .. :try_end_be} :catchall_e8

    .line 263
    return-void

    .line 241
    :cond_bf
    :try_start_bf
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mBatchRep:Lcom/cmcm/support/KSupportBatchReporter;

    .line 242
    invoke-direct {p0, v12}, Lcom/cmcm/support/KSupportBatchManager;->getServerUrl(I)Ljava/lang/String;

    move-result-object v1

    iget-object v3, p0, Lcom/cmcm/support/KSupportBatchManager;->mControl:Lcom/cmcm/support/KSupportControl;

    .line 244
    invoke-virtual {v3}, Lcom/cmcm/support/KSupportControl;->getPublicTable()Ljava/lang/String;

    move-result-object v3

    iget v5, p0, Lcom/cmcm/support/KSupportBatchManager;->mProduceId:I

    iget-object v6, p0, Lcom/cmcm/support/KSupportBatchManager;->mKfmtPath:Ljava/lang/String;

    iget v7, p0, Lcom/cmcm/support/KSupportBatchManager;->mExpireDay:I

    iget-object v8, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    .line 249
    invoke-virtual {v8}, Lcom/cmcm/support/KSupportClient;->getKLog()Lcom/cmcm/support/base/KLog;

    move-result-object v8

    iget-object v9, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    .line 250
    invoke-virtual {v9}, Lcom/cmcm/support/KSupportClient;->getEncryptKey()Lcom/cmcm/support/KSupportEncryptKey;

    move-result-object v9

    iget-object v10, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    .line 251
    invoke-virtual {v10}, Lcom/cmcm/support/KSupportClient;->getAutoPublicData()Ljava/lang/String;

    move-result-object v10

    .line 242
    invoke-virtual/range {v0 .. v10}, Lcom/cmcm/support/KSupportBatchReporter;->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
    :try_end_e6
    .catchall {:try_start_bf .. :try_end_e6} :catchall_eb

    move-result v0

    goto :goto_b5

    .line 261
    :catchall_e8
    move-exception v0

    :try_start_e9
    monitor-exit v1
    :try_end_ea
    .catchall {:try_start_e9 .. :try_end_ea} :catchall_e8

    throw v0

    .line 259
    :catchall_eb
    move-exception v0

    iget-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mSyncObj:Ljava/lang/Object;

    monitor-enter v1

    .line 260
    const/4 v2, 0x0

    :try_start_f0
    iput-boolean v2, p0, Lcom/cmcm/support/KSupportBatchManager;->mIsReporting:Z

    .line 261
    monitor-exit v1
    :try_end_f3
    .catchall {:try_start_f0 .. :try_end_f3} :catchall_f4

    throw v0

    :catchall_f4
    move-exception v0

    :try_start_f5
    monitor-exit v1
    :try_end_f6
    .catchall {:try_start_f5 .. :try_end_f6} :catchall_f4

    throw v0

    :cond_f7
    move v0, v11

    goto :goto_b5
.end method

.method private setNextReportTimer()V
    .registers 7

    .prologue
    .line 111
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mReportTimer:Ljava/util/Timer;

    if-eqz v0, :cond_5

    .line 132
    :cond_4
    :goto_4
    return-void

    .line 115
    :cond_5
    invoke-direct {p0}, Lcom/cmcm/support/KSupportBatchManager;->getInterval()J

    move-result-wide v0

    .line 116
    const-wide/16 v2, 0x0

    cmp-long v2, v0, v2

    if-ltz v2, :cond_4

    .line 120
    iget-object v2, p0, Lcom/cmcm/support/KSupportBatchManager;->mTimerSync:Ljava/lang/Object;

    monitor-enter v2

    .line 122
    :try_start_12
    new-instance v3, Ljava/util/Timer;

    new-instance v4, Ljava/lang/StringBuilder;

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

    const-string v5, "T-"

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

    move-result-object v4

    invoke-virtual {p0}, Ljava/lang/Object;->getClass()Ljava/lang/Class;

    move-result-object v5

    invoke-virtual {v5}, Ljava/lang/Class;->getSimpleName()Ljava/lang/String;

    move-result-object v5

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

    move-result-object v4

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

    move-result-object v4

    invoke-direct {v3, v4}, Ljava/util/Timer;-><init>(Ljava/lang/String;)V

    iput-object v3, p0, Lcom/cmcm/support/KSupportBatchManager;->mReportTimer:Ljava/util/Timer;

    .line 123
    new-instance v3, Lcom/cmcm/support/KSupportBatchManager$1;

    invoke-direct {v3, p0}, Lcom/cmcm/support/KSupportBatchManager$1;-><init>(Lcom/cmcm/support/KSupportBatchManager;)V

    iput-object v3, p0, Lcom/cmcm/support/KSupportBatchManager;->mReportTask:Ljava/util/TimerTask;

    .line 130
    iget-object v3, p0, Lcom/cmcm/support/KSupportBatchManager;->mReportTimer:Ljava/util/Timer;

    iget-object v4, p0, Lcom/cmcm/support/KSupportBatchManager;->mReportTask:Ljava/util/TimerTask;

    invoke-virtual {v3, v4, v0, v1}, Ljava/util/Timer;->schedule(Ljava/util/TimerTask;J)V

    .line 131
    monitor-exit v2

    goto :goto_4

    :catchall_44
    move-exception v0

    monitor-exit v2
    :try_end_46
    .catchall {:try_start_12 .. :try_end_46} :catchall_44

    throw v0
.end method


# virtual methods
.method init(Lcom/cmcm/support/KSupportClient;Lcom/cmcm/support/ISupportContext;Lcom/cmcm/support/KSupportControl;Lcom/cmcm/support/KSupportConfig;)Z
    .registers 7

    .prologue
    .line 42
    iput-object p2, p0, Lcom/cmcm/support/KSupportBatchManager;->mSupportContext:Lcom/cmcm/support/ISupportContext;

    .line 43
    invoke-interface {p2}, Lcom/cmcm/support/ISupportContext;->getApplicationContext()Landroid/content/Context;

    move-result-object v0

    iput-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mContext:Landroid/content/Context;

    .line 44
    iput-object p3, p0, Lcom/cmcm/support/KSupportBatchManager;->mControl:Lcom/cmcm/support/KSupportControl;

    .line 45
    iput-object p1, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    .line 46
    invoke-virtual {p3}, Lcom/cmcm/support/KSupportControl;->getProductID()I

    move-result v0

    iput v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mProduceId:I

    .line 47
    invoke-virtual {p3}, Lcom/cmcm/support/KSupportControl;->getValidityDays()I

    move-result v0

    iput v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mExpireDay:I

    .line 48
    new-instance v0, Ljava/lang/StringBuilder;

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

    iget-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mContext:Landroid/content/Context;

    invoke-static {v1}, Lcom/cmcm/support/KSupportUtil;->getFilesDir(Landroid/content/Context;)Ljava/io/File;

    move-result-object v1

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

    move-result-object v1

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

    move-result-object v0

    const-string v1, "/"

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

    move-result-object v0

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

    move-result-object v0

    iput-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mKfmtPath:Ljava/lang/String;

    .line 49
    new-instance v0, Ljava/lang/StringBuilder;

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

    iget-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mKfmtPath:Ljava/lang/String;

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

    move-result-object v0

    iget-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    invoke-virtual {v1}, Lcom/cmcm/support/KSupportClient;->getEnv()Lcom/cmcm/support/KSupportEnv$Environment;

    move-result-object v1

    invoke-interface {v1}, Lcom/cmcm/support/KSupportEnv$Environment;->getFmtDstFilePath()Ljava/lang/String;

    move-result-object v1

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

    move-result-object v0

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

    move-result-object v0

    iput-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mKfmtPath:Ljava/lang/String;

    .line 50
    iput-object p4, p0, Lcom/cmcm/support/KSupportBatchManager;->mConfig:Lcom/cmcm/support/KSupportConfig;

    .line 51
    const/4 v0, 0x1

    return v0
.end method

.method requestReport()V
    .registers 3

    .prologue
    .line 56
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    if-eqz v0, :cond_c

    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mClient:Lcom/cmcm/support/KSupportClient;

    invoke-virtual {v0}, Lcom/cmcm/support/KSupportClient;->isInited()Z

    move-result v0

    if-nez v0, :cond_d

    .line 73
    :cond_c
    :goto_c
    return-void

    .line 61
    :cond_d
    iget-object v1, p0, Lcom/cmcm/support/KSupportBatchManager;->mSyncObj:Ljava/lang/Object;

    monitor-enter v1

    .line 62
    :try_start_10
    iget-boolean v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mIsReporting:Z

    if-eqz v0, :cond_19

    .line 63
    monitor-exit v1

    goto :goto_c

    .line 65
    :catchall_16
    move-exception v0

    monitor-exit v1
    :try_end_18
    .catchall {:try_start_10 .. :try_end_18} :catchall_16

    throw v0

    :cond_19
    :try_start_19
    monitor-exit v1
    :try_end_1a
    .catchall {:try_start_19 .. :try_end_1a} :catchall_16

    .line 68
    iget-object v0, p0, Lcom/cmcm/support/KSupportBatchManager;->mContext:Landroid/content/Context;

    invoke-static {v0}, Lcom/cmcm/support/KSupportCommon;->isNetworkActive(Landroid/content/Context;)Z

    move-result v0

    if-eqz v0, :cond_c

    .line 72
    invoke-direct {p0}, Lcom/cmcm/support/KSupportBatchManager;->onStartReport()V

    goto :goto_c
.end method