Shepherd2UpdateJobService.smali
.class public Lcom/avast/android/shepherd2/Shepherd2UpdateJobService;
.super Landroid/app/job/JobService;
# annotations
.annotation build Landroid/annotation/TargetApi;
value = 0x15
.end annotation
# direct methods
.method public constructor <init>()V
.registers 1
invoke-direct {p0}, Landroid/app/job/JobService;-><init>()V
return-void
.end method
.method private static a(Landroid/content/Context;)V
.registers 2
const-string v0, "jobscheduler"
invoke-virtual {p0, v0}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object;
move-result-object p0
check-cast p0, Landroid/app/job/JobScheduler;
if-eqz p0, :cond_10
const v0, 0x351ca6
invoke-virtual {p0, v0}, Landroid/app/job/JobScheduler;->cancel(I)V
:cond_10
return-void
.end method
.method static b(Landroid/content/Context;)V
.registers 2
const-string v0, "jobscheduler"
invoke-virtual {p0, v0}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object;
move-result-object p0
check-cast p0, Landroid/app/job/JobScheduler;
if-eqz p0, :cond_10
const v0, 0x351ca7
invoke-virtual {p0, v0}, Landroid/app/job/JobScheduler;->cancel(I)V
:cond_10
return-void
.end method
.method static c(Landroid/content/Context;J)V
.registers 8
invoke-static {p0}, Lcom/avast/android/shepherd2/Shepherd2UpdateJobService;->a(Landroid/content/Context;)V
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
sub-long/2addr p1, v0
const-wide/16 v0, 0x0
cmp-long v2, p1, v0
if-gez v2, :cond_16
sget-object p1, Ljava/util/concurrent/TimeUnit;->HOURS:Ljava/util/concurrent/TimeUnit;
const-wide/16 v0, 0x1
invoke-virtual {p1, v0, v1}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J
move-result-wide p1
:cond_16
const v0, 0x351ca6
invoke-static {p0, v0, p1, p2}, Lcom/avast/android/shepherd2/Shepherd2UpdateJobService;->e(Landroid/content/Context;IJ)V
sget-object p0, Lcom/avast/android/shepherd2/LH;->a:Lcom/avast/android/logging/Alf;
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "Next update time scheduled to occur soonest at "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-static {}, Ljava/text/SimpleDateFormat;->getDateTimeInstance()Ljava/text/DateFormat;
move-result-object v1
new-instance v2, Ljava/util/Date;
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v3
add-long/2addr v3, p1
invoke-direct {v2, v3, v4}, Ljava/util/Date;-><init>(J)V
invoke-virtual {v1, v2}, Ljava/text/DateFormat;->format(Ljava/util/Date;)Ljava/lang/String;
move-result-object p1
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
const/4 p2, 0x0
new-array p2, p2, [Ljava/lang/Object;
invoke-virtual {p0, p1, p2}, Lcom/avast/android/logging/Alf;->c(Ljava/lang/String;[Ljava/lang/Object;)V
return-void
.end method
.method static d(Landroid/content/Context;)V
.registers 8
invoke-static {p0}, Lcom/avast/android/shepherd2/Shepherd2UpdateJobService;->b(Landroid/content/Context;)V
const v0, 0x351ca7
const-wide/32 v1, 0x36ee80
invoke-static {p0, v0, v1, v2}, Lcom/avast/android/shepherd2/Shepherd2UpdateJobService;->e(Landroid/content/Context;IJ)V
sget-object p0, Lcom/avast/android/shepherd2/LH;->a:Lcom/avast/android/logging/Alf;
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Fallback update attempt scheduled to occur soonest after "
invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-static {}, Ljava/text/SimpleDateFormat;->getDateTimeInstance()Ljava/text/DateFormat;
move-result-object v3
new-instance v4, Ljava/util/Date;
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v5
add-long/2addr v5, v1
invoke-direct {v4, v5, v6}, Ljava/util/Date;-><init>(J)V
invoke-virtual {v3, v4}, Ljava/text/DateFormat;->format(Ljava/util/Date;)Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
const/4 v1, 0x0
new-array v1, v1, [Ljava/lang/Object;
invoke-virtual {p0, v0, v1}, Lcom/avast/android/logging/Alf;->c(Ljava/lang/String;[Ljava/lang/Object;)V
return-void
.end method
.method private static e(Landroid/content/Context;IJ)V
.registers 10
const-string v0, "jobscheduler"
invoke-virtual {p0, v0}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Landroid/app/job/JobScheduler;
const-string v1, "Failed to schedule job"
const/4 v2, 0x0
if-nez v0, :cond_15
sget-object p0, Lcom/avast/android/shepherd2/LH;->a:Lcom/avast/android/logging/Alf;
new-array p1, v2, [Ljava/lang/Object;
invoke-virtual {p0, v1, p1}, Lcom/avast/android/logging/Alf;->e(Ljava/lang/String;[Ljava/lang/Object;)V
return-void
:cond_15
new-instance v3, Landroid/app/job/JobInfo$Builder;
new-instance v4, Landroid/content/ComponentName;
const-class v5, Lcom/avast/android/shepherd2/Shepherd2UpdateJobService;
invoke-direct {v4, p0, v5}, Landroid/content/ComponentName;-><init>(Landroid/content/Context;Ljava/lang/Class;)V
invoke-direct {v3, p1, v4}, Landroid/app/job/JobInfo$Builder;-><init>(ILandroid/content/ComponentName;)V
const/4 p0, 0x1
invoke-virtual {v3, p0}, Landroid/app/job/JobInfo$Builder;->setRequiredNetworkType(I)Landroid/app/job/JobInfo$Builder;
move-result-object p1
invoke-virtual {p1, p2, p3}, Landroid/app/job/JobInfo$Builder;->setMinimumLatency(J)Landroid/app/job/JobInfo$Builder;
move-result-object p1
invoke-virtual {p1}, Landroid/app/job/JobInfo$Builder;->build()Landroid/app/job/JobInfo;
move-result-object p1
:try_start_2e
invoke-virtual {v0, p1}, Landroid/app/job/JobScheduler;->schedule(Landroid/app/job/JobInfo;)I
:try_end_31
.catch Ljava/lang/IllegalStateException; {:try_start_2e .. :try_end_31} :catch_33
goto/16 :goto_a6
:catch_33
move-exception p1
invoke-virtual {p1}, Ljava/lang/IllegalStateException;->getMessage()Ljava/lang/String;
move-result-object p2
if-eqz p2, :cond_9f
invoke-virtual {p1}, Ljava/lang/IllegalStateException;->getMessage()Ljava/lang/String;
move-result-object p2
const-string p3, "Apps may not schedule more than"
invoke-virtual {p2, p3}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result p2
if-eqz p2, :cond_9f
invoke-virtual {v0}, Landroid/app/job/JobScheduler;->getAllPendingJobs()Ljava/util/List;
move-result-object p2
new-instance p3, Ljava/lang/StringBuilder;
invoke-direct {p3}, Ljava/lang/StringBuilder;-><init>()V
const-string v0, "Pending jobs: ["
invoke-virtual {p3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-interface {p2}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object p2
:goto_58
invoke-interface {p2}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_7d
invoke-interface {p2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Landroid/app/job/JobInfo;
if-eqz p0, :cond_68
const/4 p0, 0x0
goto :goto_6d
:cond_68
const/16 v1, 0x2c
invoke-virtual {p3, v1}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
:goto_6d
const/16 v1, 0x22
invoke-virtual {p3, v1}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Landroid/app/job/JobInfo;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {p3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p3, v1}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
goto :goto_58
:cond_7d
const/16 p0, 0x5d
invoke-virtual {p3, p0}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
sget-object p0, Lcom/avast/android/shepherd2/LH;->a:Lcom/avast/android/logging/Alf;
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
const-string v0, "Failed to schedule jog: "
invoke-virtual {p2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p3
invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
new-array p3, v2, [Ljava/lang/Object;
invoke-virtual {p0, p1, p2, p3}, Lcom/avast/android/logging/Alf;->f(Ljava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_a6
:cond_9f
sget-object p0, Lcom/avast/android/shepherd2/LH;->a:Lcom/avast/android/logging/Alf;
new-array p2, v2, [Ljava/lang/Object;
invoke-virtual {p0, p1, v1, p2}, Lcom/avast/android/logging/Alf;->f(Ljava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V
:goto_a6
return-void
.end method
# virtual methods
.method public onStartJob(Landroid/app/job/JobParameters;)Z
.registers 4
invoke-virtual {p1}, Landroid/app/job/JobParameters;->getJobId()I
move-result p1
const/4 v0, 0x0
const v1, 0x351ca7
if-ne v1, p1, :cond_c
const/4 p1, 0x1
goto :goto_d
:cond_c
const/4 p1, 0x0
:goto_d
invoke-virtual {p0}, Landroid/app/job/JobService;->getApplicationContext()Landroid/content/Context;
move-result-object v1
invoke-static {v1, p1}, Lcom/avast/android/shepherd2/Shepherd2DownloadService;->j(Landroid/content/Context;Z)V
return v0
.end method
.method public onStopJob(Landroid/app/job/JobParameters;)Z
.registers 2
const/4 p1, 0x0
return p1
.end method