commit | 798bdd90b06f058ee1703eab2cbc6b0fca753638 | [log] [tgz] |
---|---|---|
author | Andras Kloczl <andraskloczl@google.com> | Tue Mar 09 20:38:56 2021 +0000 |
committer | András Klöczl <andraskloczl@google.com> | Thu Mar 11 00:15:27 2021 +0000 |
tree | deb7c533aa6106b24ef05284c877fd9ecc0d587e | |
parent | 385b5cafd26fd18d25af9733280118fa8e454342 [diff] |
Prevent using invalid result uri during multi user image change Test: manual Bug: 172939189 Change-Id: I3e6f6200e82e86d6a2085652906ad2d0d44814f5 Merged-In: I3e6f6200e82e86d6a2085652906ad2d0d44814f5 Merged-In: Id2e598878b3250e8b3590905c6def561e2437d55 Merged-In: I15e15ad88b768a5b679de32c5429d921d850a3cb
diff --git a/src/com/android/settings/users/EditUserPhotoController.java b/src/com/android/settings/users/EditUserPhotoController.java index 3253f79..f62a2d5 100644 --- a/src/com/android/settings/users/EditUserPhotoController.java +++ b/src/com/android/settings/users/EditUserPhotoController.java
@@ -37,6 +37,7 @@ import android.os.UserManager; import android.provider.ContactsContract.DisplayPhoto; import android.provider.MediaStore; +import android.util.EventLog; import android.util.Log; import android.view.Gravity; import android.view.View; @@ -116,6 +117,14 @@ } final Uri pictureUri = data != null && data.getData() != null ? data.getData() : mTakePictureUri; + + // Check if the result is a content uri + if (!ContentResolver.SCHEME_CONTENT.equals(pictureUri.getScheme())) { + Log.e(TAG, "Invalid pictureUri scheme: " + pictureUri.getScheme()); + EventLog.writeEvent(0x534e4554, "172939189", -1, pictureUri.getPath()); + return false; + } + switch (requestCode) { case REQUEST_CODE_CROP_PHOTO: onPhotoCropped(pictureUri, true);