Merge "Resolve StatusHints image exploit across user." into rvc-dev

This commit is contained in:
Pranav Madapurmath
2023-06-02 23:48:37 +00:00
committed by Android (Google) Code Review
2 changed files with 61 additions and 4 deletions

View File

@@ -21,12 +21,12 @@ import android.os.Bundle;
import android.os.Parcel;
import android.os.Parcelable;
import com.android.internal.telecom.IVideoProvider;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import com.android.internal.telecom.IVideoProvider;
/**
* A parcelable representation of a conference connection.
* @hide
@@ -287,6 +287,14 @@ public final class ParcelableConference implements Parcelable {
return mCallDirection;
}
public String getCallerDisplayName() {
return mCallerDisplayName;
}
public int getCallerDisplayNamePresentation() {
return mCallerDisplayNamePresentation;
}
public static final @android.annotation.NonNull Parcelable.Creator<ParcelableConference> CREATOR =
new Parcelable.Creator<ParcelableConference> () {
@Override

View File

@@ -16,14 +16,19 @@
package android.telecom;
import android.annotation.Nullable;
import android.annotation.SystemApi;
import android.content.ComponentName;
import android.content.Context;
import android.graphics.drawable.Drawable;
import android.graphics.drawable.Icon;
import android.os.Binder;
import android.os.Bundle;
import android.os.Parcel;
import android.os.Parcelable;
import android.os.UserHandle;
import com.android.internal.annotations.VisibleForTesting;
import java.util.Objects;
@@ -33,7 +38,7 @@ import java.util.Objects;
public final class StatusHints implements Parcelable {
private final CharSequence mLabel;
private final Icon mIcon;
private Icon mIcon;
private final Bundle mExtras;
/**
@@ -48,10 +53,30 @@ public final class StatusHints implements Parcelable {
public StatusHints(CharSequence label, Icon icon, Bundle extras) {
mLabel = label;
mIcon = icon;
mIcon = validateAccountIconUserBoundary(icon, Binder.getCallingUserHandle());
mExtras = extras;
}
/**
* @param icon
* @hide
*/
@VisibleForTesting
public StatusHints(@Nullable Icon icon) {
mLabel = null;
mExtras = null;
mIcon = icon;
}
/**
*
* @param icon
* @hide
*/
public void setIcon(@Nullable Icon icon) {
mIcon = icon;
}
/**
* @return A package used to load the icon.
*
@@ -112,6 +137,30 @@ public final class StatusHints implements Parcelable {
return 0;
}
/**
* Validates the StatusHints image icon to see if it's not in the calling user space.
* Invalidates the icon if so, otherwise returns back the original icon.
*
* @param icon
* @return icon (validated)
* @hide
*/
public static Icon validateAccountIconUserBoundary(Icon icon, UserHandle callingUserHandle) {
// Refer to Icon#getUriString for context. The URI string is invalid for icons of
// incompatible types.
if (icon != null && (icon.getType() == Icon.TYPE_URI
|| icon.getType() == Icon.TYPE_URI_ADAPTIVE_BITMAP)) {
String encodedUser = icon.getUri().getEncodedUserInfo();
// If there is no encoded user, the URI is calling into the calling user space
if (encodedUser != null) {
int userId = Integer.parseInt(encodedUser);
// Do not try to save the icon if the user id isn't in the calling user space.
if (userId != callingUserHandle.getIdentifier()) return null;
}
}
return icon;
}
@Override
public void writeToParcel(Parcel out, int flags) {
out.writeCharSequence(mLabel);