UpgradePatch.smali
.class public Lcom/tencent/tinker/lib/patch/UpgradePatch;
.super Lcom/tencent/tinker/lib/patch/AbstractPatch;
# static fields
.field private static final TAG:Ljava/lang/String; = "Tinker.UpgradePatch"
# direct methods
.method public constructor <init>()V
.registers 1
invoke-direct {p0}, Lcom/tencent/tinker/lib/patch/AbstractPatch;-><init>()V
return-void
.end method
# virtual methods
.method public tryPatch(Landroid/content/Context;Ljava/lang/String;Lcom/tencent/tinker/lib/service/PatchResult;)Z
.registers 20
invoke-static/range {p1 .. p1}, Lcom/tencent/tinker/lib/tinker/Tinker;->with(Landroid/content/Context;)Lcom/tencent/tinker/lib/tinker/Tinker;
move-result-object v4
new-instance v5, Ljava/io/File;
move-object/from16 v0, p2
invoke-direct {v5, v0}, Ljava/io/File;-><init>(Ljava/lang/String;)V
invoke-virtual {v4}, Lcom/tencent/tinker/lib/tinker/Tinker;->isTinkerEnabled()Z
move-result v2
if-eqz v2, :cond_17
invoke-static/range {p1 .. p1}, Lcom/tencent/tinker/loader/shareutil/ShareTinkerInternals;->isTinkerEnableWithSharedPreferences(Landroid/content/Context;)Z
move-result v2
if-nez v2, :cond_25
:cond_17
const-string/jumbo v2, "Tinker.UpgradePatch"
const-string/jumbo v3, "UpgradePatch tryPatch:patch is disabled, just return"
const/4 v4, 0x0
new-array v4, v4, [Ljava/lang/Object;
invoke-static {v2, v3, v4}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
const/4 v2, 0x0
:goto_24
return v2
:cond_25
invoke-static {v5}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->isLegalFile(Ljava/io/File;)Z
move-result v2
if-nez v2, :cond_39
const-string/jumbo v2, "Tinker.UpgradePatch"
const-string/jumbo v3, "UpgradePatch tryPatch:patch file is not found, just return"
const/4 v4, 0x0
new-array v4, v4, [Ljava/lang/Object;
invoke-static {v2, v3, v4}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
const/4 v2, 0x0
goto :goto_24
:cond_39
new-instance v6, Lcom/tencent/tinker/loader/shareutil/ShareSecurityCheck;
move-object/from16 v0, p1
invoke-direct {v6, v0}, Lcom/tencent/tinker/loader/shareutil/ShareSecurityCheck;-><init>(Landroid/content/Context;)V
invoke-virtual {v4}, Lcom/tencent/tinker/lib/tinker/Tinker;->getTinkerFlags()I
move-result v2
move-object/from16 v0, p1
invoke-static {v0, v2, v5, v6}, Lcom/tencent/tinker/loader/shareutil/ShareTinkerInternals;->checkTinkerPackage(Landroid/content/Context;ILjava/io/File;Lcom/tencent/tinker/loader/shareutil/ShareSecurityCheck;)I
move-result v2
if-eqz v2, :cond_61
const-string/jumbo v3, "Tinker.UpgradePatch"
const-string/jumbo v6, "UpgradePatch tryPatch:onPatchPackageCheckFail"
const/4 v7, 0x0
new-array v7, v7, [Ljava/lang/Object;
invoke-static {v3, v6, v7}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v4}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v3
invoke-interface {v3, v5, v2}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchPackageCheckFail(Ljava/io/File;I)V
const/4 v2, 0x0
goto :goto_24
:cond_61
invoke-static {v5}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->getMD5(Ljava/io/File;)Ljava/lang/String;
move-result-object v7
if-nez v7, :cond_75
const-string/jumbo v2, "Tinker.UpgradePatch"
const-string/jumbo v3, "UpgradePatch tryPatch:patch md5 is null, just return"
const/4 v4, 0x0
new-array v4, v4, [Ljava/lang/Object;
invoke-static {v2, v3, v4}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
const/4 v2, 0x0
goto :goto_24
:cond_75
move-object/from16 v0, p3
iput-object v7, v0, Lcom/tencent/tinker/lib/service/PatchResult;->patchVersion:Ljava/lang/String;
const-string/jumbo v2, "Tinker.UpgradePatch"
const-string/jumbo v3, "UpgradePatch tryPatch:patchMd5:%s"
const/4 v8, 0x1
new-array v8, v8, [Ljava/lang/Object;
const/4 v9, 0x0
aput-object v7, v8, v9
invoke-static {v2, v3, v8}, Lcom/tencent/tinker/lib/util/TinkerLog;->i(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v4}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchDirectory()Ljava/io/File;
move-result-object v2
invoke-virtual {v2}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v8
invoke-static {v8}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->getPatchInfoLockFile(Ljava/lang/String;)Ljava/io/File;
move-result-object v9
invoke-static {v8}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->getPatchInfoFile(Ljava/lang/String;)Ljava/io/File;
move-result-object v10
invoke-static {v10, v9}, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->readAndCheckPropertyWithLock(Ljava/io/File;Ljava/io/File;)Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;
move-result-object v11
if-eqz v11, :cond_19f
iget-object v2, v11, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->oldVersion:Ljava/lang/String;
if-eqz v2, :cond_aa
iget-object v2, v11, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->newVersion:Ljava/lang/String;
if-eqz v2, :cond_aa
iget-object v2, v11, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->oatDir:Ljava/lang/String;
if-nez v2, :cond_c4
:cond_aa
const-string/jumbo v2, "Tinker.UpgradePatch"
const-string/jumbo v3, "UpgradePatch tryPatch:onPatchInfoCorrupted"
const/4 v6, 0x0
new-array v6, v6, [Ljava/lang/Object;
invoke-static {v2, v3, v6}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v4}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v2
iget-object v3, v11, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->oldVersion:Ljava/lang/String;
iget-object v4, v11, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->newVersion:Ljava/lang/String;
invoke-interface {v2, v5, v3, v4}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchInfoCorrupted(Ljava/io/File;Ljava/lang/String;Ljava/lang/String;)V
const/4 v2, 0x0
goto/16 :goto_24
:cond_c4
invoke-static {v7}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->checkIfMd5Valid(Ljava/lang/String;)Z
move-result v2
if-nez v2, :cond_e3
const-string/jumbo v2, "Tinker.UpgradePatch"
const-string/jumbo v3, "UpgradePatch tryPatch:onPatchVersionCheckFail md5 %s is valid"
const/4 v6, 0x1
new-array v6, v6, [Ljava/lang/Object;
const/4 v8, 0x0
aput-object v7, v6, v8
invoke-static {v2, v3, v6}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v4}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v2
invoke-interface {v2, v5, v11, v7}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchVersionCheckFail(Ljava/io/File;Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;Ljava/lang/String;)V
const/4 v2, 0x0
goto/16 :goto_24
:cond_e3
iget-object v2, v11, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->oatDir:Ljava/lang/String;
const-string/jumbo v3, "interpet"
invoke-virtual {v2, v3}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v2
if-eqz v2, :cond_19b
const-string/jumbo v2, "changing"
:goto_f1
new-instance v3, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;
iget-object v11, v11, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->oldVersion:Ljava/lang/String;
sget-object v12, Landroid/os/Build;->FINGERPRINT:Ljava/lang/String;
invoke-direct {v3, v11, v7, v12, v2}, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;-><init>(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
move-object v2, v3
:goto_fb
invoke-static {v7}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->getPatchVersionDirectory(Ljava/lang/String;)Ljava/lang/String;
move-result-object v3
new-instance v11, Ljava/lang/StringBuilder;
invoke-direct {v11}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v11, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v8
const-string/jumbo v11, "/"
invoke-virtual {v8, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v8
invoke-virtual {v8, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
const-string/jumbo v8, "Tinker.UpgradePatch"
const-string/jumbo v11, "UpgradePatch tryPatch:patchVersionDirectory:%s"
const/4 v12, 0x1
new-array v12, v12, [Ljava/lang/Object;
const/4 v13, 0x0
aput-object v3, v12, v13
invoke-static {v8, v11, v12}, Lcom/tencent/tinker/lib/util/TinkerLog;->i(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
new-instance v8, Ljava/io/File;
new-instance v11, Ljava/lang/StringBuilder;
invoke-direct {v11}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v11, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v11
const-string/jumbo v12, "/"
invoke-virtual {v11, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v11
invoke-static {v7}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->getPatchVersionFile(Ljava/lang/String;)Ljava/lang/String;
move-result-object v12
invoke-virtual {v11, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v11
invoke-virtual {v11}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v11
invoke-direct {v8, v11}, Ljava/io/File;-><init>(Ljava/lang/String;)V
:try_start_147
invoke-static {v8}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->getMD5(Ljava/io/File;)Ljava/lang/String;
move-result-object v11
invoke-virtual {v7, v11}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v7
if-nez v7, :cond_184
invoke-static {v5, v8}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->copyFileUsingStream(Ljava/io/File;Ljava/io/File;)V
const-string/jumbo v7, "Tinker.UpgradePatch"
const-string/jumbo v11, "UpgradePatch copy patch file, src file: %s size: %d, dest file: %s size:%d"
const/4 v12, 0x4
new-array v12, v12, [Ljava/lang/Object;
const/4 v13, 0x0
invoke-virtual {v5}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v14
aput-object v14, v12, v13
const/4 v13, 0x1
invoke-virtual {v5}, Ljava/io/File;->length()J
move-result-wide v14
invoke-static {v14, v15}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v14
aput-object v14, v12, v13
const/4 v13, 0x2
invoke-virtual {v8}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v14
aput-object v14, v12, v13
const/4 v13, 0x3
invoke-virtual {v8}, Ljava/io/File;->length()J
move-result-wide v14
invoke-static {v14, v15}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v14
aput-object v14, v12, v13
invoke-static {v7, v11, v12}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
:try_end_184
.catch Ljava/io/IOException; {:try_start_147 .. :try_end_184} :catch_1ae
:cond_184
move-object/from16 v0, p1
invoke-static {v4, v6, v0, v3, v8}, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->tryRecoverDexFiles(Lcom/tencent/tinker/lib/tinker/Tinker;Lcom/tencent/tinker/loader/shareutil/ShareSecurityCheck;Landroid/content/Context;Ljava/lang/String;Ljava/io/File;)Z
move-result v7
if-nez v7, :cond_1d8
const-string/jumbo v2, "Tinker.UpgradePatch"
const-string/jumbo v3, "UpgradePatch tryPatch:new patch recover, try patch dex failed"
const/4 v4, 0x0
new-array v4, v4, [Ljava/lang/Object;
invoke-static {v2, v3, v4}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
const/4 v2, 0x0
goto/16 :goto_24
:cond_19b
iget-object v2, v11, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->oatDir:Ljava/lang/String;
goto/16 :goto_f1
:cond_19f
new-instance v2, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;
const-string/jumbo v3, ""
sget-object v11, Landroid/os/Build;->FINGERPRINT:Ljava/lang/String;
const-string/jumbo v12, "odex"
invoke-direct {v2, v3, v7, v11, v12}, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;-><init>(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
goto/16 :goto_fb
:catch_1ae
move-exception v2
const-string/jumbo v2, "Tinker.UpgradePatch"
const-string/jumbo v3, "UpgradePatch tryPatch:copy patch file fail from %s to %s"
const/4 v6, 0x2
new-array v6, v6, [Ljava/lang/Object;
const/4 v7, 0x0
invoke-virtual {v5}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v9
aput-object v9, v6, v7
const/4 v7, 0x1
invoke-virtual {v8}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v9
aput-object v9, v6, v7
invoke-static {v2, v3, v6}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v4}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v2
invoke-virtual {v5}, Ljava/io/File;->getName()Ljava/lang/String;
move-result-object v3
const/4 v4, 0x1
invoke-interface {v2, v5, v8, v3, v4}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchTypeExtractFail(Ljava/io/File;Ljava/io/File;Ljava/lang/String;I)V
const/4 v2, 0x0
goto/16 :goto_24
:cond_1d8
move-object/from16 v0, p1
invoke-static {v4, v6, v0, v3, v8}, Lcom/tencent/tinker/lib/patch/BsDiffPatchInternal;->tryRecoverLibraryFiles(Lcom/tencent/tinker/lib/tinker/Tinker;Lcom/tencent/tinker/loader/shareutil/ShareSecurityCheck;Landroid/content/Context;Ljava/lang/String;Ljava/io/File;)Z
move-result v7
if-nez v7, :cond_1ef
const-string/jumbo v2, "Tinker.UpgradePatch"
const-string/jumbo v3, "UpgradePatch tryPatch:new patch recover, try patch library failed"
const/4 v4, 0x0
new-array v4, v4, [Ljava/lang/Object;
invoke-static {v2, v3, v4}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
const/4 v2, 0x0
goto/16 :goto_24
:cond_1ef
move-object/from16 v0, p1
invoke-static {v4, v6, v0, v3, v8}, Lcom/tencent/tinker/lib/patch/ResDiffPatchInternal;->tryRecoverResourceFiles(Lcom/tencent/tinker/lib/tinker/Tinker;Lcom/tencent/tinker/loader/shareutil/ShareSecurityCheck;Landroid/content/Context;Ljava/lang/String;Ljava/io/File;)Z
move-result v3
if-nez v3, :cond_206
const-string/jumbo v2, "Tinker.UpgradePatch"
const-string/jumbo v3, "UpgradePatch tryPatch:new patch recover, try patch resource failed"
const/4 v4, 0x0
new-array v4, v4, [Ljava/lang/Object;
invoke-static {v2, v3, v4}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
const/4 v2, 0x0
goto/16 :goto_24
:cond_206
invoke-static {v5, v4}, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->waitAndCheckDexOptFile(Ljava/io/File;Lcom/tencent/tinker/lib/tinker/Tinker;)Z
move-result v3
if-nez v3, :cond_21b
const-string/jumbo v2, "Tinker.UpgradePatch"
const-string/jumbo v3, "UpgradePatch tryPatch:new patch recover, check dex opt file failed"
const/4 v4, 0x0
new-array v4, v4, [Ljava/lang/Object;
invoke-static {v2, v3, v4}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
const/4 v2, 0x0
goto/16 :goto_24
:cond_21b
invoke-static {v10, v2, v9}, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->rewritePatchInfoFileWithLock(Ljava/io/File;Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;Ljava/io/File;)Z
move-result v3
if-nez v3, :cond_23b
const-string/jumbo v3, "Tinker.UpgradePatch"
const-string/jumbo v6, "UpgradePatch tryPatch:new patch recover, rewrite patch info failed"
const/4 v7, 0x0
new-array v7, v7, [Ljava/lang/Object;
invoke-static {v3, v6, v7}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v4}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v3
iget-object v4, v2, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->oldVersion:Ljava/lang/String;
iget-object v2, v2, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->newVersion:Ljava/lang/String;
invoke-interface {v3, v5, v4, v2}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchInfoCorrupted(Ljava/io/File;Ljava/lang/String;Ljava/lang/String;)V
const/4 v2, 0x0
goto/16 :goto_24
:cond_23b
const-string/jumbo v2, "Tinker.UpgradePatch"
const-string/jumbo v3, "UpgradePatch tryPatch: done, it is ok"
const/4 v4, 0x0
new-array v4, v4, [Ljava/lang/Object;
invoke-static {v2, v3, v4}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
const/4 v2, 0x1
goto/16 :goto_24
.end method