FSDScheduler.smali
.class Lcom/taboola/android/global_components/fsd/FSDScheduler;
.super Ljava/lang/Object;
.source "FSDScheduler.java"
# static fields
.field private static final TAG:Ljava/lang/String;
# instance fields
.field private mFirstScheduleTimeInHours:I
.field private mFsdManager:Lcom/taboola/android/global_components/fsd/FSDManager;
.field private mNextScheduleTimeInDays:I
.field private mNumberOfRetries:I
.field private mPercentageAllowedForStatistics:I
.field private mRetriesIntervalTimeInHours:I
# direct methods
.method static constructor <clinit>()V
.registers 1
.line 19
const-class v0, Lcom/taboola/android/global_components/fsd/FSDScheduler;
invoke-virtual {v0}, Ljava/lang/Class;->getSimpleName()Ljava/lang/String;
move-result-object v0
sput-object v0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->TAG:Ljava/lang/String;
return-void
.end method
.method constructor <init>()V
.registers 3
.line 27
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const/16 v0, 0x3c
.line 21
iput v0, p0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mFirstScheduleTimeInHours:I
const/16 v0, 0x1e
.line 22
iput v0, p0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mNextScheduleTimeInDays:I
const/4 v0, 0x3
.line 23
iput v0, p0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mNumberOfRetries:I
const/16 v0, 0x18
.line 24
iput v0, p0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mRetriesIntervalTimeInHours:I
const/16 v0, 0xa
.line 25
iput v0, p0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mPercentageAllowedForStatistics:I
.line 28
invoke-static {}, Lcom/taboola/android/Taboola;->getTaboolaImpl()Lcom/taboola/android/ITaboolaImpl;
move-result-object v0
invoke-interface {v0}, Lcom/taboola/android/ITaboolaImpl;->getFsdManager()Lcom/taboola/android/global_components/fsd/FSDManager;
move-result-object v0
iput-object v0, p0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mFsdManager:Lcom/taboola/android/global_components/fsd/FSDManager;
.line 29
iget v1, p0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mFirstScheduleTimeInHours:I
invoke-virtual {v0, v1}, Lcom/taboola/android/global_components/fsd/FSDManager;->getFirstScheduleTimeInHours(I)I
move-result v0
iput v0, p0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mFirstScheduleTimeInHours:I
.line 30
iget-object v0, p0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mFsdManager:Lcom/taboola/android/global_components/fsd/FSDManager;
iget v1, p0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mNextScheduleTimeInDays:I
invoke-virtual {v0, v1}, Lcom/taboola/android/global_components/fsd/FSDManager;->getNextScheduleTimeInDays(I)I
move-result v0
iput v0, p0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mNextScheduleTimeInDays:I
.line 31
iget-object v0, p0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mFsdManager:Lcom/taboola/android/global_components/fsd/FSDManager;
iget v1, p0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mNumberOfRetries:I
invoke-virtual {v0, v1}, Lcom/taboola/android/global_components/fsd/FSDManager;->getNumberOfRetries(I)I
move-result v0
iput v0, p0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mNumberOfRetries:I
.line 32
iget-object v0, p0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mFsdManager:Lcom/taboola/android/global_components/fsd/FSDManager;
iget v1, p0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mRetriesIntervalTimeInHours:I
invoke-virtual {v0, v1}, Lcom/taboola/android/global_components/fsd/FSDManager;->getRetriesInvervalTimeInHours(I)I
move-result v0
iput v0, p0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mRetriesIntervalTimeInHours:I
.line 33
iget-object v0, p0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mFsdManager:Lcom/taboola/android/global_components/fsd/FSDManager;
iget v1, p0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mPercentageAllowedForStatistics:I
invoke-virtual {v0, v1}, Lcom/taboola/android/global_components/fsd/FSDManager;->getAllowedPercentageForStatistics(I)I
move-result v0
iput v0, p0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mPercentageAllowedForStatistics:I
return-void
.end method
.method private isDebugMode(Landroid/content/Context;)Z
.registers 4
.line 158
iget-object v0, p0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mFsdManager:Lcom/taboola/android/global_components/fsd/FSDManager;
const/4 v1, 0x0
if-eqz v0, :cond_1b
if-nez p1, :cond_8
goto :goto_1b
.line 161
:cond_8
invoke-virtual {v0, v1}, Lcom/taboola/android/global_components/fsd/FSDManager;->getIsInDebugMode(Z)Z
move-result v0
if-eqz v0, :cond_1b
invoke-virtual {p1}, Landroid/content/Context;->getPackageName()Ljava/lang/String;
move-result-object p1
const-string v0, "com.taboola.testingsample"
invoke-virtual {p1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result p1
if-eqz p1, :cond_1b
const/4 v1, 0x1
:cond_1b
:goto_1b
return v1
.end method
.method private scheduleFSD(Landroid/content/Context;Ljava/util/Calendar;Landroid/app/PendingIntent;)V
.registers 10
const-string v0, "alarm"
.line 126
invoke-virtual {p1, v0}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object;
move-result-object p1
check-cast p1, Landroid/app/AlarmManager;
if-eqz p1, :cond_5d
.line 128
sget-object v0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->TAG:Ljava/lang/String;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Alarm set to run in "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/util/Calendar;->getTimeInMillis()J
move-result-wide v2
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v4
sub-long/2addr v2, v4
const-wide/16 v4, 0x3e8
div-long/2addr v2, v4
invoke-virtual {v1, v2, v3}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
const-string v2, " seconds @ "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/util/Calendar;->getTime()Ljava/util/Date;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Lcom/taboola/android/utils/Logger;->d(Ljava/lang/String;Ljava/lang/String;)V
const/4 v0, 0x0
.line 130
sget v1, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v2, 0x17
if-lt v1, v2, :cond_47
.line 131
invoke-virtual {p2}, Ljava/util/Calendar;->getTimeInMillis()J
move-result-wide v1
invoke-virtual {p1, v0, v1, v2, p3}, Landroid/app/AlarmManager;->setExactAndAllowWhileIdle(IJLandroid/app/PendingIntent;)V
goto :goto_64
.line 132
:cond_47
sget v1, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v2, 0x13
if-lt v1, v2, :cond_55
.line 133
invoke-virtual {p2}, Ljava/util/Calendar;->getTimeInMillis()J
move-result-wide v1
invoke-virtual {p1, v0, v1, v2, p3}, Landroid/app/AlarmManager;->setExact(IJLandroid/app/PendingIntent;)V
goto :goto_64
.line 135
:cond_55
invoke-virtual {p2}, Ljava/util/Calendar;->getTimeInMillis()J
move-result-wide v1
invoke-virtual {p1, v0, v1, v2, p3}, Landroid/app/AlarmManager;->set(IJLandroid/app/PendingIntent;)V
goto :goto_64
.line 138
:cond_5d
sget-object p1, Lcom/taboola/android/global_components/fsd/FSDScheduler;->TAG:Ljava/lang/String;
const-string p2, "setFsdAlarm() | Alarm Manager is null"
invoke-static {p1, p2}, Lcom/taboola/android/utils/Logger;->d(Ljava/lang/String;Ljava/lang/String;)V
:goto_64
return-void
.end method
# virtual methods
.method cancelScheduler(Landroid/content/Context;)V
.registers 6
:try_start_0
const-string v0, "alarm"
.line 145
invoke-virtual {p1, v0}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Landroid/app/AlarmManager;
if-eqz v0, :cond_19
const/4 v1, 0x0
.line 147
invoke-virtual {p0, p1}, Lcom/taboola/android/global_components/fsd/FSDScheduler;->getFSDIntent(Landroid/content/Context;)Landroid/content/Intent;
move-result-object v2
const/high16 v3, 0x8000000
invoke-static {p1, v1, v2, v3}, Landroid/app/PendingIntent;->getBroadcast(Landroid/content/Context;ILandroid/content/Intent;I)Landroid/app/PendingIntent;
move-result-object p1
invoke-virtual {v0, p1}, Landroid/app/AlarmManager;->cancel(Landroid/app/PendingIntent;)V
goto :goto_2b
.line 149
:cond_19
sget-object p1, Lcom/taboola/android/global_components/fsd/FSDScheduler;->TAG:Ljava/lang/String;
const-string v0, "cancelScheduledFSD() | Alarm Manager is null"
invoke-static {p1, v0}, Lcom/taboola/android/utils/Logger;->d(Ljava/lang/String;Ljava/lang/String;)V
:try_end_20
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_20} :catch_21
goto :goto_2b
:catch_21
move-exception p1
.line 152
sget-object v0, Lcom/taboola/android/global_components/fsd/FSDScheduler;->TAG:Ljava/lang/String;
invoke-virtual {p1}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1, p1}, Lcom/taboola/android/utils/Logger;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
:goto_2b
return-void
.end method
.method getFSDIntent(Landroid/content/Context;)Landroid/content/Intent;
.registers 4
.line 120
new-instance v0, Landroid/content/Intent;
invoke-direct {v0}, Landroid/content/Intent;-><init>()V
.line 121
const-class v1, Lcom/taboola/android/global_components/fsd/FSDReceiver;
invoke-virtual {v0, p1, v1}, Landroid/content/Intent;->setClass(Landroid/content/Context;Ljava/lang/Class;)Landroid/content/Intent;
return-object v0
.end method
.method schedule(Landroid/content/Context;)V
.registers 19
move-object/from16 v1, p0
move-object/from16 v0, p1
if-eqz v0, :cond_134
.line 38
:try_start_6
iget-object v2, v1, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mFsdManager:Lcom/taboola/android/global_components/fsd/FSDManager;
if-nez v2, :cond_c
goto/16 :goto_134
.line 42
:cond_c
invoke-static {}, Ljava/util/Calendar;->getInstance()Ljava/util/Calendar;
move-result-object v2
const-wide/16 v3, 0x0
.line 43
invoke-static {v0, v3, v4}, Lcom/taboola/android/utils/SharedPrefUtil;->getFsdSuccess(Landroid/content/Context;J)J
move-result-wide v5
const/4 v7, 0x0
.line 44
invoke-static {v0, v7}, Lcom/taboola/android/utils/SharedPrefUtil;->getFsdFail(Landroid/content/Context;I)J
move-result-wide v8
.line 45
invoke-static {v0, v3, v4}, Lcom/taboola/android/utils/SharedPrefUtil;->getFsdNext(Landroid/content/Context;J)J
move-result-wide v10
const/16 v12, 0x1e
const/16 v13, 0xd
const/16 v14, 0xb
const/4 v15, 0x1
cmp-long v16, v10, v3
if-nez v16, :cond_73
.line 50
new-instance v3, Ljava/util/Random;
invoke-direct {v3}, Ljava/util/Random;-><init>()V
const/16 v4, 0x65
invoke-virtual {v3, v4}, Ljava/util/Random;->nextInt(I)I
move-result v3
.line 51
sget-object v4, Lcom/taboola/android/global_components/fsd/FSDScheduler;->TAG:Ljava/lang/String;
new-instance v5, Ljava/lang/StringBuilder;
invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V
const-string v6, "Random: "
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
invoke-static {v4, v5}, Lcom/taboola/android/utils/Logger;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 52
iget v4, v1, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mPercentageAllowedForStatistics:I
if-ge v3, v4, :cond_58
.line 53
invoke-static {v0, v15}, Lcom/taboola/android/utils/SharedPrefUtil;->setFsdStatsEnabled(Landroid/content/Context;Z)V
.line 54
iget-object v3, v1, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mFsdManager:Lcom/taboola/android/global_components/fsd/FSDManager;
invoke-virtual {v3, v2}, Lcom/taboola/android/global_components/fsd/FSDManager;->createAndSendFirstTimeLog(Ljava/util/Calendar;)V
goto :goto_5b
.line 56
:cond_58
invoke-static {v0, v7}, Lcom/taboola/android/utils/SharedPrefUtil;->setFsdStatsEnabled(Landroid/content/Context;Z)V
.line 59
:goto_5b
sget-object v3, Lcom/taboola/android/global_components/fsd/FSDScheduler;->TAG:Ljava/lang/String;
const-string v4, "schedule(): first time ever."
invoke-static {v3, v4}, Lcom/taboola/android/utils/Logger;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 60
new-instance v3, Ljava/util/Random;
invoke-direct {v3}, Ljava/util/Random;-><init>()V
iget v4, v1, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mFirstScheduleTimeInHours:I
add-int/2addr v4, v15
invoke-virtual {v3, v4}, Ljava/util/Random;->nextInt(I)I
move-result v3
invoke-virtual {v2, v14, v3}, Ljava/util/Calendar;->add(II)V
goto/16 :goto_e6
:cond_73
cmp-long v3, v8, v5
if-nez v3, :cond_82
.line 63
sget-object v3, Lcom/taboola/android/global_components/fsd/FSDScheduler;->TAG:Ljava/lang/String;
const-string v4, "schedule(): Alarm already set but did not fire yet"
invoke-static {v3, v4}, Lcom/taboola/android/utils/Logger;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 64
invoke-virtual {v2, v10, v11}, Ljava/util/Calendar;->setTimeInMillis(J)V
goto :goto_e6
.line 66
:cond_82
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v3
cmp-long v16, v3, v10
if-ltz v16, :cond_de
const/4 v3, 0x5
cmp-long v4, v5, v8
if-lez v4, :cond_a6
.line 69
sget-object v4, Lcom/taboola/android/global_components/fsd/FSDScheduler;->TAG:Ljava/lang/String;
const-string v5, "schedule(): Last time was success flow"
invoke-static {v4, v5}, Lcom/taboola/android/utils/Logger;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 71
invoke-direct/range {p0 .. p1}, Lcom/taboola/android/global_components/fsd/FSDScheduler;->isDebugMode(Landroid/content/Context;)Z
move-result v4
if-eqz v4, :cond_a0
.line 72
invoke-virtual {v2, v13, v12}, Ljava/util/Calendar;->add(II)V
goto :goto_e6
.line 74
:cond_a0
iget v4, v1, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mNextScheduleTimeInDays:I
invoke-virtual {v2, v3, v4}, Ljava/util/Calendar;->add(II)V
goto :goto_e6
.line 79
:cond_a6
invoke-static {v0, v7}, Lcom/taboola/android/utils/SharedPrefUtil;->getFsdRetries(Landroid/content/Context;I)I
move-result v4
.line 80
iget v5, v1, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mNumberOfRetries:I
if-gt v4, v5, :cond_c1
.line 81
sget-object v3, Lcom/taboola/android/global_components/fsd/FSDScheduler;->TAG:Ljava/lang/String;
const-string v5, "schedule(): Last time was failure - let\'s retry."
invoke-static {v3, v5}, Lcom/taboola/android/utils/Logger;->d(Ljava/lang/String;Ljava/lang/String;)V
if-ne v4, v15, :cond_bb
.line 83
invoke-virtual {v2, v14, v15}, Ljava/util/Calendar;->add(II)V
goto :goto_e6
.line 85
:cond_bb
iget v3, v1, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mRetriesIntervalTimeInHours:I
invoke-virtual {v2, v14, v3}, Ljava/util/Calendar;->add(II)V
goto :goto_e6
.line 88
:cond_c1
sget-object v4, Lcom/taboola/android/global_components/fsd/FSDScheduler;->TAG:Ljava/lang/String;
const-string v5, "schedule(): Last time was failure and num of retires exceeded!"
invoke-static {v4, v5}, Lcom/taboola/android/utils/Logger;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 89
iget-object v4, v1, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mFsdManager:Lcom/taboola/android/global_components/fsd/FSDManager;
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v5
const-string v8, "fsd_err_maxre"
new-array v9, v7, [Ljava/lang/String;
invoke-virtual {v4, v5, v6, v8, v9}, Lcom/taboola/android/global_components/fsd/FSDManager;->addStats(JLjava/lang/String;[Ljava/lang/String;)V
.line 90
invoke-static {v0, v7}, Lcom/taboola/android/utils/SharedPrefUtil;->setFsdRetry(Landroid/content/Context;I)V
.line 91
iget v4, v1, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mNextScheduleTimeInDays:I
invoke-virtual {v2, v3, v4}, Ljava/util/Calendar;->add(II)V
goto :goto_e6
.line 96
:cond_de
iget-object v3, v1, Lcom/taboola/android/global_components/fsd/FSDScheduler;->mFsdManager:Lcom/taboola/android/global_components/fsd/FSDManager;
invoke-virtual {v3}, Lcom/taboola/android/global_components/fsd/FSDManager;->sendFsdStatsToKibana()V
.line 97
invoke-virtual {v2, v10, v11}, Ljava/util/Calendar;->setTimeInMillis(J)V
.line 101
:goto_e6
invoke-direct/range {p0 .. p1}, Lcom/taboola/android/global_components/fsd/FSDScheduler;->isDebugMode(Landroid/content/Context;)Z
move-result v3
if-eqz v3, :cond_f6
.line 102
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v3
invoke-virtual {v2, v3, v4}, Ljava/util/Calendar;->setTimeInMillis(J)V
.line 103
invoke-virtual {v2, v13, v12}, Ljava/util/Calendar;->add(II)V
.line 106
:cond_f6
invoke-virtual {v2}, Ljava/util/Calendar;->getTimeInMillis()J
move-result-wide v3
invoke-static {v0, v3, v4}, Lcom/taboola/android/utils/SharedPrefUtil;->setFsdNext(Landroid/content/Context;J)V
.line 107
invoke-virtual/range {p0 .. p1}, Lcom/taboola/android/global_components/fsd/FSDScheduler;->getFSDIntent(Landroid/content/Context;)Landroid/content/Intent;
move-result-object v3
const/high16 v4, 0x8000000
.line 109
invoke-static {v0, v7, v3, v4}, Landroid/app/PendingIntent;->getBroadcast(Landroid/content/Context;ILandroid/content/Intent;I)Landroid/app/PendingIntent;
move-result-object v3
.line 111
sget-object v4, Lcom/taboola/android/global_components/fsd/FSDScheduler;->TAG:Ljava/lang/String;
new-instance v5, Ljava/lang/StringBuilder;
invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V
const-string v6, "Alarm set to: "
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
new-instance v6, Ljava/util/Date;
invoke-virtual {v2}, Ljava/util/Calendar;->getTimeInMillis()J
move-result-wide v7
invoke-direct {v6, v7, v8}, Ljava/util/Date;-><init>(J)V
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
invoke-static {v4, v5}, Lcom/taboola/android/utils/Logger;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 112
invoke-direct {v1, v0, v2, v3}, Lcom/taboola/android/global_components/fsd/FSDScheduler;->scheduleFSD(Landroid/content/Context;Ljava/util/Calendar;Landroid/app/PendingIntent;)V
:try_end_129
.catch Ljava/lang/Exception; {:try_start_6 .. :try_end_129} :catch_12a
goto :goto_134
:catch_12a
move-exception v0
.line 114
sget-object v2, Lcom/taboola/android/global_components/fsd/FSDScheduler;->TAG:Ljava/lang/String;
invoke-virtual {v0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object v3
invoke-static {v2, v3, v0}, Lcom/taboola/android/utils/Logger;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
:cond_134
:goto_134
return-void
.end method