TimingUploadTaskScheduleCenter.smali

.class Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;
.super Ljava/lang/Object;
.source "TimingUploadTaskScheduleCenter.java"


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


# instance fields
.field private appKey:Ljava/lang/String;

.field private cache:Lio/rong/rtlog/upload/RtLogCache;

.field private config:Lio/rong/rtlog/upload/RtLogTimingUploadConfig;

.field private context:Landroid/content/Context;

.field private deviceId:Ljava/lang/String;

.field private executor:Lio/rong/rtlog/upload/LimitAliveSingleTaskExecutor;

.field private inBackgroundTime:J

.field private isStartSchedule:Z

.field private isStopInBackground:Z

.field private logCacheDir:Ljava/lang/String;

.field private version:Ljava/lang/String;


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

    return-void
.end method

.method constructor <init>(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Lio/rong/rtlog/upload/RtLogCache;Ljava/lang/String;)V
    .registers 10

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

    .line 2
    new-instance v0, Lio/rong/rtlog/upload/LimitAliveSingleTaskExecutor;

    invoke-direct {v0}, Lio/rong/rtlog/upload/LimitAliveSingleTaskExecutor;-><init>()V

    iput-object v0, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->executor:Lio/rong/rtlog/upload/LimitAliveSingleTaskExecutor;

    const/4 v0, 0x0

    .line 3
    iput-boolean v0, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->isStartSchedule:Z

    const-wide/16 v1, -0x1

    .line 4
    iput-wide v1, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->inBackgroundTime:J

    .line 5
    iput-boolean v0, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->isStopInBackground:Z

    .line 6
    iput-object p1, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->context:Landroid/content/Context;

    .line 7
    iput-object p2, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->version:Ljava/lang/String;

    .line 8
    iput-object p3, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->deviceId:Ljava/lang/String;

    .line 9
    iput-object p4, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->appKey:Ljava/lang/String;

    .line 10
    iput-object p5, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->cache:Lio/rong/rtlog/upload/RtLogCache;

    .line 11
    iput-object p6, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->logCacheDir:Ljava/lang/String;

    .line 12
    new-instance p1, Lio/rong/rtlog/upload/RtLogTimingUploadConfig;

    invoke-direct {p1}, Lio/rong/rtlog/upload/RtLogTimingUploadConfig;-><init>()V

    iput-object p1, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->config:Lio/rong/rtlog/upload/RtLogTimingUploadConfig;

    .line 13
    iget-object p1, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->config:Lio/rong/rtlog/upload/RtLogTimingUploadConfig;

    iget-object p2, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->cache:Lio/rong/rtlog/upload/RtLogCache;

    invoke-virtual {p2}, Lio/rong/rtlog/upload/RtLogCache;->loadTimingUploadConfigCache()Ljava/lang/String;

    move-result-object p2

    invoke-virtual {p1, p2}, Lio/rong/rtlog/upload/RtLogTimingUploadConfig;->loadLogConfig(Ljava/lang/String;)V

    return-void
.end method

.method static synthetic access$000(Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;Lio/rong/rtlog/upload/TimingUploadLogTask;ZZ)V
    .registers 4

    .line 1
    invoke-direct {p0, p1, p2, p3}, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->onTaskEnd(Lio/rong/rtlog/upload/TimingUploadLogTask;ZZ)V

    return-void
.end method

.method private declared-synchronized executeTask(Lio/rong/rtlog/upload/TimingUploadLogTask;JZ)V
    .registers 9

    monitor-enter p0

    .line 1
    :try_start_1
    iget-object v0, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->executor:Lio/rong/rtlog/upload/LimitAliveSingleTaskExecutor;

    new-instance v1, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter$1;

    invoke-direct {v1, p0, p1, p4}, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter$1;-><init>(Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;Lio/rong/rtlog/upload/TimingUploadLogTask;Z)V

    const-wide/16 v2, 0x3e8

    mul-long p2, p2, v2

    invoke-virtual {v0, v1, p2, p3}, Lio/rong/rtlog/upload/LimitAliveSingleTaskExecutor;->execute(Ljava/lang/Runnable;J)V
    :try_end_f
    .catchall {:try_start_1 .. :try_end_f} :catchall_11

    .line 2
    monitor-exit p0

    return-void

    :catchall_11
    move-exception p1

    monitor-exit p0

    throw p1
.end method

.method private declared-synchronized getDelayTime()J
    .registers 7

    monitor-enter p0

    .line 1
    :try_start_1
    iget-object v0, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->config:Lio/rong/rtlog/upload/RtLogTimingUploadConfig;

    invoke-virtual {v0}, Lio/rong/rtlog/upload/RtLogTimingUploadConfig;->getIntervalUploadTime()I

    move-result v0

    int-to-long v0, v0

    const-wide/high16 v2, 0x4000000000000000L    # 2.0

    iget-object v4, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->config:Lio/rong/rtlog/upload/RtLogTimingUploadConfig;

    invoke-virtual {v4}, Lio/rong/rtlog/upload/RtLogTimingUploadConfig;->getCurrentDelayTimes()I

    move-result v4

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

    int-to-double v4, v4

    invoke-static {v2, v3, v4, v5}, Ljava/lang/Math;->pow(DD)D

    move-result-wide v2
    :try_end_17
    .catchall {:try_start_1 .. :try_end_17} :catchall_1c

    double-to-long v2, v2

    mul-long v0, v0, v2

    monitor-exit p0

    return-wide v0

    :catchall_1c
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method private declared-synchronized nextTask(JZ)V
    .registers 5

    monitor-enter p0

    .line 1
    :try_start_1
    invoke-direct {p0}, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->shouldStopInBackground()Z

    move-result v0

    if-eqz v0, :cond_c

    const/4 p1, 0x1

    .line 2
    iput-boolean p1, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->isStopInBackground:Z
    :try_end_a
    .catchall {:try_start_1 .. :try_end_a} :catchall_21

    .line 3
    monitor-exit p0

    return-void

    .line 4
    :cond_c
    :try_start_c
    iget-boolean v0, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->isStartSchedule:Z

    if-eqz v0, :cond_1f

    iget-object v0, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->config:Lio/rong/rtlog/upload/RtLogTimingUploadConfig;

    invoke-virtual {v0}, Lio/rong/rtlog/upload/RtLogTimingUploadConfig;->isUploadEnabled()Z

    move-result v0

    if-eqz v0, :cond_1f

    .line 5
    invoke-direct {p0}, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->obtainTask()Lio/rong/rtlog/upload/TimingUploadLogTask;

    move-result-object v0

    .line 6
    invoke-direct {p0, v0, p1, p2, p3}, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->executeTask(Lio/rong/rtlog/upload/TimingUploadLogTask;JZ)V
    :try_end_1f
    .catchall {:try_start_c .. :try_end_1f} :catchall_21

    .line 7
    :cond_1f
    monitor-exit p0

    return-void

    :catchall_21
    move-exception p1

    monitor-exit p0

    throw p1
.end method

.method private declared-synchronized obtainTask()Lio/rong/rtlog/upload/TimingUploadLogTask;
    .registers 10

    monitor-enter p0

    .line 1
    :try_start_1
    new-instance v8, Lio/rong/rtlog/upload/TimingUploadLogTask;

    iget-object v1, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->context:Landroid/content/Context;

    iget-object v2, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->version:Ljava/lang/String;

    iget-object v3, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->deviceId:Ljava/lang/String;

    iget-object v4, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->appKey:Ljava/lang/String;

    iget-object v0, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->config:Lio/rong/rtlog/upload/RtLogTimingUploadConfig;

    .line 2
    invoke-virtual {v0}, Lio/rong/rtlog/upload/RtLogTimingUploadConfig;->getLogLevel()I

    move-result v5

    iget-object v0, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->config:Lio/rong/rtlog/upload/RtLogTimingUploadConfig;

    .line 3
    invoke-virtual {v0}, Lio/rong/rtlog/upload/RtLogTimingUploadConfig;->getUploadUrl()Ljava/lang/String;

    move-result-object v6

    iget-object v7, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->logCacheDir:Ljava/lang/String;

    move-object v0, v8

    invoke-direct/range {v0 .. v7}, Lio/rong/rtlog/upload/TimingUploadLogTask;-><init>(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;ILjava/lang/String;Ljava/lang/String;)V
    :try_end_1d
    .catchall {:try_start_1 .. :try_end_1d} :catchall_1f

    .line 4
    monitor-exit p0

    return-object v8

    :catchall_1f
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method private declared-synchronized onTaskEnd(Lio/rong/rtlog/upload/TimingUploadLogTask;ZZ)V
    .registers 7

    monitor-enter p0

    const/4 v0, 0x1

    if-eqz p2, :cond_52

    .line 1
    :try_start_4
    invoke-virtual {p1}, Lio/rong/rtlog/upload/TimingUploadLogTask;->getUploadResponse()Ljava/lang/String;

    move-result-object p2

    invoke-static {p2}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z

    move-result p2
    :try_end_c
    .catchall {:try_start_4 .. :try_end_c} :catchall_50

    if-nez p2, :cond_52

    .line 2
    :try_start_e
    new-instance p2, Lorg/json/JSONObject;

    invoke-virtual {p1}, Lio/rong/rtlog/upload/TimingUploadLogTask;->getUploadResponse()Ljava/lang/String;

    move-result-object p1

    invoke-direct {p2, p1}, Lorg/json/JSONObject;-><init>(Ljava/lang/String;)V

    const-string p1, "nextTime"

    .line 3
    invoke-virtual {p2, p1}, Lorg/json/JSONObject;->optInt(Ljava/lang/String;)I

    move-result p1

    const-string v1, "level"

    .line 4
    invoke-virtual {p2, v1}, Lorg/json/JSONObject;->optInt(Ljava/lang/String;)I

    move-result v1

    const-string v2, "logSwitch"

    .line 5
    invoke-virtual {p2, v2}, Lorg/json/JSONObject;->optInt(Ljava/lang/String;)I

    move-result p2

    if-ne p2, v0, :cond_40

    .line 6
    iget-object p2, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->config:Lio/rong/rtlog/upload/RtLogTimingUploadConfig;

    invoke-virtual {p2, v0}, Lio/rong/rtlog/upload/RtLogTimingUploadConfig;->setUploadEnabled(Z)V

    .line 7
    iget-object p2, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->config:Lio/rong/rtlog/upload/RtLogTimingUploadConfig;

    invoke-virtual {p2, p1}, Lio/rong/rtlog/upload/RtLogTimingUploadConfig;->setIntervalUploadTime(I)V

    .line 8
    iget-object p1, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->config:Lio/rong/rtlog/upload/RtLogTimingUploadConfig;

    invoke-virtual {p1}, Lio/rong/rtlog/upload/RtLogTimingUploadConfig;->resetCurrentDelayTimes()V

    .line 9
    iget-object p1, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->config:Lio/rong/rtlog/upload/RtLogTimingUploadConfig;

    invoke-virtual {p1, v1}, Lio/rong/rtlog/upload/RtLogTimingUploadConfig;->setLogLevel(I)V

    goto :goto_52

    .line 10
    :cond_40
    iget-object p1, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->config:Lio/rong/rtlog/upload/RtLogTimingUploadConfig;

    const/4 p2, 0x0

    invoke-virtual {p1, p2}, Lio/rong/rtlog/upload/RtLogTimingUploadConfig;->setUploadEnabled(Z)V
    :try_end_46
    .catch Lorg/json/JSONException; {:try_start_e .. :try_end_46} :catch_47
    .catchall {:try_start_e .. :try_end_46} :catchall_50

    goto :goto_52

    :catch_47
    move-exception p1

    .line 11
    :try_start_48
    sget-object p2, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->TAG:Ljava/lang/String;

    const-string v1, "onTaskEnd"

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

    goto :goto_52

    :catchall_50
    move-exception p1

    goto :goto_62

    :cond_52
    :goto_52
    if-eqz p3, :cond_59

    .line 12
    iget-object p1, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->config:Lio/rong/rtlog/upload/RtLogTimingUploadConfig;

    invoke-virtual {p1}, Lio/rong/rtlog/upload/RtLogTimingUploadConfig;->increaseDelayTimes()V

    .line 13
    :cond_59
    invoke-direct {p0}, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->getDelayTime()J

    move-result-wide p1

    invoke-direct {p0, p1, p2, v0}, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->nextTask(JZ)V
    :try_end_60
    .catchall {:try_start_48 .. :try_end_60} :catchall_50

    .line 14
    monitor-exit p0

    return-void

    :goto_62
    monitor-exit p0

    throw p1
.end method

.method private declared-synchronized shouldStopInBackground()Z
    .registers 6

    monitor-enter p0

    .line 1
    :try_start_1
    iget-wide v0, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->inBackgroundTime:J

    const-wide/16 v2, -0x1

    cmp-long v4, v0, v2

    if-eqz v4, :cond_19

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

    move-result-wide v0

    iget-wide v2, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->inBackgroundTime:J
    :try_end_f
    .catchall {:try_start_1 .. :try_end_f} :catchall_1c

    sub-long/2addr v0, v2

    const-wide/32 v2, 0x493e0

    cmp-long v4, v0, v2

    if-lez v4, :cond_19

    const/4 v0, 0x1

    goto :goto_1a

    :cond_19
    const/4 v0, 0x0

    .line 3
    :goto_1a
    monitor-exit p0

    return v0

    :catchall_1c
    move-exception v0

    monitor-exit p0

    throw v0
.end method


# virtual methods
.method declared-synchronized endSchedule()V
    .registers 2

    monitor-enter p0

    const/4 v0, 0x0

    .line 1
    :try_start_2
    iput-boolean v0, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->isStartSchedule:Z
    :try_end_4
    .catchall {:try_start_2 .. :try_end_4} :catchall_6

    .line 2
    monitor-exit p0

    return-void

    :catchall_6
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method declared-synchronized setToBackgroundTime(J)V
    .registers 6

    monitor-enter p0

    const-wide/16 v0, 0x0

    cmp-long v2, p1, v0

    if-lez v2, :cond_a

    .line 1
    :try_start_7
    iput-wide p1, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->inBackgroundTime:J

    goto :goto_1d

    :cond_a
    const-wide/16 p1, -0x1

    .line 2
    iput-wide p1, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->inBackgroundTime:J

    .line 3
    iget-boolean p1, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->isStopInBackground:Z

    if-eqz p1, :cond_1d

    const/4 p1, 0x0

    .line 4
    iput-boolean p1, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->isStopInBackground:Z

    .line 5
    invoke-direct {p0}, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->getDelayTime()J

    move-result-wide p1

    const/4 v0, 0x1

    invoke-direct {p0, p1, p2, v0}, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->nextTask(JZ)V
    :try_end_1d
    .catchall {:try_start_7 .. :try_end_1d} :catchall_1f

    .line 6
    :cond_1d
    :goto_1d
    monitor-exit p0

    return-void

    :catchall_1f
    move-exception p1

    monitor-exit p0

    throw p1
.end method

.method declared-synchronized startTask()V
    .registers 4

    monitor-enter p0

    .line 1
    :try_start_1
    iget-boolean v0, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->isStartSchedule:Z
    :try_end_3
    .catchall {:try_start_1 .. :try_end_3} :catchall_12

    if-eqz v0, :cond_7

    monitor-exit p0

    return-void

    :cond_7
    const/4 v0, 0x1

    .line 2
    :try_start_8
    iput-boolean v0, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->isStartSchedule:Z

    const-wide/16 v0, 0x1e

    const/4 v2, 0x0

    .line 3
    invoke-direct {p0, v0, v1, v2}, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->nextTask(JZ)V
    :try_end_10
    .catchall {:try_start_8 .. :try_end_10} :catchall_12

    .line 4
    monitor-exit p0

    return-void

    :catchall_12
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method declared-synchronized updateTimingUploadConfig(Ljava/lang/String;)V
    .registers 3

    monitor-enter p0

    .line 1
    :try_start_1
    iget-object v0, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->config:Lio/rong/rtlog/upload/RtLogTimingUploadConfig;

    invoke-virtual {v0, p1}, Lio/rong/rtlog/upload/RtLogTimingUploadConfig;->loadLogConfig(Ljava/lang/String;)V

    .line 2
    iget-object v0, p0, Lio/rong/rtlog/upload/TimingUploadTaskScheduleCenter;->cache:Lio/rong/rtlog/upload/RtLogCache;

    invoke-virtual {v0, p1}, Lio/rong/rtlog/upload/RtLogCache;->saveTimingUploadConfig(Ljava/lang/String;)V
    :try_end_b
    .catchall {:try_start_1 .. :try_end_b} :catchall_d

    .line 3
    monitor-exit p0

    return-void

    :catchall_d
    move-exception p1

    monitor-exit p0

    throw p1
.end method