diff options
| author | 2021-04-01 02:35:18 +0000 | |
|---|---|---|
| committer | 2021-04-01 02:35:18 +0000 | |
| commit | 4f1799e6c8a75d110179eb1d09dd5d889111a0dc (patch) | |
| tree | 2a78074d91742e905a1ef904537906ce52dc15cb | |
| parent | 939a1ea1482b48b6e0abc457b3819f7b39ac10dd (diff) | |
| parent | e851fc58d6529af7cd9ae4ed1d61825440815fe4 (diff) | |
Merge "wifidisplay: restrict broadcast by the proper permission" into rvc-qpr-dev am: e851fc58d6
Original change: https://googleplex-android-review.googlesource.com/c/platform/frameworks/base/+/13824713
Change-Id: I128bd35ad9dea6d9085f746790af2c1bc2344b47
| -rw-r--r-- | core/java/android/hardware/display/DisplayManager.java | 3 | ||||
| -rw-r--r-- | services/core/java/com/android/server/display/WifiDisplayAdapter.java | 7 |
2 files changed, 9 insertions, 1 deletions
diff --git a/core/java/android/hardware/display/DisplayManager.java b/core/java/android/hardware/display/DisplayManager.java index 7a383d993389..d83b4321a8ab 100644 --- a/core/java/android/hardware/display/DisplayManager.java +++ b/core/java/android/hardware/display/DisplayManager.java @@ -62,6 +62,9 @@ public final class DisplayManager { * {@link #EXTRA_WIFI_DISPLAY_STATUS} extra. * </p><p> * This broadcast is only sent to registered receivers and can only be sent by the system. + * </p><p> + * {@link android.Manifest.permission#ACCESS_FINE_LOCATION} permission is required to + * receive this broadcast. * </p> * @hide */ diff --git a/services/core/java/com/android/server/display/WifiDisplayAdapter.java b/services/core/java/com/android/server/display/WifiDisplayAdapter.java index 57323170b327..551df49b550f 100644 --- a/services/core/java/com/android/server/display/WifiDisplayAdapter.java +++ b/services/core/java/com/android/server/display/WifiDisplayAdapter.java @@ -91,6 +91,10 @@ final class WifiDisplayAdapter extends DisplayAdapter { private boolean mPendingStatusChangeBroadcast; + private static final String[] RECEIVER_PERMISSIONS_FOR_BROADCAST = { + android.Manifest.permission.ACCESS_FINE_LOCATION, + }; + // Called with SyncRoot lock held. public WifiDisplayAdapter(DisplayManagerService.SyncRoot syncRoot, Context context, Handler handler, Listener listener, @@ -432,7 +436,8 @@ final class WifiDisplayAdapter extends DisplayAdapter { } // Send protected broadcast about wifi display status to registered receivers. - getContext().sendBroadcastAsUser(intent, UserHandle.ALL); + getContext().createContextAsUser(UserHandle.ALL, 0) + .sendBroadcastWithMultiplePermissions(intent, RECEIVER_PERMISSIONS_FOR_BROADCAST); } private final BroadcastReceiver mBroadcastReceiver = new BroadcastReceiver() { |