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