mirror of
https://github.com/M66B/FairEmail.git
synced 2025-01-01 04:35:57 +00:00
Bio error handling
This commit is contained in:
parent
8874986ee5
commit
3e8f173da1
1 changed files with 27 additions and 17 deletions
|
@ -2827,18 +2827,18 @@ public class Helper {
|
|||
|
||||
@Override
|
||||
public void onAuthenticationError(final int errorCode, @NonNull final CharSequence errString) {
|
||||
if (isCancelled(errorCode) || errorCode == BiometricPrompt.ERROR_UNABLE_TO_PROCESS)
|
||||
if (isBioCancelled(errorCode) || errorCode == BiometricPrompt.ERROR_UNABLE_TO_PROCESS)
|
||||
Log.w("Authenticate biometric error " + errorCode + ": " + errString);
|
||||
else
|
||||
Log.e("Authenticate biometric error " + errorCode + ": " + errString);
|
||||
|
||||
if (isHardwareFailure(errorCode)) {
|
||||
if (isBioHardwareFailure(errorCode)) {
|
||||
prefs.edit().remove("biometrics").apply();
|
||||
ApplicationEx.getMainHandler().post(authenticated);
|
||||
return;
|
||||
}
|
||||
|
||||
if (!isCancelled(errorCode))
|
||||
if (!isBioCancelled(errorCode))
|
||||
ApplicationEx.getMainHandler().post(new RunnableEx("auth:error") {
|
||||
@Override
|
||||
public void delegate() {
|
||||
|
@ -2864,19 +2864,6 @@ public class Helper {
|
|||
if (++fails >= 3)
|
||||
ApplicationEx.getMainHandler().post(cancelled);
|
||||
}
|
||||
|
||||
private boolean isCancelled(int errorCode) {
|
||||
return (errorCode == BiometricPrompt.ERROR_NEGATIVE_BUTTON ||
|
||||
errorCode == BiometricPrompt.ERROR_CANCELED ||
|
||||
errorCode == BiometricPrompt.ERROR_USER_CANCELED);
|
||||
}
|
||||
|
||||
private boolean isHardwareFailure(int errorCode) {
|
||||
return (errorCode == BiometricPrompt.ERROR_HW_UNAVAILABLE ||
|
||||
errorCode == BiometricPrompt.ERROR_NO_BIOMETRICS || // No fingerprints enrolled.
|
||||
errorCode == BiometricPrompt.ERROR_HW_NOT_PRESENT ||
|
||||
errorCode == BiometricPrompt.ERROR_NO_DEVICE_CREDENTIAL);
|
||||
}
|
||||
});
|
||||
|
||||
prompt.authenticate(info.build());
|
||||
|
@ -3082,7 +3069,17 @@ public class Helper {
|
|||
|
||||
@Override
|
||||
public void onAuthenticationError(int errorCode, @NonNull CharSequence errString) {
|
||||
ToastEx.makeText(activity, "Error " + errorCode + ": " + errString, Toast.LENGTH_LONG).show();
|
||||
tilPassword.post(new RunnableEx("tilPassword") {
|
||||
@Override
|
||||
protected void delegate() {
|
||||
if (isBioCancelled(errorCode))
|
||||
return;
|
||||
else if (isBioHardwareFailure(errorCode))
|
||||
tilPassword.getEditText().setTransformationMethod(null);
|
||||
else
|
||||
ToastEx.makeText(activity, "Error " + errorCode + ": " + errString, Toast.LENGTH_LONG).show();
|
||||
}
|
||||
});
|
||||
}
|
||||
});
|
||||
prompt.authenticate(info.build());
|
||||
|
@ -3093,6 +3090,19 @@ public class Helper {
|
|||
});
|
||||
}
|
||||
|
||||
private static boolean isBioCancelled(int errorCode) {
|
||||
return (errorCode == BiometricPrompt.ERROR_NEGATIVE_BUTTON ||
|
||||
errorCode == BiometricPrompt.ERROR_CANCELED ||
|
||||
errorCode == BiometricPrompt.ERROR_USER_CANCELED);
|
||||
}
|
||||
|
||||
private static boolean isBioHardwareFailure(int errorCode) {
|
||||
return (errorCode == BiometricPrompt.ERROR_HW_UNAVAILABLE ||
|
||||
errorCode == BiometricPrompt.ERROR_NO_BIOMETRICS || // No fingerprints enrolled.
|
||||
errorCode == BiometricPrompt.ERROR_HW_NOT_PRESENT ||
|
||||
errorCode == BiometricPrompt.ERROR_NO_DEVICE_CREDENTIAL);
|
||||
}
|
||||
|
||||
static void selectKeyAlias(final Activity activity, final LifecycleOwner owner, final String alias, final IKeyAlias intf) {
|
||||
final Context context = activity.getApplicationContext();
|
||||
new Thread(new Runnable() {
|
||||
|
|
Loading…
Reference in a new issue