- Imported from https://github.com/supermegamestre/Project-Real-Resurrection-3 - APKTool decompilation (Smali bytecode) for modding and rebuilding APK - Supports both 32-bit (armeabi-v7a) and 64-bit (arm64-v8a) architectures - Includes full Smali source, resources, and native libraries - Ready to rebuild APK after modifications with apktool b command - Added comprehensive README-apktool.md with modding guide This branch complements the JADX branches: - Use JADX (main/discord-community) to UNDERSTAND code (readable Java) - Use APKTool (this branch) to MODIFY and REBUILD APK (editable Smali) Total: 44,417 files, 538.51 MB Smali source code
501 lines
14 KiB
Smali
501 lines
14 KiB
Smali
.class Landroidx/biometric/CryptoObjectUtils;
|
|
.super Ljava/lang/Object;
|
|
.source "SourceFile"
|
|
|
|
|
|
# annotations
|
|
.annotation system Ldalvik/annotation/MemberClasses;
|
|
value = {
|
|
Landroidx/biometric/CryptoObjectUtils$Api23Impl;,
|
|
Landroidx/biometric/CryptoObjectUtils$Api28Impl;,
|
|
Landroidx/biometric/CryptoObjectUtils$Api30Impl;
|
|
}
|
|
.end annotation
|
|
|
|
|
|
# static fields
|
|
.field private static final FAKE_KEY_NAME:Ljava/lang/String; = "androidxBiometric"
|
|
|
|
.field private static final KEYSTORE_INSTANCE:Ljava/lang/String; = "AndroidKeyStore"
|
|
|
|
.field private static final TAG:Ljava/lang/String; = "CryptoObjectUtils"
|
|
|
|
|
|
# direct methods
|
|
.method private constructor <init>()V
|
|
.locals 0
|
|
|
|
.line 64
|
|
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public static createFakeCryptoObject()Landroidx/biometric/BiometricPrompt$CryptoObject;
|
|
.locals 6
|
|
.annotation build Landroidx/annotation/Nullable;
|
|
.end annotation
|
|
|
|
.annotation build Landroidx/annotation/RequiresApi;
|
|
value = 0x17
|
|
.end annotation
|
|
|
|
const-string v0, "androidxBiometric"
|
|
|
|
const-string v1, "AndroidKeyStore"
|
|
|
|
const/4 v2, 0x0
|
|
|
|
.line 242
|
|
:try_start_0
|
|
invoke-static {v1}, Ljava/security/KeyStore;->getInstance(Ljava/lang/String;)Ljava/security/KeyStore;
|
|
|
|
move-result-object v3
|
|
|
|
.line 243
|
|
invoke-virtual {v3, v2}, Ljava/security/KeyStore;->load(Ljava/security/KeyStore$LoadStoreParameter;)V
|
|
|
|
const/4 v4, 0x3
|
|
|
|
.line 246
|
|
invoke-static {v0, v4}, Landroidx/biometric/CryptoObjectUtils$Api23Impl;->createKeyGenParameterSpecBuilder(Ljava/lang/String;I)Landroid/security/keystore/KeyGenParameterSpec$Builder;
|
|
|
|
move-result-object v4
|
|
|
|
.line 249
|
|
invoke-static {v4}, Landroidx/biometric/CryptoObjectUtils$Api23Impl;->setBlockModeCBC(Landroid/security/keystore/KeyGenParameterSpec$Builder;)V
|
|
|
|
.line 250
|
|
invoke-static {v4}, Landroidx/biometric/CryptoObjectUtils$Api23Impl;->setEncryptionPaddingPKCS7(Landroid/security/keystore/KeyGenParameterSpec$Builder;)V
|
|
|
|
const-string v5, "AES"
|
|
|
|
.line 253
|
|
invoke-static {v5, v1}, Ljavax/crypto/KeyGenerator;->getInstance(Ljava/lang/String;Ljava/lang/String;)Ljavax/crypto/KeyGenerator;
|
|
|
|
move-result-object v1
|
|
|
|
.line 254
|
|
invoke-static {v4}, Landroidx/biometric/CryptoObjectUtils$Api23Impl;->buildKeyGenParameterSpec(Landroid/security/keystore/KeyGenParameterSpec$Builder;)Landroid/security/keystore/KeyGenParameterSpec;
|
|
|
|
move-result-object v4
|
|
|
|
.line 255
|
|
invoke-static {v1, v4}, Landroidx/biometric/CryptoObjectUtils$Api23Impl;->initKeyGenerator(Ljavax/crypto/KeyGenerator;Landroid/security/keystore/KeyGenParameterSpec;)V
|
|
|
|
.line 256
|
|
invoke-virtual {v1}, Ljavax/crypto/KeyGenerator;->generateKey()Ljavax/crypto/SecretKey;
|
|
|
|
.line 259
|
|
invoke-virtual {v3, v0, v2}, Ljava/security/KeyStore;->getKey(Ljava/lang/String;[C)Ljava/security/Key;
|
|
|
|
move-result-object v0
|
|
|
|
check-cast v0, Ljavax/crypto/SecretKey;
|
|
|
|
const-string v1, "AES/CBC/PKCS7Padding"
|
|
|
|
.line 260
|
|
invoke-static {v1}, Ljavax/crypto/Cipher;->getInstance(Ljava/lang/String;)Ljavax/crypto/Cipher;
|
|
|
|
move-result-object v1
|
|
|
|
const/4 v3, 0x1
|
|
|
|
.line 263
|
|
invoke-virtual {v1, v3, v0}, Ljavax/crypto/Cipher;->init(ILjava/security/Key;)V
|
|
|
|
.line 265
|
|
new-instance v0, Landroidx/biometric/BiometricPrompt$CryptoObject;
|
|
|
|
invoke-direct {v0, v1}, Landroidx/biometric/BiometricPrompt$CryptoObject;-><init>(Ljavax/crypto/Cipher;)V
|
|
:try_end_0
|
|
.catch Ljavax/crypto/NoSuchPaddingException; {:try_start_0 .. :try_end_0} :catch_8
|
|
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_0 .. :try_end_0} :catch_7
|
|
.catch Ljava/security/cert/CertificateException; {:try_start_0 .. :try_end_0} :catch_6
|
|
.catch Ljava/security/KeyStoreException; {:try_start_0 .. :try_end_0} :catch_5
|
|
.catch Ljava/security/InvalidKeyException; {:try_start_0 .. :try_end_0} :catch_4
|
|
.catch Ljava/security/InvalidAlgorithmParameterException; {:try_start_0 .. :try_end_0} :catch_3
|
|
.catch Ljava/security/UnrecoverableKeyException; {:try_start_0 .. :try_end_0} :catch_2
|
|
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_1
|
|
.catch Ljava/security/NoSuchProviderException; {:try_start_0 .. :try_end_0} :catch_0
|
|
|
|
return-object v0
|
|
|
|
:catch_0
|
|
move-exception v0
|
|
|
|
goto :goto_0
|
|
|
|
:catch_1
|
|
move-exception v0
|
|
|
|
goto :goto_0
|
|
|
|
:catch_2
|
|
move-exception v0
|
|
|
|
goto :goto_0
|
|
|
|
:catch_3
|
|
move-exception v0
|
|
|
|
goto :goto_0
|
|
|
|
:catch_4
|
|
move-exception v0
|
|
|
|
goto :goto_0
|
|
|
|
:catch_5
|
|
move-exception v0
|
|
|
|
goto :goto_0
|
|
|
|
:catch_6
|
|
move-exception v0
|
|
|
|
goto :goto_0
|
|
|
|
:catch_7
|
|
move-exception v0
|
|
|
|
goto :goto_0
|
|
|
|
:catch_8
|
|
move-exception v0
|
|
|
|
:goto_0
|
|
const-string v1, "CryptoObjectUtils"
|
|
|
|
const-string v3, "Failed to create fake crypto object."
|
|
|
|
.line 269
|
|
invoke-static {v1, v3, v0}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
|
|
|
|
return-object v2
|
|
.end method
|
|
|
|
.method public static unwrapFromBiometricPrompt(Landroid/hardware/biometrics/BiometricPrompt$CryptoObject;)Landroidx/biometric/BiometricPrompt$CryptoObject;
|
|
.locals 3
|
|
.param p0 # Landroid/hardware/biometrics/BiometricPrompt$CryptoObject;
|
|
.annotation build Landroidx/annotation/Nullable;
|
|
.end annotation
|
|
.end param
|
|
.annotation build Landroidx/annotation/Nullable;
|
|
.end annotation
|
|
|
|
.annotation build Landroidx/annotation/RequiresApi;
|
|
value = 0x1c
|
|
.end annotation
|
|
|
|
const/4 v0, 0x0
|
|
|
|
if-nez p0, :cond_0
|
|
|
|
return-object v0
|
|
|
|
.line 81
|
|
:cond_0
|
|
invoke-static {p0}, Landroidx/biometric/CryptoObjectUtils$Api28Impl;->getCipher(Landroid/hardware/biometrics/BiometricPrompt$CryptoObject;)Ljavax/crypto/Cipher;
|
|
|
|
move-result-object v1
|
|
|
|
if-eqz v1, :cond_1
|
|
|
|
.line 83
|
|
new-instance p0, Landroidx/biometric/BiometricPrompt$CryptoObject;
|
|
|
|
invoke-direct {p0, v1}, Landroidx/biometric/BiometricPrompt$CryptoObject;-><init>(Ljavax/crypto/Cipher;)V
|
|
|
|
return-object p0
|
|
|
|
.line 86
|
|
:cond_1
|
|
invoke-static {p0}, Landroidx/biometric/CryptoObjectUtils$Api28Impl;->getSignature(Landroid/hardware/biometrics/BiometricPrompt$CryptoObject;)Ljava/security/Signature;
|
|
|
|
move-result-object v1
|
|
|
|
if-eqz v1, :cond_2
|
|
|
|
.line 88
|
|
new-instance p0, Landroidx/biometric/BiometricPrompt$CryptoObject;
|
|
|
|
invoke-direct {p0, v1}, Landroidx/biometric/BiometricPrompt$CryptoObject;-><init>(Ljava/security/Signature;)V
|
|
|
|
return-object p0
|
|
|
|
.line 91
|
|
:cond_2
|
|
invoke-static {p0}, Landroidx/biometric/CryptoObjectUtils$Api28Impl;->getMac(Landroid/hardware/biometrics/BiometricPrompt$CryptoObject;)Ljavax/crypto/Mac;
|
|
|
|
move-result-object v1
|
|
|
|
if-eqz v1, :cond_3
|
|
|
|
.line 93
|
|
new-instance p0, Landroidx/biometric/BiometricPrompt$CryptoObject;
|
|
|
|
invoke-direct {p0, v1}, Landroidx/biometric/BiometricPrompt$CryptoObject;-><init>(Ljavax/crypto/Mac;)V
|
|
|
|
return-object p0
|
|
|
|
:cond_3
|
|
sget v1, Landroid/os/Build$VERSION;->SDK_INT:I
|
|
|
|
const/16 v2, 0x1e
|
|
|
|
if-lt v1, v2, :cond_4
|
|
|
|
.line 99
|
|
invoke-static {p0}, Landroidx/biometric/CryptoObjectUtils$Api30Impl;->getIdentityCredential(Landroid/hardware/biometrics/BiometricPrompt$CryptoObject;)Landroid/security/identity/IdentityCredential;
|
|
|
|
move-result-object p0
|
|
|
|
if-eqz p0, :cond_4
|
|
|
|
.line 101
|
|
new-instance v0, Landroidx/biometric/BiometricPrompt$CryptoObject;
|
|
|
|
invoke-direct {v0, p0}, Landroidx/biometric/BiometricPrompt$CryptoObject;-><init>(Landroid/security/identity/IdentityCredential;)V
|
|
|
|
:cond_4
|
|
return-object v0
|
|
.end method
|
|
|
|
.method public static unwrapFromFingerprintManager(Landroidx/core/hardware/fingerprint/FingerprintManagerCompat$CryptoObject;)Landroidx/biometric/BiometricPrompt$CryptoObject;
|
|
.locals 2
|
|
.param p0 # Landroidx/core/hardware/fingerprint/FingerprintManagerCompat$CryptoObject;
|
|
.annotation build Landroidx/annotation/Nullable;
|
|
.end annotation
|
|
.end param
|
|
.annotation build Landroidx/annotation/Nullable;
|
|
.end annotation
|
|
|
|
const/4 v0, 0x0
|
|
|
|
if-nez p0, :cond_0
|
|
|
|
return-object v0
|
|
|
|
.line 169
|
|
:cond_0
|
|
invoke-virtual {p0}, Landroidx/core/hardware/fingerprint/FingerprintManagerCompat$CryptoObject;->getCipher()Ljavax/crypto/Cipher;
|
|
|
|
move-result-object v1
|
|
|
|
if-eqz v1, :cond_1
|
|
|
|
.line 171
|
|
new-instance p0, Landroidx/biometric/BiometricPrompt$CryptoObject;
|
|
|
|
invoke-direct {p0, v1}, Landroidx/biometric/BiometricPrompt$CryptoObject;-><init>(Ljavax/crypto/Cipher;)V
|
|
|
|
return-object p0
|
|
|
|
.line 174
|
|
:cond_1
|
|
invoke-virtual {p0}, Landroidx/core/hardware/fingerprint/FingerprintManagerCompat$CryptoObject;->getSignature()Ljava/security/Signature;
|
|
|
|
move-result-object v1
|
|
|
|
if-eqz v1, :cond_2
|
|
|
|
.line 176
|
|
new-instance p0, Landroidx/biometric/BiometricPrompt$CryptoObject;
|
|
|
|
invoke-direct {p0, v1}, Landroidx/biometric/BiometricPrompt$CryptoObject;-><init>(Ljava/security/Signature;)V
|
|
|
|
return-object p0
|
|
|
|
.line 179
|
|
:cond_2
|
|
invoke-virtual {p0}, Landroidx/core/hardware/fingerprint/FingerprintManagerCompat$CryptoObject;->getMac()Ljavax/crypto/Mac;
|
|
|
|
move-result-object p0
|
|
|
|
if-eqz p0, :cond_3
|
|
|
|
.line 181
|
|
new-instance v0, Landroidx/biometric/BiometricPrompt$CryptoObject;
|
|
|
|
invoke-direct {v0, p0}, Landroidx/biometric/BiometricPrompt$CryptoObject;-><init>(Ljavax/crypto/Mac;)V
|
|
|
|
:cond_3
|
|
return-object v0
|
|
.end method
|
|
|
|
.method public static wrapForBiometricPrompt(Landroidx/biometric/BiometricPrompt$CryptoObject;)Landroid/hardware/biometrics/BiometricPrompt$CryptoObject;
|
|
.locals 3
|
|
.param p0 # Landroidx/biometric/BiometricPrompt$CryptoObject;
|
|
.annotation build Landroidx/annotation/Nullable;
|
|
.end annotation
|
|
.end param
|
|
.annotation build Landroidx/annotation/Nullable;
|
|
.end annotation
|
|
|
|
.annotation build Landroidx/annotation/RequiresApi;
|
|
value = 0x1c
|
|
.end annotation
|
|
|
|
const/4 v0, 0x0
|
|
|
|
if-nez p0, :cond_0
|
|
|
|
return-object v0
|
|
|
|
.line 124
|
|
:cond_0
|
|
invoke-virtual {p0}, Landroidx/biometric/BiometricPrompt$CryptoObject;->getCipher()Ljavax/crypto/Cipher;
|
|
|
|
move-result-object v1
|
|
|
|
if-eqz v1, :cond_1
|
|
|
|
.line 126
|
|
invoke-static {v1}, Landroidx/biometric/CryptoObjectUtils$Api28Impl;->create(Ljavax/crypto/Cipher;)Landroid/hardware/biometrics/BiometricPrompt$CryptoObject;
|
|
|
|
move-result-object p0
|
|
|
|
return-object p0
|
|
|
|
.line 129
|
|
:cond_1
|
|
invoke-virtual {p0}, Landroidx/biometric/BiometricPrompt$CryptoObject;->getSignature()Ljava/security/Signature;
|
|
|
|
move-result-object v1
|
|
|
|
if-eqz v1, :cond_2
|
|
|
|
.line 131
|
|
invoke-static {v1}, Landroidx/biometric/CryptoObjectUtils$Api28Impl;->create(Ljava/security/Signature;)Landroid/hardware/biometrics/BiometricPrompt$CryptoObject;
|
|
|
|
move-result-object p0
|
|
|
|
return-object p0
|
|
|
|
.line 134
|
|
:cond_2
|
|
invoke-virtual {p0}, Landroidx/biometric/BiometricPrompt$CryptoObject;->getMac()Ljavax/crypto/Mac;
|
|
|
|
move-result-object v1
|
|
|
|
if-eqz v1, :cond_3
|
|
|
|
.line 136
|
|
invoke-static {v1}, Landroidx/biometric/CryptoObjectUtils$Api28Impl;->create(Ljavax/crypto/Mac;)Landroid/hardware/biometrics/BiometricPrompt$CryptoObject;
|
|
|
|
move-result-object p0
|
|
|
|
return-object p0
|
|
|
|
:cond_3
|
|
sget v1, Landroid/os/Build$VERSION;->SDK_INT:I
|
|
|
|
const/16 v2, 0x1e
|
|
|
|
if-lt v1, v2, :cond_4
|
|
|
|
.line 142
|
|
invoke-virtual {p0}, Landroidx/biometric/BiometricPrompt$CryptoObject;->getIdentityCredential()Landroid/security/identity/IdentityCredential;
|
|
|
|
move-result-object p0
|
|
|
|
if-eqz p0, :cond_4
|
|
|
|
.line 144
|
|
invoke-static {p0}, Landroidx/biometric/CryptoObjectUtils$Api30Impl;->create(Landroid/security/identity/IdentityCredential;)Landroid/hardware/biometrics/BiometricPrompt$CryptoObject;
|
|
|
|
move-result-object p0
|
|
|
|
return-object p0
|
|
|
|
:cond_4
|
|
return-object v0
|
|
.end method
|
|
|
|
.method public static wrapForFingerprintManager(Landroidx/biometric/BiometricPrompt$CryptoObject;)Landroidx/core/hardware/fingerprint/FingerprintManagerCompat$CryptoObject;
|
|
.locals 3
|
|
.param p0 # Landroidx/biometric/BiometricPrompt$CryptoObject;
|
|
.annotation build Landroidx/annotation/Nullable;
|
|
.end annotation
|
|
.end param
|
|
.annotation build Landroidx/annotation/Nullable;
|
|
.end annotation
|
|
|
|
const/4 v0, 0x0
|
|
|
|
if-nez p0, :cond_0
|
|
|
|
return-object v0
|
|
|
|
.line 204
|
|
:cond_0
|
|
invoke-virtual {p0}, Landroidx/biometric/BiometricPrompt$CryptoObject;->getCipher()Ljavax/crypto/Cipher;
|
|
|
|
move-result-object v1
|
|
|
|
if-eqz v1, :cond_1
|
|
|
|
.line 206
|
|
new-instance p0, Landroidx/core/hardware/fingerprint/FingerprintManagerCompat$CryptoObject;
|
|
|
|
invoke-direct {p0, v1}, Landroidx/core/hardware/fingerprint/FingerprintManagerCompat$CryptoObject;-><init>(Ljavax/crypto/Cipher;)V
|
|
|
|
return-object p0
|
|
|
|
.line 210
|
|
:cond_1
|
|
invoke-virtual {p0}, Landroidx/biometric/BiometricPrompt$CryptoObject;->getSignature()Ljava/security/Signature;
|
|
|
|
move-result-object v1
|
|
|
|
if-eqz v1, :cond_2
|
|
|
|
.line 212
|
|
new-instance p0, Landroidx/core/hardware/fingerprint/FingerprintManagerCompat$CryptoObject;
|
|
|
|
invoke-direct {p0, v1}, Landroidx/core/hardware/fingerprint/FingerprintManagerCompat$CryptoObject;-><init>(Ljava/security/Signature;)V
|
|
|
|
return-object p0
|
|
|
|
.line 216
|
|
:cond_2
|
|
invoke-virtual {p0}, Landroidx/biometric/BiometricPrompt$CryptoObject;->getMac()Ljavax/crypto/Mac;
|
|
|
|
move-result-object v1
|
|
|
|
if-eqz v1, :cond_3
|
|
|
|
.line 218
|
|
new-instance p0, Landroidx/core/hardware/fingerprint/FingerprintManagerCompat$CryptoObject;
|
|
|
|
invoke-direct {p0, v1}, Landroidx/core/hardware/fingerprint/FingerprintManagerCompat$CryptoObject;-><init>(Ljavax/crypto/Mac;)V
|
|
|
|
return-object p0
|
|
|
|
:cond_3
|
|
sget v1, Landroid/os/Build$VERSION;->SDK_INT:I
|
|
|
|
const/16 v2, 0x1e
|
|
|
|
if-lt v1, v2, :cond_4
|
|
|
|
.line 223
|
|
invoke-virtual {p0}, Landroidx/biometric/BiometricPrompt$CryptoObject;->getIdentityCredential()Landroid/security/identity/IdentityCredential;
|
|
|
|
move-result-object p0
|
|
|
|
if-eqz p0, :cond_4
|
|
|
|
const-string p0, "CryptoObjectUtils"
|
|
|
|
const-string v1, "Identity credential is not supported by FingerprintManager."
|
|
|
|
.line 224
|
|
invoke-static {p0, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
|
|
|
|
:cond_4
|
|
return-object v0
|
|
.end method
|