Launch correct enrollment activity from ChooseLock
Test: no noticable difference when setting up fingeprint work profile Fixes: 130397083 Change-Id: I34be5262cc52052ce25a188f19bbcc13f938ac92
This commit is contained in:
@@ -20,11 +20,15 @@ import android.app.settings.SettingsEnums;
|
||||
import android.content.Intent;
|
||||
import android.content.pm.PackageManager;
|
||||
import android.os.Bundle;
|
||||
import android.os.UserHandle;
|
||||
|
||||
import com.android.settings.SetupWizardUtils;
|
||||
import com.android.settings.biometrics.face.FaceEnrollIntroduction;
|
||||
import com.android.settings.biometrics.fingerprint.FingerprintEnrollFindSensor;
|
||||
import com.android.settings.biometrics.fingerprint.FingerprintEnrollIntroduction;
|
||||
import com.android.settings.biometrics.fingerprint.SetupFingerprintEnrollIntroduction;
|
||||
import com.android.settings.core.InstrumentedActivity;
|
||||
import com.android.settings.password.ChooseLockSettingsHelper;
|
||||
|
||||
import com.google.android.setupcompat.util.WizardManagerHelper;
|
||||
|
||||
@@ -36,6 +40,12 @@ import com.google.android.setupcompat.util.WizardManagerHelper;
|
||||
*/
|
||||
public class BiometricEnrollActivity extends InstrumentedActivity {
|
||||
|
||||
private static final String TAG = "BiometricEnrollActivity";
|
||||
|
||||
public static final String EXTRA_SKIP_INTRO = "skip_intro";
|
||||
|
||||
public static final class InternalActivity extends BiometricEnrollActivity {}
|
||||
|
||||
@Override
|
||||
public void onCreate(Bundle savedInstanceState) {
|
||||
super.onCreate(savedInstanceState);
|
||||
@@ -45,19 +55,43 @@ public class BiometricEnrollActivity extends InstrumentedActivity {
|
||||
|
||||
// This logic may have to be modified on devices with multiple biometrics.
|
||||
if (pm.hasSystemFeature(PackageManager.FEATURE_FINGERPRINT)) {
|
||||
intent = getFingerprintEnrollIntent();
|
||||
// ChooseLockGeneric can request to start fingerprint enroll bypassing the intro screen.
|
||||
if (getIntent().getBooleanExtra(EXTRA_SKIP_INTRO, false)
|
||||
&& this instanceof InternalActivity) {
|
||||
intent = getFingerprintFindSensorIntent();
|
||||
} else {
|
||||
intent = getFingerprintIntroIntent();
|
||||
}
|
||||
} else if (pm.hasSystemFeature(PackageManager.FEATURE_FACE)) {
|
||||
intent = getFaceEnrollIntent();
|
||||
intent = getFaceIntroIntent();
|
||||
}
|
||||
|
||||
if (intent != null) {
|
||||
intent.setFlags(Intent.FLAG_ACTIVITY_FORWARD_RESULT);
|
||||
|
||||
if (this instanceof InternalActivity) {
|
||||
// Propagate challenge and user Id from ChooseLockGeneric.
|
||||
final byte[] token = getIntent()
|
||||
.getByteArrayExtra(ChooseLockSettingsHelper.EXTRA_KEY_CHALLENGE_TOKEN);
|
||||
final int userId = getIntent()
|
||||
.getIntExtra(Intent.EXTRA_USER_ID, UserHandle.USER_NULL);
|
||||
|
||||
intent.putExtra(ChooseLockSettingsHelper.EXTRA_KEY_CHALLENGE_TOKEN, token);
|
||||
intent.putExtra(Intent.EXTRA_USER_ID, userId);
|
||||
}
|
||||
|
||||
startActivity(intent);
|
||||
}
|
||||
finish();
|
||||
}
|
||||
|
||||
private Intent getFingerprintEnrollIntent() {
|
||||
private Intent getFingerprintFindSensorIntent() {
|
||||
Intent intent = new Intent(this, FingerprintEnrollFindSensor.class);
|
||||
SetupWizardUtils.copySetupExtras(getIntent(), intent);
|
||||
return intent;
|
||||
}
|
||||
|
||||
private Intent getFingerprintIntroIntent() {
|
||||
if (WizardManagerHelper.isAnySetupWizard(getIntent())) {
|
||||
Intent intent = new Intent(this, SetupFingerprintEnrollIntroduction.class);
|
||||
WizardManagerHelper.copyWizardManagerExtras(getIntent(), intent);
|
||||
@@ -67,7 +101,7 @@ public class BiometricEnrollActivity extends InstrumentedActivity {
|
||||
}
|
||||
}
|
||||
|
||||
private Intent getFaceEnrollIntent() {
|
||||
private Intent getFaceIntroIntent() {
|
||||
Intent intent = new Intent(this, FaceEnrollIntroduction.class);
|
||||
WizardManagerHelper.copyWizardManagerExtras(getIntent(), intent);
|
||||
return intent;
|
||||
|
Reference in New Issue
Block a user