TinkerPatchService.smali
.class public Lcom/tencent/tinker/lib/service/TinkerPatchService;
.super Ljava/lang/Object;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/tencent/tinker/lib/service/TinkerPatchService$JobServiceRunner;,
Lcom/tencent/tinker/lib/service/TinkerPatchService$IntentServiceRunner;
}
.end annotation
# static fields
.field private static final MIN_SDKVER_TO_USE_JOBSCHEDULER:I = 0x1a
.field private static final PATCH_PATH_EXTRA:Ljava/lang/String; = "patch_path_extra"
.field private static final RESULT_CLASS_EXTRA:Ljava/lang/String; = "patch_result_class"
.field private static final TAG:Ljava/lang/String; = "Tinker.TinkerPatchService"
.field private static mHandler:Landroid/os/Handler;
.field private static notificationId:I
.field private static resultServiceClass:Ljava/lang/Class;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/lang/Class",
"<+",
"Lcom/tencent/tinker/lib/service/AbstractResultService;",
">;"
}
.end annotation
.end field
.field private static sIsPatchApplying:Ljava/util/concurrent/atomic/AtomicBoolean;
.field private static upgradePatchProcessor:Lcom/tencent/tinker/lib/patch/AbstractPatch;
# direct methods
.method static constructor <clinit>()V
.registers 2
const/4 v1, 0x0
sput-object v1, Lcom/tencent/tinker/lib/service/TinkerPatchService;->upgradePatchProcessor:Lcom/tencent/tinker/lib/patch/AbstractPatch;
const v0, -0x42bfb85d
sput v0, Lcom/tencent/tinker/lib/service/TinkerPatchService;->notificationId:I
sput-object v1, Lcom/tencent/tinker/lib/service/TinkerPatchService;->resultServiceClass:Ljava/lang/Class;
new-instance v0, Landroid/os/Handler;
invoke-static {}, Landroid/os/Looper;->getMainLooper()Landroid/os/Looper;
move-result-object v1
invoke-direct {v0, v1}, Landroid/os/Handler;-><init>(Landroid/os/Looper;)V
sput-object v0, Lcom/tencent/tinker/lib/service/TinkerPatchService;->mHandler:Landroid/os/Handler;
new-instance v0, Ljava/util/concurrent/atomic/AtomicBoolean;
const/4 v1, 0x0
invoke-direct {v0, v1}, Ljava/util/concurrent/atomic/AtomicBoolean;-><init>(Z)V
sput-object v0, Lcom/tencent/tinker/lib/service/TinkerPatchService;->sIsPatchApplying:Ljava/util/concurrent/atomic/AtomicBoolean;
return-void
.end method
.method public constructor <init>()V
.registers 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method static synthetic access$000(Landroid/content/Context;Ljava/lang/String;)V
.registers 2
invoke-static {p0, p1}, Lcom/tencent/tinker/lib/service/TinkerPatchService;->runPatchServiceByIntentService(Landroid/content/Context;Ljava/lang/String;)V
return-void
.end method
.method static synthetic access$100(Landroid/content/Context;Landroid/content/Intent;)V
.registers 2
invoke-static {p0, p1}, Lcom/tencent/tinker/lib/service/TinkerPatchService;->doApplyPatch(Landroid/content/Context;Landroid/content/Intent;)V
return-void
.end method
.method static synthetic access$200()I
.registers 1
sget v0, Lcom/tencent/tinker/lib/service/TinkerPatchService;->notificationId:I
return v0
.end method
.method private static doApplyPatch(Landroid/content/Context;Landroid/content/Intent;)V
.registers 14
const/4 v2, 0x0
sget-object v0, Lcom/tencent/tinker/lib/service/TinkerPatchService;->sIsPatchApplying:Ljava/util/concurrent/atomic/AtomicBoolean;
const/4 v1, 0x1
invoke-virtual {v0, v2, v1}, Ljava/util/concurrent/atomic/AtomicBoolean;->compareAndSet(ZZ)Z
move-result v0
if-nez v0, :cond_16
const-string/jumbo v0, "Tinker.TinkerPatchService"
const-string/jumbo v1, "TinkerPatchService doApplyPatch is running by another runner."
new-array v2, v2, [Ljava/lang/Object;
invoke-static {v0, v1, v2}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
:goto_15
return-void
:cond_16
invoke-static {p0}, Lcom/tencent/tinker/lib/tinker/Tinker;->with(Landroid/content/Context;)Lcom/tencent/tinker/lib/tinker/Tinker;
move-result-object v3
invoke-virtual {v3}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v0
invoke-interface {v0, p1}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchServiceStart(Landroid/content/Intent;)V
if-nez p1, :cond_2f
const-string/jumbo v0, "Tinker.TinkerPatchService"
const-string/jumbo v1, "TinkerPatchService received a null intent, ignoring."
new-array v2, v2, [Ljava/lang/Object;
invoke-static {v0, v1, v2}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_15
:cond_2f
invoke-static {p1}, Lcom/tencent/tinker/lib/service/TinkerPatchService;->getPatchPathExtra(Landroid/content/Intent;)Ljava/lang/String;
move-result-object v4
if-nez v4, :cond_41
const-string/jumbo v0, "Tinker.TinkerPatchService"
const-string/jumbo v1, "TinkerPatchService can\'t get the path extra, ignoring."
new-array v2, v2, [Ljava/lang/Object;
invoke-static {v0, v1, v2}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_15
:cond_41
new-instance v5, Ljava/io/File;
invoke-direct {v5, v4}, Ljava/io/File;-><init>(Ljava/lang/String;)V
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v6
const/4 v0, 0x0
new-instance v8, Lcom/tencent/tinker/lib/service/PatchResult;
invoke-direct {v8}, Lcom/tencent/tinker/lib/service/PatchResult;-><init>()V
:try_start_50
sget-object v1, Lcom/tencent/tinker/lib/service/TinkerPatchService;->upgradePatchProcessor:Lcom/tencent/tinker/lib/patch/AbstractPatch;
if-nez v1, :cond_88
new-instance v0, Lcom/tencent/tinker/loader/TinkerRuntimeException;
const-string/jumbo v1, "upgradePatchProcessor is null."
invoke-direct {v0, v1}, Lcom/tencent/tinker/loader/TinkerRuntimeException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_5d
.catch Ljava/lang/Throwable; {:try_start_50 .. :try_end_5d} :catch_5d
:catch_5d
move-exception v0
invoke-virtual {v3}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v1
invoke-interface {v1, v5, v0}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchException(Ljava/io/File;Ljava/lang/Throwable;)V
move v1, v2
:goto_66
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v10
sub-long v6, v10, v6
invoke-virtual {v3}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v3
invoke-interface {v3, v5, v1, v6, v7}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchResult(Ljava/io/File;ZJ)V
iput-boolean v1, v8, Lcom/tencent/tinker/lib/service/PatchResult;->isSuccess:Z
iput-object v4, v8, Lcom/tencent/tinker/lib/service/PatchResult;->rawPatchFilePath:Ljava/lang/String;
iput-wide v6, v8, Lcom/tencent/tinker/lib/service/PatchResult;->costTime:J
iput-object v0, v8, Lcom/tencent/tinker/lib/service/PatchResult;->e:Ljava/lang/Throwable;
invoke-static {p1}, Lcom/tencent/tinker/lib/service/TinkerPatchService;->getPatchResultExtra(Landroid/content/Intent;)Ljava/lang/String;
move-result-object v0
invoke-static {p0, v8, v0}, Lcom/tencent/tinker/lib/service/AbstractResultService;->runResultService(Landroid/content/Context;Lcom/tencent/tinker/lib/service/PatchResult;Ljava/lang/String;)V
sget-object v0, Lcom/tencent/tinker/lib/service/TinkerPatchService;->sIsPatchApplying:Ljava/util/concurrent/atomic/AtomicBoolean;
invoke-virtual {v0, v2}, Ljava/util/concurrent/atomic/AtomicBoolean;->set(Z)V
goto :goto_15
:cond_88
:try_start_88
sget-object v1, Lcom/tencent/tinker/lib/service/TinkerPatchService;->upgradePatchProcessor:Lcom/tencent/tinker/lib/patch/AbstractPatch;
invoke-virtual {v1, p0, v4, v8}, Lcom/tencent/tinker/lib/patch/AbstractPatch;->tryPatch(Landroid/content/Context;Ljava/lang/String;Lcom/tencent/tinker/lib/service/PatchResult;)Z
:try_end_8d
.catch Ljava/lang/Throwable; {:try_start_88 .. :try_end_8d} :catch_5d
move-result v1
goto :goto_66
.end method
.method public static getExpectedRealRunnerClass()Ljava/lang/Class;
.registers 2
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/lang/Class",
"<+",
"Landroid/app/Service;",
">;"
}
.end annotation
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v1, 0x1a
if-ge v0, v1, :cond_9
const-class v0, Lcom/tencent/tinker/lib/service/TinkerPatchService$IntentServiceRunner;
:goto_8
return-object v0
:cond_9
const-class v0, Lcom/tencent/tinker/lib/service/TinkerPatchService$JobServiceRunner;
goto :goto_8
.end method
.method public static getPatchPathExtra(Landroid/content/Intent;)Ljava/lang/String;
.registers 3
if-nez p0, :cond_b
new-instance v0, Lcom/tencent/tinker/loader/TinkerRuntimeException;
const-string/jumbo v1, "getPatchPathExtra, but intent is null"
invoke-direct {v0, v1}, Lcom/tencent/tinker/loader/TinkerRuntimeException;-><init>(Ljava/lang/String;)V
throw v0
:cond_b
const-string/jumbo v0, "patch_path_extra"
invoke-static {p0, v0}, Lcom/tencent/tinker/loader/shareutil/ShareIntentUtil;->getStringExtra(Landroid/content/Intent;Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public static getPatchResultExtra(Landroid/content/Intent;)Ljava/lang/String;
.registers 3
if-nez p0, :cond_b
new-instance v0, Lcom/tencent/tinker/loader/TinkerRuntimeException;
const-string/jumbo v1, "getPatchResultExtra, but intent is null"
invoke-direct {v0, v1}, Lcom/tencent/tinker/loader/TinkerRuntimeException;-><init>(Ljava/lang/String;)V
throw v0
:cond_b
const-string/jumbo v0, "patch_result_class"
invoke-static {p0, v0}, Lcom/tencent/tinker/loader/shareutil/ShareIntentUtil;->getStringExtra(Landroid/content/Intent;Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public static runPatchService(Landroid/content/Context;Ljava/lang/String;)V
.registers 8
:try_start_0
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v1, 0x1a
if-ge v0, v1, :cond_a
invoke-static {p0, p1}, Lcom/tencent/tinker/lib/service/TinkerPatchService;->runPatchServiceByIntentService(Landroid/content/Context;Ljava/lang/String;)V
:try_end_9
.catch Ljava/lang/Throwable; {:try_start_0 .. :try_end_9} :catch_20
:goto_9
return-void
:cond_a
:try_start_a
invoke-static {p0, p1}, Lcom/tencent/tinker/lib/service/TinkerPatchService;->runPatchServiceByJobScheduler(Landroid/content/Context;Ljava/lang/String;)Z
:try_end_d
.catch Ljava/lang/Throwable; {:try_start_a .. :try_end_d} :catch_3f
:goto_d
:try_start_d
sget-object v0, Lcom/tencent/tinker/lib/service/TinkerPatchService;->mHandler:Landroid/os/Handler;
new-instance v1, Lcom/tencent/tinker/lib/service/TinkerPatchService$1;
invoke-direct {v1, p0, p1}, Lcom/tencent/tinker/lib/service/TinkerPatchService$1;-><init>(Landroid/content/Context;Ljava/lang/String;)V
sget-object v2, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;
const-wide/16 v4, 0x5
invoke-virtual {v2, v4, v5}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J
move-result-wide v2
invoke-virtual {v0, v1, v2, v3}, Landroid/os/Handler;->postDelayed(Ljava/lang/Runnable;J)Z
:try_end_1f
.catch Ljava/lang/Throwable; {:try_start_d .. :try_end_1f} :catch_20
goto :goto_9
:catch_20
move-exception v0
const-string/jumbo v1, "Tinker.TinkerPatchService"
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v3, "start patch service fail, exception:"
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
const/4 v2, 0x0
new-array v2, v2, [Ljava/lang/Object;
invoke-static {v1, v0, v2}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_9
:catch_3f
move-exception v0
goto :goto_d
.end method
.method private static runPatchServiceByIntentService(Landroid/content/Context;Ljava/lang/String;)V
.registers 5
const-string/jumbo v0, "Tinker.TinkerPatchService"
const-string/jumbo v1, "run patch service by intent service."
const/4 v2, 0x0
new-array v2, v2, [Ljava/lang/Object;
invoke-static {v0, v1, v2}, Lcom/tencent/tinker/lib/util/TinkerLog;->i(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
new-instance v0, Landroid/content/Intent;
const-class v1, Lcom/tencent/tinker/lib/service/TinkerPatchService$IntentServiceRunner;
invoke-direct {v0, p0, v1}, Landroid/content/Intent;-><init>(Landroid/content/Context;Ljava/lang/Class;)V
const-string/jumbo v1, "patch_path_extra"
invoke-virtual {v0, v1, p1}, Landroid/content/Intent;->putExtra(Ljava/lang/String;Ljava/lang/String;)Landroid/content/Intent;
const-string/jumbo v1, "patch_result_class"
sget-object v2, Lcom/tencent/tinker/lib/service/TinkerPatchService;->resultServiceClass:Ljava/lang/Class;
invoke-virtual {v2}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v2
invoke-virtual {v0, v1, v2}, Landroid/content/Intent;->putExtra(Ljava/lang/String;Ljava/lang/String;)Landroid/content/Intent;
invoke-virtual {p0, v0}, Landroid/content/Context;->startService(Landroid/content/Intent;)Landroid/content/ComponentName;
return-void
.end method
.method private static runPatchServiceByJobScheduler(Landroid/content/Context;Ljava/lang/String;)Z
.registers 8
.annotation build Landroid/annotation/TargetApi;
value = 0x15
.end annotation
const/4 v1, 0x1
const/4 v2, 0x0
const-string/jumbo v0, "Tinker.TinkerPatchService"
const-string/jumbo v3, "run patch service by job scheduler."
new-array v4, v2, [Ljava/lang/Object;
invoke-static {v0, v3, v4}, Lcom/tencent/tinker/lib/util/TinkerLog;->i(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
new-instance v3, Landroid/app/job/JobInfo$Builder;
new-instance v0, Landroid/content/ComponentName;
const-class v4, Lcom/tencent/tinker/lib/service/TinkerPatchService$JobServiceRunner;
invoke-direct {v0, p0, v4}, Landroid/content/ComponentName;-><init>(Landroid/content/Context;Ljava/lang/Class;)V
invoke-direct {v3, v1, v0}, Landroid/app/job/JobInfo$Builder;-><init>(ILandroid/content/ComponentName;)V
new-instance v0, Landroid/os/PersistableBundle;
invoke-direct {v0}, Landroid/os/PersistableBundle;-><init>()V
const-string/jumbo v4, "patch_path_extra"
invoke-virtual {v0, v4, p1}, Landroid/os/PersistableBundle;->putString(Ljava/lang/String;Ljava/lang/String;)V
const-string/jumbo v4, "patch_result_class"
sget-object v5, Lcom/tencent/tinker/lib/service/TinkerPatchService;->resultServiceClass:Ljava/lang/Class;
invoke-virtual {v5}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v5
invoke-virtual {v0, v4, v5}, Landroid/os/PersistableBundle;->putString(Ljava/lang/String;Ljava/lang/String;)V
invoke-virtual {v3, v0}, Landroid/app/job/JobInfo$Builder;->setExtras(Landroid/os/PersistableBundle;)Landroid/app/job/JobInfo$Builder;
const-wide/16 v4, 0x5
invoke-virtual {v3, v4, v5}, Landroid/app/job/JobInfo$Builder;->setOverrideDeadline(J)Landroid/app/job/JobInfo$Builder;
const-string/jumbo 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;
if-nez v0, :cond_4f
const-string/jumbo v0, "Tinker.TinkerPatchService"
const-string/jumbo v1, "jobScheduler is null."
new-array v3, v2, [Ljava/lang/Object;
invoke-static {v0, v1, v3}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
:goto_4e
return v2
:cond_4f
invoke-virtual {v3}, Landroid/app/job/JobInfo$Builder;->build()Landroid/app/job/JobInfo;
move-result-object v3
invoke-virtual {v0, v3}, Landroid/app/job/JobScheduler;->schedule(Landroid/app/job/JobInfo;)I
move-result v0
if-ne v0, v1, :cond_5c
move v0, v1
:goto_5a
move v2, v0
goto :goto_4e
:cond_5c
move v0, v2
goto :goto_5a
.end method
.method public static setPatchProcessor(Lcom/tencent/tinker/lib/patch/AbstractPatch;Ljava/lang/Class;)V
.registers 3
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lcom/tencent/tinker/lib/patch/AbstractPatch;",
"Ljava/lang/Class",
"<+",
"Lcom/tencent/tinker/lib/service/AbstractResultService;",
">;)V"
}
.end annotation
sput-object p0, Lcom/tencent/tinker/lib/service/TinkerPatchService;->upgradePatchProcessor:Lcom/tencent/tinker/lib/patch/AbstractPatch;
sput-object p1, Lcom/tencent/tinker/lib/service/TinkerPatchService;->resultServiceClass:Ljava/lang/Class;
:try_start_4
invoke-virtual {p1}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Ljava/lang/Class;->forName(Ljava/lang/String;)Ljava/lang/Class;
:try_end_b
.catch Ljava/lang/ClassNotFoundException; {:try_start_4 .. :try_end_b} :catch_c
:goto_b
return-void
:catch_c
move-exception v0
goto :goto_b
.end method
.method public static setTinkerNotificationId(I)V
.registers 1
sput p0, Lcom/tencent/tinker/lib/service/TinkerPatchService;->notificationId:I
return-void
.end method