am 28096c49: Merge "Fix issue #15828903: Intent.parseUri allows call to FLAG_GRANT_*_URI_PERMISSION" into lmp-mr1-dev
* commit '28096c49d81ddcdde51627e9d396947efdc4f508': Fix issue #15828903: Intent.parseUri allows call to FLAG_GRANT_*_URI_PERMISSION
This commit is contained in:
@@ -7821,6 +7821,7 @@ package android.content {
|
||||
field public static final int FLAG_RECEIVER_REGISTERED_ONLY = 1073741824; // 0x40000000
|
||||
field public static final int FLAG_RECEIVER_REPLACE_PENDING = 536870912; // 0x20000000
|
||||
field public static final java.lang.String METADATA_DOCK_HOME = "android.dock_home";
|
||||
field public static final int URI_ALLOW_UNSAFE = 4; // 0x4
|
||||
field public static final int URI_ANDROID_APP_SCHEME = 2; // 0x2
|
||||
field public static final int URI_INTENT_SCHEME = 1; // 0x1
|
||||
}
|
||||
|
||||
@@ -55,12 +55,9 @@ import android.text.TextUtils;
|
||||
import android.util.AndroidException;
|
||||
import android.util.ArrayMap;
|
||||
import android.view.IWindowManager;
|
||||
import android.view.View;
|
||||
|
||||
import com.android.internal.os.BaseCommand;
|
||||
|
||||
import dalvik.system.VMRuntime;
|
||||
|
||||
import java.io.BufferedReader;
|
||||
import java.io.File;
|
||||
import java.io.FileNotFoundException;
|
||||
@@ -619,7 +616,7 @@ public class Am extends BaseCommand {
|
||||
// The argument is a URI. Fully parse it, and use that result
|
||||
// to fill in any data not specified so far.
|
||||
baseIntent = Intent.parseUri(arg, Intent.URI_INTENT_SCHEME
|
||||
| Intent.URI_ANDROID_APP_SCHEME);
|
||||
| Intent.URI_ANDROID_APP_SCHEME | Intent.URI_ALLOW_UNSAFE);
|
||||
} else if (arg.indexOf('/') >= 0) {
|
||||
// The argument is a component name. Build an Intent to launch
|
||||
// it.
|
||||
|
||||
@@ -4010,6 +4010,20 @@ public class Intent implements Parcelable, Cloneable {
|
||||
*/
|
||||
public static final int URI_ANDROID_APP_SCHEME = 1<<1;
|
||||
|
||||
/**
|
||||
* Flag for use with {@link #toUri} and {@link #parseUri}: allow parsing
|
||||
* of unsafe information. In particular, the flags {@link #FLAG_GRANT_READ_URI_PERMISSION},
|
||||
* {@link #FLAG_GRANT_WRITE_URI_PERMISSION}, {@link #FLAG_GRANT_PERSISTABLE_URI_PERMISSION},
|
||||
* and {@link #FLAG_GRANT_PREFIX_URI_PERMISSION} flags can not be set, so that the
|
||||
* generated Intent can not cause unexpected data access to happen.
|
||||
*
|
||||
* <p>If you do not trust the source of the URI being parsed, you should still do further
|
||||
* processing to protect yourself from it. In particular, when using it to start an
|
||||
* activity you should usually add in {@link #CATEGORY_BROWSABLE} to limit the activities
|
||||
* that can handle it.</p>
|
||||
*/
|
||||
public static final int URI_ALLOW_UNSAFE = 1<<2;
|
||||
|
||||
// ---------------------------------------------------------------------
|
||||
|
||||
private String mAction;
|
||||
@@ -4309,7 +4323,7 @@ public class Intent implements Parcelable, Cloneable {
|
||||
// old format Intent URI
|
||||
} else if (!uri.startsWith("#Intent;", i)) {
|
||||
if (!androidApp) {
|
||||
return getIntentOld(uri);
|
||||
return getIntentOld(uri, flags);
|
||||
} else {
|
||||
i = -1;
|
||||
}
|
||||
@@ -4359,6 +4373,9 @@ public class Intent implements Parcelable, Cloneable {
|
||||
// launch flags
|
||||
else if (uri.startsWith("launchFlags=", i)) {
|
||||
intent.mFlags = Integer.decode(value).intValue();
|
||||
if ((flags& URI_ALLOW_UNSAFE) == 0) {
|
||||
intent.mFlags &= ~IMMUTABLE_FLAGS;
|
||||
}
|
||||
}
|
||||
|
||||
// package
|
||||
@@ -4488,6 +4505,10 @@ public class Intent implements Parcelable, Cloneable {
|
||||
}
|
||||
|
||||
public static Intent getIntentOld(String uri) throws URISyntaxException {
|
||||
return getIntentOld(uri, 0);
|
||||
}
|
||||
|
||||
private static Intent getIntentOld(String uri, int flags) throws URISyntaxException {
|
||||
Intent intent;
|
||||
|
||||
int i = uri.lastIndexOf('#');
|
||||
@@ -4536,6 +4557,9 @@ public class Intent implements Parcelable, Cloneable {
|
||||
i += 12;
|
||||
int j = uri.indexOf(')', i);
|
||||
intent.mFlags = Integer.decode(uri.substring(i, j)).intValue();
|
||||
if ((flags& URI_ALLOW_UNSAFE) == 0) {
|
||||
intent.mFlags &= ~IMMUTABLE_FLAGS;
|
||||
}
|
||||
i = j + 1;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user