Merge "Launch FaceEnrollPage form BiometricEnrollActivity"
This commit is contained in:
@@ -23,6 +23,7 @@ import static com.android.settings.biometrics.BiometricEnrollBase.RESULT_CONSENT
|
|||||||
import static com.android.settings.biometrics.BiometricEnrollBase.RESULT_CONSENT_GRANTED;
|
import static com.android.settings.biometrics.BiometricEnrollBase.RESULT_CONSENT_GRANTED;
|
||||||
|
|
||||||
import android.annotation.NonNull;
|
import android.annotation.NonNull;
|
||||||
|
import android.app.Activity;
|
||||||
import android.app.admin.DevicePolicyManager;
|
import android.app.admin.DevicePolicyManager;
|
||||||
import android.app.settings.SettingsEnums;
|
import android.app.settings.SettingsEnums;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
@@ -73,7 +74,8 @@ public class BiometricEnrollActivity extends InstrumentedActivity {
|
|||||||
private static final int REQUEST_CHOOSE_OPTIONS = 3;
|
private static final int REQUEST_CHOOSE_OPTIONS = 3;
|
||||||
// prompt hand phone back to parent after enrollment
|
// prompt hand phone back to parent after enrollment
|
||||||
private static final int REQUEST_HANDOFF_PARENT = 4;
|
private static final int REQUEST_HANDOFF_PARENT = 4;
|
||||||
private static final int REQUEST_SINGLE_ENROLL = 5;
|
private static final int REQUEST_SINGLE_ENROLL_FINGERPRINT = 5;
|
||||||
|
private static final int REQUEST_SINGLE_ENROLL_FACE = 6;
|
||||||
|
|
||||||
public static final int RESULT_SKIP = BiometricEnrollBase.RESULT_SKIP;
|
public static final int RESULT_SKIP = BiometricEnrollBase.RESULT_SKIP;
|
||||||
|
|
||||||
@@ -118,7 +120,6 @@ public class BiometricEnrollActivity extends InstrumentedActivity {
|
|||||||
private Bundle mParentalOptions;
|
private Bundle mParentalOptions;
|
||||||
@Nullable private Long mGkPwHandle;
|
@Nullable private Long mGkPwHandle;
|
||||||
@Nullable private ParentalConsentHelper mParentalConsentHelper;
|
@Nullable private ParentalConsentHelper mParentalConsentHelper;
|
||||||
@Nullable private MultiBiometricEnrollHelper mMultiBiometricEnrollHelper;
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onCreate(@Nullable Bundle savedInstanceState) {
|
public void onCreate(@Nullable Bundle savedInstanceState) {
|
||||||
@@ -314,8 +315,6 @@ public class BiometricEnrollActivity extends InstrumentedActivity {
|
|||||||
} else if (canUseFace || canUseFingerprint) {
|
} else if (canUseFace || canUseFingerprint) {
|
||||||
if (mGkPwHandle == null) {
|
if (mGkPwHandle == null) {
|
||||||
setOrConfirmCredentialsNow();
|
setOrConfirmCredentialsNow();
|
||||||
} else if (canUseFace && canUseFingerprint) {
|
|
||||||
launchFaceAndFingerprintEnroll();
|
|
||||||
} else if (canUseFingerprint) {
|
} else if (canUseFingerprint) {
|
||||||
launchFingerprintOnlyEnroll();
|
launchFingerprintOnlyEnroll();
|
||||||
} else {
|
} else {
|
||||||
@@ -444,49 +443,63 @@ public class BiometricEnrollActivity extends InstrumentedActivity {
|
|||||||
// handles responses while multi biometric enrollment is pending
|
// handles responses while multi biometric enrollment is pending
|
||||||
private void handleOnActivityResultWhileEnrolling(
|
private void handleOnActivityResultWhileEnrolling(
|
||||||
int requestCode, int resultCode, Intent data) {
|
int requestCode, int resultCode, Intent data) {
|
||||||
if (requestCode == REQUEST_HANDOFF_PARENT) {
|
|
||||||
Log.d(TAG, "Enrollment complete, requesting handoff, result: " + resultCode);
|
|
||||||
setResult(RESULT_OK, newResultIntent());
|
|
||||||
finish();
|
|
||||||
} else if (mMultiBiometricEnrollHelper == null) {
|
|
||||||
overridePendingTransition(R.anim.sud_slide_next_in, R.anim.sud_slide_next_out);
|
|
||||||
|
|
||||||
switch (requestCode) {
|
Log.d(TAG, "handleOnActivityResultWhileEnrolling, request = " + requestCode + ""
|
||||||
case REQUEST_CHOOSE_LOCK:
|
+ ", resultCode = " + resultCode);
|
||||||
case REQUEST_CONFIRM_LOCK:
|
switch (requestCode) {
|
||||||
mConfirmingCredentials = false;
|
case REQUEST_HANDOFF_PARENT:
|
||||||
final boolean isOk =
|
setResult(RESULT_OK, newResultIntent());
|
||||||
isSuccessfulConfirmOrChooseCredential(requestCode, resultCode);
|
finish();
|
||||||
if (isOk && (mHasFeatureFace || mHasFeatureFingerprint)) {
|
break;
|
||||||
updateGatekeeperPasswordHandle(data);
|
case REQUEST_CHOOSE_LOCK:
|
||||||
if (mHasFeatureFace && mHasFeatureFingerprint) {
|
case REQUEST_CONFIRM_LOCK:
|
||||||
launchFaceAndFingerprintEnroll();
|
mConfirmingCredentials = false;
|
||||||
} else if (mHasFeatureFingerprint) {
|
final boolean isOk =
|
||||||
launchFingerprintOnlyEnroll();
|
isSuccessfulConfirmOrChooseCredential(requestCode, resultCode);
|
||||||
} else {
|
if (isOk && (mHasFeatureFace || mHasFeatureFingerprint)) {
|
||||||
launchFaceOnlyEnroll();
|
updateGatekeeperPasswordHandle(data);
|
||||||
}
|
if (mHasFeatureFingerprint) {
|
||||||
|
launchFingerprintOnlyEnroll();
|
||||||
} else {
|
} else {
|
||||||
Log.d(TAG, "Unknown result for set/choose lock: " + resultCode);
|
launchFaceOnlyEnroll();
|
||||||
setResult(resultCode, newResultIntent());
|
|
||||||
finish();
|
|
||||||
}
|
}
|
||||||
break;
|
} else {
|
||||||
case REQUEST_SINGLE_ENROLL:
|
Log.d(TAG, "Unknown result for set/choose lock: " + resultCode);
|
||||||
mIsSingleEnrolling = false;
|
setResult(resultCode, newResultIntent());
|
||||||
finishOrLaunchHandToParent(resultCode);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
Log.w(TAG, "Unknown enrolling requestCode: " + requestCode + ", finishing");
|
|
||||||
finish();
|
finish();
|
||||||
}
|
}
|
||||||
} else {
|
break;
|
||||||
Log.d(TAG, "RequestCode: " + requestCode + " resultCode: " + resultCode);
|
case REQUEST_SINGLE_ENROLL_FINGERPRINT:
|
||||||
BiometricUtils.removeGatekeeperPasswordHandle(this, mGkPwHandle);
|
mIsSingleEnrolling = false;
|
||||||
finishOrLaunchHandToParent(resultCode);
|
if ((resultCode == BiometricEnrollBase.RESULT_SKIP
|
||||||
|
|| resultCode == BiometricEnrollBase.RESULT_FINISHED) && mHasFeatureFace) {
|
||||||
|
launchFaceOnlyEnroll();
|
||||||
|
} else {
|
||||||
|
finishOrLaunchHandToParent(resultCode);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case REQUEST_SINGLE_ENROLL_FACE:
|
||||||
|
mIsSingleEnrolling = false;
|
||||||
|
if (resultCode == Activity.RESULT_CANCELED && mHasFeatureFingerprint) {
|
||||||
|
launchFingerprintOnlyEnroll();
|
||||||
|
} else {
|
||||||
|
finishOrLaunchHandToParent(resultCode);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
Log.w(TAG, "Unknown enrolling requestCode: " + requestCode + ", finishing");
|
||||||
|
finish();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void finish() {
|
||||||
|
if (mGkPwHandle != null) {
|
||||||
|
BiometricUtils.removeGatekeeperPasswordHandle(this, mGkPwHandle);
|
||||||
|
}
|
||||||
|
super.finish();
|
||||||
|
}
|
||||||
|
|
||||||
private void finishOrLaunchHandToParent(int resultCode) {
|
private void finishOrLaunchHandToParent(int resultCode) {
|
||||||
if (mParentalOptionsRequired) {
|
if (mParentalOptionsRequired) {
|
||||||
if (!mSkipReturnToParent) {
|
if (!mSkipReturnToParent) {
|
||||||
@@ -630,7 +643,7 @@ public class BiometricEnrollActivity extends InstrumentedActivity {
|
|||||||
} else {
|
} else {
|
||||||
intent = BiometricUtils.getFingerprintIntroIntent(this, getIntent());
|
intent = BiometricUtils.getFingerprintIntroIntent(this, getIntent());
|
||||||
}
|
}
|
||||||
launchSingleSensorEnrollActivity(intent, REQUEST_SINGLE_ENROLL);
|
launchSingleSensorEnrollActivity(intent, REQUEST_SINGLE_ENROLL_FINGERPRINT);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -638,16 +651,10 @@ public class BiometricEnrollActivity extends InstrumentedActivity {
|
|||||||
if (!mIsSingleEnrolling) {
|
if (!mIsSingleEnrolling) {
|
||||||
mIsSingleEnrolling = true;
|
mIsSingleEnrolling = true;
|
||||||
final Intent intent = BiometricUtils.getFaceIntroIntent(this, getIntent());
|
final Intent intent = BiometricUtils.getFaceIntroIntent(this, getIntent());
|
||||||
launchSingleSensorEnrollActivity(intent, REQUEST_SINGLE_ENROLL);
|
launchSingleSensorEnrollActivity(intent, REQUEST_SINGLE_ENROLL_FACE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void launchFaceAndFingerprintEnroll() {
|
|
||||||
mMultiBiometricEnrollHelper = new MultiBiometricEnrollHelper(this, mUserId,
|
|
||||||
mIsFaceEnrollable, mIsFingerprintEnrollable, mGkPwHandle);
|
|
||||||
mMultiBiometricEnrollHelper.startNextStep();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void launchHandoffToParent() {
|
private void launchHandoffToParent() {
|
||||||
final Intent intent = BiometricUtils.getHandoffToParentIntent(this, getIntent());
|
final Intent intent = BiometricUtils.getHandoffToParentIntent(this, getIntent());
|
||||||
startActivityForResult(intent, REQUEST_HANDOFF_PARENT);
|
startActivityForResult(intent, REQUEST_HANDOFF_PARENT);
|
||||||
|
Reference in New Issue
Block a user