Merge "[SafetyCenter] Update Settings to align with renamed SafetyCenterManager APIs" into tm-dev
This commit is contained in:
committed by
Android (Google) Code Review
commit
5ccb07df85
@@ -104,7 +104,7 @@ public class FaceUpdater {
|
||||
public void onEnrollmentProgress(int remaining) {
|
||||
mCallback.onEnrollmentProgress(remaining);
|
||||
if (remaining == 0) {
|
||||
BiometricsSafetySource.sendSafetyData(mContext); // biometrics data changed
|
||||
BiometricsSafetySource.onBiometricsChanged(mContext); // biometrics data changed
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -131,7 +131,7 @@ public class FaceUpdater {
|
||||
@Override
|
||||
public void onRemovalSucceeded(@Nullable Face fp, int remaining) {
|
||||
mCallback.onRemovalSucceeded(fp, remaining);
|
||||
BiometricsSafetySource.sendSafetyData(mContext); // biometrics data changed
|
||||
BiometricsSafetySource.onBiometricsChanged(mContext); // biometrics data changed
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@@ -88,7 +88,7 @@ public class FingerprintUpdater {
|
||||
public void onEnrollmentProgress(int remaining) {
|
||||
mCallback.onEnrollmentProgress(remaining);
|
||||
if (remaining == 0) {
|
||||
BiometricsSafetySource.sendSafetyData(mContext); // biometrics data changed
|
||||
BiometricsSafetySource.onBiometricsChanged(mContext); // biometrics data changed
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -115,7 +115,7 @@ public class FingerprintUpdater {
|
||||
@Override
|
||||
public void onRemovalSucceeded(@Nullable Fingerprint fp, int remaining) {
|
||||
mCallback.onRemovalSucceeded(fp, remaining);
|
||||
BiometricsSafetySource.sendSafetyData(mContext); // biometrics data changed
|
||||
BiometricsSafetySource.onBiometricsChanged(mContext); // biometrics data changed
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@@ -22,6 +22,7 @@ import android.content.Intent;
|
||||
import android.hardware.face.FaceManager;
|
||||
import android.hardware.fingerprint.FingerprintManager;
|
||||
import android.os.Bundle;
|
||||
import android.safetycenter.SafetyEvent;
|
||||
import android.safetycenter.SafetySourceData;
|
||||
import android.safetycenter.SafetySourceStatus;
|
||||
|
||||
@@ -38,11 +39,10 @@ public final class BiometricsSafetySource {
|
||||
|
||||
public static final String SAFETY_SOURCE_ID = "Biometrics";
|
||||
|
||||
private BiometricsSafetySource() {
|
||||
}
|
||||
private BiometricsSafetySource() {}
|
||||
|
||||
/** Sends biometric safety data to Safety Center. */
|
||||
public static void sendSafetyData(Context context) {
|
||||
/** Sets biometric safety data for Safety Center. */
|
||||
public static void setSafetySourceData(Context context, SafetyEvent safetyEvent) {
|
||||
if (!SafetyCenterManagerWrapper.get().isEnabled(context)) {
|
||||
return;
|
||||
}
|
||||
@@ -54,13 +54,14 @@ public final class BiometricsSafetySource {
|
||||
if (combinedBiometricStatusUtils.isAvailable()) {
|
||||
final RestrictedLockUtils.EnforcedAdmin disablingAdmin =
|
||||
combinedBiometricStatusUtils.getDisablingAdmin();
|
||||
sendBiometricSafetySourceData(context,
|
||||
setBiometricSafetySourceData(context,
|
||||
context.getString(R.string.security_settings_biometric_preference_title),
|
||||
combinedBiometricStatusUtils.getSummary(),
|
||||
biometricNavigationUtils.getBiometricSettingsIntent(context,
|
||||
combinedBiometricStatusUtils.getSettingsClassName(), disablingAdmin,
|
||||
Bundle.EMPTY),
|
||||
disablingAdmin == null /* enabled */);
|
||||
disablingAdmin == null /* enabled */,
|
||||
safetyEvent);
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -70,13 +71,15 @@ public final class BiometricsSafetySource {
|
||||
if (faceStatusUtils.isAvailable()) {
|
||||
final RestrictedLockUtils.EnforcedAdmin disablingAdmin =
|
||||
faceStatusUtils.getDisablingAdmin();
|
||||
sendBiometricSafetySourceData(context,
|
||||
setBiometricSafetySourceData(context,
|
||||
context.getString(R.string.security_settings_face_preference_title),
|
||||
faceStatusUtils.getSummary(),
|
||||
biometricNavigationUtils.getBiometricSettingsIntent(context,
|
||||
faceStatusUtils.getSettingsClassName(), disablingAdmin,
|
||||
Bundle.EMPTY),
|
||||
disablingAdmin == null /* enabled */);
|
||||
disablingAdmin == null /* enabled */,
|
||||
safetyEvent);
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -87,27 +90,37 @@ public final class BiometricsSafetySource {
|
||||
if (fingerprintStatusUtils.isAvailable()) {
|
||||
final RestrictedLockUtils.EnforcedAdmin disablingAdmin =
|
||||
fingerprintStatusUtils.getDisablingAdmin();
|
||||
sendBiometricSafetySourceData(context,
|
||||
setBiometricSafetySourceData(context,
|
||||
context.getString(R.string.security_settings_fingerprint_preference_title),
|
||||
fingerprintStatusUtils.getSummary(),
|
||||
biometricNavigationUtils.getBiometricSettingsIntent(context,
|
||||
fingerprintStatusUtils.getSettingsClassName(), disablingAdmin,
|
||||
Bundle.EMPTY),
|
||||
disablingAdmin == null /* enabled */);
|
||||
disablingAdmin == null /* enabled */,
|
||||
safetyEvent);
|
||||
}
|
||||
}
|
||||
|
||||
private static void sendBiometricSafetySourceData(Context context, String title, String summary,
|
||||
Intent clickIntent, boolean enabled) {
|
||||
/** Notifies Safety Center of a change in biometrics settings. */
|
||||
public static void onBiometricsChanged(Context context) {
|
||||
setSafetySourceData(
|
||||
context,
|
||||
new SafetyEvent.Builder(SafetyEvent.SAFETY_EVENT_TYPE_SOURCE_STATE_CHANGED).build()
|
||||
);
|
||||
}
|
||||
|
||||
private static void setBiometricSafetySourceData(Context context, String title, String summary,
|
||||
Intent clickIntent, boolean enabled, SafetyEvent safetyEvent) {
|
||||
final PendingIntent pendingIntent = createPendingIntent(context, clickIntent);
|
||||
|
||||
final SafetySourceStatus status = new SafetySourceStatus.Builder(title, summary,
|
||||
SafetySourceStatus.STATUS_LEVEL_NONE, pendingIntent)
|
||||
.setEnabled(enabled).build();
|
||||
final SafetySourceData safetySourceData = new SafetySourceData.Builder(SAFETY_SOURCE_ID)
|
||||
.setStatus(status).build();
|
||||
final SafetySourceData safetySourceData =
|
||||
new SafetySourceData.Builder().setStatus(status).build();
|
||||
|
||||
SafetyCenterManagerWrapper.get().sendSafetyCenterUpdate(context, safetySourceData);
|
||||
SafetyCenterManagerWrapper.get().setSafetySourceData(
|
||||
context, SAFETY_SOURCE_ID, safetySourceData, safetyEvent);
|
||||
}
|
||||
|
||||
private static PendingIntent createPendingIntent(Context context, Intent intent) {
|
||||
|
@@ -16,11 +16,14 @@
|
||||
|
||||
package com.android.settings.safetycenter;
|
||||
|
||||
import static android.safetycenter.SafetyEvent.SAFETY_EVENT_TYPE_SOURCE_STATE_CHANGED;
|
||||
|
||||
import android.app.PendingIntent;
|
||||
import android.app.settings.SettingsEnums;
|
||||
import android.content.Context;
|
||||
import android.content.Intent;
|
||||
import android.os.UserHandle;
|
||||
import android.safetycenter.SafetyEvent;
|
||||
import android.safetycenter.SafetySourceData;
|
||||
import android.safetycenter.SafetySourceIssue;
|
||||
import android.safetycenter.SafetySourceStatus;
|
||||
@@ -42,9 +45,10 @@ public final class LockScreenSafetySource {
|
||||
private LockScreenSafetySource() {
|
||||
}
|
||||
|
||||
/** Sends lock screen safety data to Safety Center. */
|
||||
public static void sendSafetyData(Context context,
|
||||
ScreenLockPreferenceDetailsUtils screenLockPreferenceDetailsUtils) {
|
||||
/** Sets lock screen safety data for Safety Center. */
|
||||
public static void setSafetySourceData(Context context,
|
||||
ScreenLockPreferenceDetailsUtils screenLockPreferenceDetailsUtils,
|
||||
SafetyEvent safetyEvent) {
|
||||
if (!SafetyCenterManagerWrapper.get().isEnabled(context)) {
|
||||
return;
|
||||
}
|
||||
@@ -71,21 +75,27 @@ public final class LockScreenSafetySource {
|
||||
.setEnabled(
|
||||
!screenLockPreferenceDetailsUtils.isPasswordQualityManaged(userId, admin))
|
||||
.setIconAction(gearMenuIconAction).build();
|
||||
final SafetySourceData.Builder safetySourceDataBuilder = new SafetySourceData.Builder(
|
||||
SAFETY_SOURCE_ID).setStatus(status);
|
||||
final SafetySourceData.Builder safetySourceDataBuilder =
|
||||
new SafetySourceData.Builder().setStatus(status);
|
||||
if (!screenLockPreferenceDetailsUtils.isLockPatternSecure()) {
|
||||
safetySourceDataBuilder.addIssue(createNoScreenLockIssue(context, pendingIntent));
|
||||
}
|
||||
final SafetySourceData safetySourceData = safetySourceDataBuilder.build();
|
||||
|
||||
SafetyCenterManagerWrapper.get().sendSafetyCenterUpdate(context, safetySourceData);
|
||||
SafetyCenterManagerWrapper.get().setSafetySourceData(
|
||||
context,
|
||||
SAFETY_SOURCE_ID,
|
||||
safetySourceData,
|
||||
safetyEvent
|
||||
);
|
||||
}
|
||||
|
||||
/** Notifies Safety Center of a change in lock screen settings. */
|
||||
public static void onLockScreenChange(Context context) {
|
||||
sendSafetyData(
|
||||
setSafetySourceData(
|
||||
context,
|
||||
new ScreenLockPreferenceDetailsUtils(context, SettingsEnums.SAFETY_CENTER));
|
||||
new ScreenLockPreferenceDetailsUtils(context, SettingsEnums.SAFETY_CENTER),
|
||||
new SafetyEvent.Builder(SAFETY_EVENT_TYPE_SOURCE_STATE_CHANGED).build());
|
||||
}
|
||||
|
||||
private static IconAction createGearMenuIconAction(Context context,
|
||||
|
@@ -18,6 +18,7 @@ package com.android.settings.safetycenter;
|
||||
|
||||
import android.content.Context;
|
||||
import android.safetycenter.SafetyCenterManager;
|
||||
import android.safetycenter.SafetyEvent;
|
||||
import android.safetycenter.SafetySourceData;
|
||||
import android.util.Log;
|
||||
|
||||
@@ -26,7 +27,12 @@ import com.android.internal.annotations.VisibleForTesting;
|
||||
/** A wrapper for the SafetyCenterManager system service. */
|
||||
public class SafetyCenterManagerWrapper {
|
||||
|
||||
private static final String TAG = "SafetyCenterManagerWrapper";
|
||||
/**
|
||||
* Tag for logging.
|
||||
*
|
||||
* <p>The tag is restricted to 23 characters (the maximum allowed for Android logging).
|
||||
*/
|
||||
private static final String TAG = "SafetyCenterManagerWrap";
|
||||
|
||||
@VisibleForTesting
|
||||
public static SafetyCenterManagerWrapper sInstance;
|
||||
@@ -41,8 +47,10 @@ public class SafetyCenterManagerWrapper {
|
||||
return sInstance;
|
||||
}
|
||||
|
||||
/** Sends updated safety source data to Safety Center. */
|
||||
public void sendSafetyCenterUpdate(Context context, SafetySourceData safetySourceData) {
|
||||
/** Sets the latest safety source data for Safety Center. */
|
||||
public void setSafetySourceData(Context context, String safetySourceId,
|
||||
SafetySourceData safetySourceData,
|
||||
SafetyEvent safetyEvent) {
|
||||
SafetyCenterManager safetyCenterManager =
|
||||
context.getSystemService(SafetyCenterManager.class);
|
||||
|
||||
@@ -52,7 +60,11 @@ public class SafetyCenterManagerWrapper {
|
||||
}
|
||||
|
||||
try {
|
||||
safetyCenterManager.sendSafetyCenterUpdate(safetySourceData);
|
||||
safetyCenterManager.setSafetySourceData(
|
||||
safetySourceId,
|
||||
safetySourceData,
|
||||
safetyEvent
|
||||
);
|
||||
} catch (Exception e) {
|
||||
Log.e(TAG, "Failed to send SafetySourceData", e);
|
||||
return;
|
||||
|
@@ -19,11 +19,14 @@ package com.android.settings.safetycenter;
|
||||
import static android.content.Intent.ACTION_BOOT_COMPLETED;
|
||||
import static android.safetycenter.SafetyCenterManager.ACTION_REFRESH_SAFETY_SOURCES;
|
||||
import static android.safetycenter.SafetyCenterManager.EXTRA_REFRESH_SAFETY_SOURCE_IDS;
|
||||
import static android.safetycenter.SafetyEvent.SAFETY_EVENT_TYPE_DEVICE_REBOOTED;
|
||||
import static android.safetycenter.SafetyEvent.SAFETY_EVENT_TYPE_REFRESH_REQUESTED;
|
||||
|
||||
import android.app.settings.SettingsEnums;
|
||||
import android.content.BroadcastReceiver;
|
||||
import android.content.Context;
|
||||
import android.content.Intent;
|
||||
import android.safetycenter.SafetyEvent;
|
||||
|
||||
import com.android.settings.security.ScreenLockPreferenceDetailsUtils;
|
||||
|
||||
@@ -34,6 +37,11 @@ import java.util.List;
|
||||
/** Broadcast receiver for handling requests from Safety Center for fresh data. */
|
||||
public class SafetySourceBroadcastReceiver extends BroadcastReceiver {
|
||||
|
||||
private static final SafetyEvent EVENT_REFRESH_REQUESTED =
|
||||
new SafetyEvent.Builder(SAFETY_EVENT_TYPE_REFRESH_REQUESTED).build();
|
||||
private static final SafetyEvent EVENT_DEVICE_REBOOTED =
|
||||
new SafetyEvent.Builder(SAFETY_EVENT_TYPE_DEVICE_REBOOTED).build();
|
||||
|
||||
@Override
|
||||
public void onReceive(Context context, Intent intent) {
|
||||
if (!SafetyCenterManagerWrapper.get().isEnabled(context)) {
|
||||
@@ -44,31 +52,37 @@ public class SafetySourceBroadcastReceiver extends BroadcastReceiver {
|
||||
String[] sourceIdsExtra =
|
||||
intent.getStringArrayExtra(EXTRA_REFRESH_SAFETY_SOURCE_IDS);
|
||||
if (sourceIdsExtra != null && sourceIdsExtra.length > 0) {
|
||||
refreshSafetySources(context, ImmutableList.copyOf(sourceIdsExtra));
|
||||
refreshSafetySources(
|
||||
context,
|
||||
ImmutableList.copyOf(sourceIdsExtra),
|
||||
EVENT_REFRESH_REQUESTED);
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
if (ACTION_BOOT_COMPLETED.equals(intent.getAction())) {
|
||||
refreshAllSafetySources(context);
|
||||
refreshAllSafetySources(context, EVENT_DEVICE_REBOOTED);
|
||||
}
|
||||
}
|
||||
|
||||
private static void refreshSafetySources(Context context, List<String> sourceIds) {
|
||||
private static void refreshSafetySources(Context context, List<String> sourceIds,
|
||||
SafetyEvent safetyEvent) {
|
||||
if (sourceIds.contains(LockScreenSafetySource.SAFETY_SOURCE_ID)) {
|
||||
LockScreenSafetySource.sendSafetyData(context,
|
||||
new ScreenLockPreferenceDetailsUtils(context, SettingsEnums.SAFETY_CENTER));
|
||||
LockScreenSafetySource.setSafetySourceData(context,
|
||||
new ScreenLockPreferenceDetailsUtils(context, SettingsEnums.SAFETY_CENTER),
|
||||
safetyEvent);
|
||||
}
|
||||
|
||||
if (sourceIds.contains(BiometricsSafetySource.SAFETY_SOURCE_ID)) {
|
||||
BiometricsSafetySource.sendSafetyData(context);
|
||||
BiometricsSafetySource.setSafetySourceData(context, safetyEvent);
|
||||
}
|
||||
}
|
||||
|
||||
private static void refreshAllSafetySources(Context context) {
|
||||
LockScreenSafetySource.sendSafetyData(context,
|
||||
new ScreenLockPreferenceDetailsUtils(context, SettingsEnums.SAFETY_CENTER));
|
||||
BiometricsSafetySource.sendSafetyData(context);
|
||||
private static void refreshAllSafetySources(Context context, SafetyEvent safetyEvent) {
|
||||
LockScreenSafetySource.setSafetySourceData(context,
|
||||
new ScreenLockPreferenceDetailsUtils(context, SettingsEnums.SAFETY_CENTER),
|
||||
safetyEvent);
|
||||
BiometricsSafetySource.setSafetySourceData(context, safetyEvent);
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user