- 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
536 lines
13 KiB
Smali
536 lines
13 KiB
Smali
.class public Landroidx/biometric/BiometricManager;
|
|
.super Ljava/lang/Object;
|
|
.source "SourceFile"
|
|
|
|
|
|
# annotations
|
|
.annotation system Ldalvik/annotation/MemberClasses;
|
|
value = {
|
|
Landroidx/biometric/BiometricManager$Api29Impl;,
|
|
Landroidx/biometric/BiometricManager$Api30Impl;,
|
|
Landroidx/biometric/BiometricManager$DefaultInjector;,
|
|
Landroidx/biometric/BiometricManager$Injector;,
|
|
Landroidx/biometric/BiometricManager$Authenticators;
|
|
}
|
|
.end annotation
|
|
|
|
|
|
# static fields
|
|
.field public static final BIOMETRIC_ERROR_HW_UNAVAILABLE:I = 0x1
|
|
|
|
.field public static final BIOMETRIC_ERROR_NONE_ENROLLED:I = 0xb
|
|
|
|
.field public static final BIOMETRIC_ERROR_NO_HARDWARE:I = 0xc
|
|
|
|
.field public static final BIOMETRIC_ERROR_SECURITY_UPDATE_REQUIRED:I = 0xf
|
|
|
|
.field public static final BIOMETRIC_ERROR_UNSUPPORTED:I = -0x2
|
|
|
|
.field public static final BIOMETRIC_STATUS_UNKNOWN:I = -0x1
|
|
|
|
.field public static final BIOMETRIC_SUCCESS:I = 0x0
|
|
|
|
.field private static final TAG:Ljava/lang/String; = "BiometricManager"
|
|
|
|
|
|
# instance fields
|
|
.field private final mBiometricManager:Landroid/hardware/biometrics/BiometricManager;
|
|
.annotation build Landroidx/annotation/Nullable;
|
|
.end annotation
|
|
.end field
|
|
|
|
.field private final mFingerprintManager:Landroidx/core/hardware/fingerprint/FingerprintManagerCompat;
|
|
.annotation build Landroidx/annotation/Nullable;
|
|
.end annotation
|
|
.end field
|
|
|
|
.field private final mInjector:Landroidx/biometric/BiometricManager$Injector;
|
|
.annotation build Landroidx/annotation/NonNull;
|
|
.end annotation
|
|
.end field
|
|
|
|
|
|
# direct methods
|
|
.method public constructor <init>(Landroidx/biometric/BiometricManager$Injector;)V
|
|
.locals 4
|
|
.param p1 # Landroidx/biometric/BiometricManager$Injector;
|
|
.annotation build Landroidx/annotation/NonNull;
|
|
.end annotation
|
|
.end param
|
|
.annotation build Landroidx/annotation/VisibleForTesting;
|
|
.end annotation
|
|
|
|
.line 291
|
|
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
|
|
|
|
iput-object p1, p0, Landroidx/biometric/BiometricManager;->mInjector:Landroidx/biometric/BiometricManager$Injector;
|
|
|
|
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
|
|
|
|
const/4 v1, 0x0
|
|
|
|
const/16 v2, 0x1d
|
|
|
|
if-lt v0, v2, :cond_0
|
|
|
|
.line 294
|
|
invoke-interface {p1}, Landroidx/biometric/BiometricManager$Injector;->getBiometricManager()Landroid/hardware/biometrics/BiometricManager;
|
|
|
|
move-result-object v3
|
|
|
|
goto :goto_0
|
|
|
|
:cond_0
|
|
move-object v3, v1
|
|
|
|
:goto_0
|
|
iput-object v3, p0, Landroidx/biometric/BiometricManager;->mBiometricManager:Landroid/hardware/biometrics/BiometricManager;
|
|
|
|
if-gt v0, v2, :cond_1
|
|
|
|
.line 297
|
|
invoke-interface {p1}, Landroidx/biometric/BiometricManager$Injector;->getFingerprintManager()Landroidx/core/hardware/fingerprint/FingerprintManagerCompat;
|
|
|
|
move-result-object v1
|
|
|
|
:cond_1
|
|
iput-object v1, p0, Landroidx/biometric/BiometricManager;->mFingerprintManager:Landroidx/core/hardware/fingerprint/FingerprintManagerCompat;
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method private canAuthenticateCompat(I)I
|
|
.locals 3
|
|
|
|
.line 360
|
|
invoke-static {p1}, Landroidx/biometric/AuthenticatorUtils;->isSupportedCombination(I)Z
|
|
|
|
move-result v0
|
|
|
|
if-nez v0, :cond_0
|
|
|
|
const/4 p1, -0x2
|
|
|
|
return p1
|
|
|
|
:cond_0
|
|
const/16 v0, 0xc
|
|
|
|
if-nez p1, :cond_1
|
|
|
|
return v0
|
|
|
|
:cond_1
|
|
iget-object v1, p0, Landroidx/biometric/BiometricManager;->mInjector:Landroidx/biometric/BiometricManager$Injector;
|
|
|
|
.line 370
|
|
invoke-interface {v1}, Landroidx/biometric/BiometricManager$Injector;->isDeviceSecurable()Z
|
|
|
|
move-result v1
|
|
|
|
if-nez v1, :cond_2
|
|
|
|
return v0
|
|
|
|
.line 376
|
|
:cond_2
|
|
invoke-static {p1}, Landroidx/biometric/AuthenticatorUtils;->isDeviceCredentialAllowed(I)Z
|
|
|
|
move-result v1
|
|
|
|
if-eqz v1, :cond_4
|
|
|
|
iget-object p1, p0, Landroidx/biometric/BiometricManager;->mInjector:Landroidx/biometric/BiometricManager$Injector;
|
|
|
|
.line 377
|
|
invoke-interface {p1}, Landroidx/biometric/BiometricManager$Injector;->isDeviceSecuredWithCredential()Z
|
|
|
|
move-result p1
|
|
|
|
if-eqz p1, :cond_3
|
|
|
|
const/4 p1, 0x0
|
|
|
|
goto :goto_0
|
|
|
|
:cond_3
|
|
const/16 p1, 0xb
|
|
|
|
:goto_0
|
|
return p1
|
|
|
|
:cond_4
|
|
sget v1, Landroid/os/Build$VERSION;->SDK_INT:I
|
|
|
|
const/16 v2, 0x1d
|
|
|
|
if-ne v1, v2, :cond_6
|
|
|
|
.line 384
|
|
invoke-static {p1}, Landroidx/biometric/AuthenticatorUtils;->isWeakBiometricAllowed(I)Z
|
|
|
|
move-result p1
|
|
|
|
if-eqz p1, :cond_5
|
|
|
|
.line 385
|
|
invoke-direct {p0}, Landroidx/biometric/BiometricManager;->canAuthenticateWithWeakBiometricOnApi29()I
|
|
|
|
move-result p1
|
|
|
|
goto :goto_1
|
|
|
|
.line 386
|
|
:cond_5
|
|
invoke-direct {p0}, Landroidx/biometric/BiometricManager;->canAuthenticateWithStrongBiometricOnApi29()I
|
|
|
|
move-result p1
|
|
|
|
:goto_1
|
|
return p1
|
|
|
|
:cond_6
|
|
const/16 p1, 0x1c
|
|
|
|
if-ne v1, p1, :cond_8
|
|
|
|
iget-object p1, p0, Landroidx/biometric/BiometricManager;->mInjector:Landroidx/biometric/BiometricManager$Injector;
|
|
|
|
.line 393
|
|
invoke-interface {p1}, Landroidx/biometric/BiometricManager$Injector;->isFingerprintHardwarePresent()Z
|
|
|
|
move-result p1
|
|
|
|
if-eqz p1, :cond_7
|
|
|
|
.line 394
|
|
invoke-direct {p0}, Landroidx/biometric/BiometricManager;->canAuthenticateWithFingerprintOrUnknownBiometric()I
|
|
|
|
move-result v0
|
|
|
|
:cond_7
|
|
return v0
|
|
|
|
.line 399
|
|
:cond_8
|
|
invoke-direct {p0}, Landroidx/biometric/BiometricManager;->canAuthenticateWithFingerprint()I
|
|
|
|
move-result p1
|
|
|
|
return p1
|
|
.end method
|
|
|
|
.method private canAuthenticateWithFingerprint()I
|
|
.locals 2
|
|
|
|
iget-object v0, p0, Landroidx/biometric/BiometricManager;->mFingerprintManager:Landroidx/core/hardware/fingerprint/FingerprintManagerCompat;
|
|
|
|
if-nez v0, :cond_0
|
|
|
|
const-string v0, "BiometricManager"
|
|
|
|
const-string v1, "Failure in canAuthenticate(). FingerprintManager was null."
|
|
|
|
.line 495
|
|
invoke-static {v0, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
|
|
|
|
const/4 v0, 0x1
|
|
|
|
return v0
|
|
|
|
.line 498
|
|
:cond_0
|
|
invoke-virtual {v0}, Landroidx/core/hardware/fingerprint/FingerprintManagerCompat;->isHardwareDetected()Z
|
|
|
|
move-result v0
|
|
|
|
if-nez v0, :cond_1
|
|
|
|
const/16 v0, 0xc
|
|
|
|
return v0
|
|
|
|
:cond_1
|
|
iget-object v0, p0, Landroidx/biometric/BiometricManager;->mFingerprintManager:Landroidx/core/hardware/fingerprint/FingerprintManagerCompat;
|
|
|
|
.line 501
|
|
invoke-virtual {v0}, Landroidx/core/hardware/fingerprint/FingerprintManagerCompat;->hasEnrolledFingerprints()Z
|
|
|
|
move-result v0
|
|
|
|
if-nez v0, :cond_2
|
|
|
|
const/16 v0, 0xb
|
|
|
|
return v0
|
|
|
|
:cond_2
|
|
const/4 v0, 0x0
|
|
|
|
return v0
|
|
.end method
|
|
|
|
.method private canAuthenticateWithFingerprintOrUnknownBiometric()I
|
|
.locals 1
|
|
|
|
iget-object v0, p0, Landroidx/biometric/BiometricManager;->mInjector:Landroidx/biometric/BiometricManager$Injector;
|
|
|
|
.line 475
|
|
invoke-interface {v0}, Landroidx/biometric/BiometricManager$Injector;->isDeviceSecuredWithCredential()Z
|
|
|
|
move-result v0
|
|
|
|
if-nez v0, :cond_0
|
|
|
|
.line 476
|
|
invoke-direct {p0}, Landroidx/biometric/BiometricManager;->canAuthenticateWithFingerprint()I
|
|
|
|
move-result v0
|
|
|
|
return v0
|
|
|
|
.line 481
|
|
:cond_0
|
|
invoke-direct {p0}, Landroidx/biometric/BiometricManager;->canAuthenticateWithFingerprint()I
|
|
|
|
move-result v0
|
|
|
|
if-nez v0, :cond_1
|
|
|
|
const/4 v0, 0x0
|
|
|
|
goto :goto_0
|
|
|
|
:cond_1
|
|
const/4 v0, -0x1
|
|
|
|
:goto_0
|
|
return v0
|
|
.end method
|
|
|
|
.method private canAuthenticateWithStrongBiometricOnApi29()I
|
|
.locals 4
|
|
.annotation build Landroidx/annotation/RequiresApi;
|
|
value = 0x1d
|
|
.end annotation
|
|
|
|
const-string v0, "BiometricManager"
|
|
|
|
.line 415
|
|
invoke-static {}, Landroidx/biometric/BiometricManager$Api29Impl;->getCanAuthenticateWithCryptoMethod()Ljava/lang/reflect/Method;
|
|
|
|
move-result-object v1
|
|
|
|
if-eqz v1, :cond_1
|
|
|
|
.line 419
|
|
invoke-static {}, Landroidx/biometric/CryptoObjectUtils;->createFakeCryptoObject()Landroidx/biometric/BiometricPrompt$CryptoObject;
|
|
|
|
move-result-object v2
|
|
|
|
.line 418
|
|
invoke-static {v2}, Landroidx/biometric/CryptoObjectUtils;->wrapForBiometricPrompt(Landroidx/biometric/BiometricPrompt$CryptoObject;)Landroid/hardware/biometrics/BiometricPrompt$CryptoObject;
|
|
|
|
move-result-object v2
|
|
|
|
if-eqz v2, :cond_1
|
|
|
|
:try_start_0
|
|
iget-object v3, p0, Landroidx/biometric/BiometricManager;->mBiometricManager:Landroid/hardware/biometrics/BiometricManager;
|
|
|
|
filled-new-array {v2}, [Ljava/lang/Object;
|
|
|
|
move-result-object v2
|
|
|
|
.line 423
|
|
invoke-virtual {v1, v3, v2}, Ljava/lang/reflect/Method;->invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
move-result-object v1
|
|
|
|
.line 424
|
|
instance-of v2, v1, Ljava/lang/Integer;
|
|
|
|
if-eqz v2, :cond_0
|
|
|
|
.line 425
|
|
check-cast v1, Ljava/lang/Integer;
|
|
|
|
invoke-virtual {v1}, Ljava/lang/Integer;->intValue()I
|
|
|
|
move-result v0
|
|
|
|
return v0
|
|
|
|
:catch_0
|
|
move-exception v1
|
|
|
|
goto :goto_0
|
|
|
|
:catch_1
|
|
move-exception v1
|
|
|
|
goto :goto_0
|
|
|
|
:catch_2
|
|
move-exception v1
|
|
|
|
goto :goto_0
|
|
|
|
:cond_0
|
|
const-string v1, "Invalid return type for canAuthenticate(CryptoObject)."
|
|
|
|
.line 427
|
|
invoke-static {v0, v1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
|
|
:try_end_0
|
|
.catch Ljava/lang/IllegalAccessException; {:try_start_0 .. :try_end_0} :catch_2
|
|
.catch Ljava/lang/IllegalArgumentException; {:try_start_0 .. :try_end_0} :catch_1
|
|
.catch Ljava/lang/reflect/InvocationTargetException; {:try_start_0 .. :try_end_0} :catch_0
|
|
|
|
goto :goto_1
|
|
|
|
:goto_0
|
|
const-string v2, "Failed to invoke canAuthenticate(CryptoObject)."
|
|
|
|
.line 430
|
|
invoke-static {v0, v2, v1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
|
|
|
|
.line 436
|
|
:cond_1
|
|
:goto_1
|
|
invoke-direct {p0}, Landroidx/biometric/BiometricManager;->canAuthenticateWithWeakBiometricOnApi29()I
|
|
|
|
move-result v0
|
|
|
|
iget-object v1, p0, Landroidx/biometric/BiometricManager;->mInjector:Landroidx/biometric/BiometricManager$Injector;
|
|
|
|
.line 437
|
|
invoke-interface {v1}, Landroidx/biometric/BiometricManager$Injector;->isStrongBiometricGuaranteed()Z
|
|
|
|
move-result v1
|
|
|
|
if-nez v1, :cond_3
|
|
|
|
if-eqz v0, :cond_2
|
|
|
|
goto :goto_2
|
|
|
|
.line 442
|
|
:cond_2
|
|
invoke-direct {p0}, Landroidx/biometric/BiometricManager;->canAuthenticateWithFingerprintOrUnknownBiometric()I
|
|
|
|
move-result v0
|
|
|
|
:cond_3
|
|
:goto_2
|
|
return v0
|
|
.end method
|
|
|
|
.method private canAuthenticateWithWeakBiometricOnApi29()I
|
|
.locals 2
|
|
.annotation build Landroidx/annotation/RequiresApi;
|
|
value = 0x1d
|
|
.end annotation
|
|
|
|
iget-object v0, p0, Landroidx/biometric/BiometricManager;->mBiometricManager:Landroid/hardware/biometrics/BiometricManager;
|
|
|
|
if-nez v0, :cond_0
|
|
|
|
const-string v0, "BiometricManager"
|
|
|
|
const-string v1, "Failure in canAuthenticate(). BiometricManager was null."
|
|
|
|
.line 457
|
|
invoke-static {v0, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
|
|
|
|
const/4 v0, 0x1
|
|
|
|
return v0
|
|
|
|
.line 460
|
|
:cond_0
|
|
invoke-static {v0}, Landroidx/biometric/BiometricManager$Api29Impl;->canAuthenticate(Landroid/hardware/biometrics/BiometricManager;)I
|
|
|
|
move-result v0
|
|
|
|
return v0
|
|
.end method
|
|
|
|
.method public static from(Landroid/content/Context;)Landroidx/biometric/BiometricManager;
|
|
.locals 2
|
|
.param p0 # Landroid/content/Context;
|
|
.annotation build Landroidx/annotation/NonNull;
|
|
.end annotation
|
|
.end param
|
|
.annotation build Landroidx/annotation/NonNull;
|
|
.end annotation
|
|
|
|
.line 282
|
|
new-instance v0, Landroidx/biometric/BiometricManager;
|
|
|
|
new-instance v1, Landroidx/biometric/BiometricManager$DefaultInjector;
|
|
|
|
invoke-direct {v1, p0}, Landroidx/biometric/BiometricManager$DefaultInjector;-><init>(Landroid/content/Context;)V
|
|
|
|
invoke-direct {v0, v1}, Landroidx/biometric/BiometricManager;-><init>(Landroidx/biometric/BiometricManager$Injector;)V
|
|
|
|
return-object v0
|
|
.end method
|
|
|
|
|
|
# virtual methods
|
|
.method public canAuthenticate()I
|
|
.locals 1
|
|
.annotation runtime Ljava/lang/Deprecated;
|
|
.end annotation
|
|
|
|
const/16 v0, 0xff
|
|
|
|
.line 314
|
|
invoke-virtual {p0, v0}, Landroidx/biometric/BiometricManager;->canAuthenticate(I)I
|
|
|
|
move-result v0
|
|
|
|
return v0
|
|
.end method
|
|
|
|
.method public canAuthenticate(I)I
|
|
.locals 2
|
|
|
|
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
|
|
|
|
const/16 v1, 0x1e
|
|
|
|
if-lt v0, v1, :cond_1
|
|
|
|
iget-object v0, p0, Landroidx/biometric/BiometricManager;->mBiometricManager:Landroid/hardware/biometrics/BiometricManager;
|
|
|
|
if-nez v0, :cond_0
|
|
|
|
const-string p1, "BiometricManager"
|
|
|
|
const-string v0, "Failure in canAuthenticate(). BiometricManager was null."
|
|
|
|
.line 338
|
|
invoke-static {p1, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
|
|
|
|
const/4 p1, 0x1
|
|
|
|
return p1
|
|
|
|
.line 341
|
|
:cond_0
|
|
invoke-static {v0, p1}, Landroidx/biometric/BiometricManager$Api30Impl;->canAuthenticate(Landroid/hardware/biometrics/BiometricManager;I)I
|
|
|
|
move-result p1
|
|
|
|
return p1
|
|
|
|
.line 343
|
|
:cond_1
|
|
invoke-direct {p0, p1}, Landroidx/biometric/BiometricManager;->canAuthenticateCompat(I)I
|
|
|
|
move-result p1
|
|
|
|
return p1
|
|
.end method
|