Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 57e6a44d authored by TreeHugger Robot's avatar TreeHugger Robot Committed by Automerger Merge Worker
Browse files

Merge "Change createRequestInteractAcrossProfilesIntent to throw Exception"...

Merge "Change createRequestInteractAcrossProfilesIntent to throw Exception" into rvc-dev am: cff44bd8

Change-Id: I0a2dac1586db9855d28294bb699b351be75bf1fb
parents 949ad273 cff44bd8
Loading
Loading
Loading
Loading
+1 −1
Original line number Original line Diff line number Diff line
@@ -11572,7 +11572,7 @@ package android.content.pm {
  public class CrossProfileApps {
  public class CrossProfileApps {
    method public boolean canInteractAcrossProfiles();
    method public boolean canInteractAcrossProfiles();
    method public boolean canRequestInteractAcrossProfiles();
    method public boolean canRequestInteractAcrossProfiles();
    method @Nullable public android.content.Intent createRequestInteractAcrossProfilesIntent();
    method @NonNull public android.content.Intent createRequestInteractAcrossProfilesIntent();
    method @NonNull public android.graphics.drawable.Drawable getProfileSwitchingIconDrawable(@NonNull android.os.UserHandle);
    method @NonNull public android.graphics.drawable.Drawable getProfileSwitchingIconDrawable(@NonNull android.os.UserHandle);
    method @NonNull public CharSequence getProfileSwitchingLabel(@NonNull android.os.UserHandle);
    method @NonNull public CharSequence getProfileSwitchingLabel(@NonNull android.os.UserHandle);
    method @NonNull public java.util.List<android.os.UserHandle> getTargetUserProfiles();
    method @NonNull public java.util.List<android.os.UserHandle> getTargetUserProfiles();
+5 −4
Original line number Original line Diff line number Diff line
@@ -334,7 +334,7 @@ public class CrossProfileApps {
     * Returns an {@link Intent} to open the settings page that allows the user to decide whether
     * Returns an {@link Intent} to open the settings page that allows the user to decide whether
     * the calling app can interact across profiles.
     * the calling app can interact across profiles.
     *
     *
     * <p>Returns {@code null} if {@link #canRequestInteractAcrossProfiles()} is {@code false}.
     * <p>The method {@link #canRequestInteractAcrossProfiles()} must be returning {@code true}.
     *
     *
     * <p>Note that the user may already have given consent and the app may already be able to
     * <p>Note that the user may already have given consent and the app may already be able to
     * interact across profiles, even if {@link #canRequestInteractAcrossProfiles()} is {@code
     * interact across profiles, even if {@link #canRequestInteractAcrossProfiles()} is {@code
@@ -345,11 +345,12 @@ public class CrossProfileApps {
     * the app can interact across profiles
     * the app can interact across profiles
     *
     *
     * @throws SecurityException if {@code mContext.getPackageName()} does not belong to the
     * @throws SecurityException if {@code mContext.getPackageName()} does not belong to the
     * calling UID.
     * calling UID, or {@link #canRequestInteractAcrossProfiles()} is {@code false}.
     */
     */
    public @Nullable Intent createRequestInteractAcrossProfilesIntent() {
    public @NonNull Intent createRequestInteractAcrossProfilesIntent() {
        if (!canRequestInteractAcrossProfiles()) {
        if (!canRequestInteractAcrossProfiles()) {
            return null;
            throw new SecurityException(
                    "The calling package can not request to interact across profiles.");
        }
        }
        final Intent settingsIntent = new Intent();
        final Intent settingsIntent = new Intent();
        settingsIntent.setAction(Settings.ACTION_MANAGE_CROSS_PROFILE_ACCESS);
        settingsIntent.setAction(Settings.ACTION_MANAGE_CROSS_PROFILE_ACCESS);