summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJohn Reck <jreck@google.com>2011-02-23 14:41:45 -0800
committerJohn Reck <jreck@google.com>2011-02-23 15:08:59 -0800
commit17e78fd06905d090cfab4c4f7313bd4b3eec5473 (patch)
treec3c3de1782f7963002efb70430a7cffc49283621
parent128e6fc298d695790d1d5c378306cf509a957dce (diff)
downloadpackages_apps_Browser-17e78fd06905d090cfab4c4f7313bd4b3eec5473.zip
packages_apps_Browser-17e78fd06905d090cfab4c4f7313bd4b3eec5473.tar.gz
packages_apps_Browser-17e78fd06905d090cfab4c4f7313bd4b3eec5473.tar.bz2
Prevent PARENT account from not matching inserted values
Bug: 3481259 Adds a check in insert to make sure that the PARENT folder has the same account_* values as the bookmark being inserted. Change-Id: I5e42e94fd4eac39eb73047e4246d2102d8e55d82
-rw-r--r--src/com/android/browser/provider/BrowserProvider2.java39
1 files changed, 34 insertions, 5 deletions
diff --git a/src/com/android/browser/provider/BrowserProvider2.java b/src/com/android/browser/provider/BrowserProvider2.java
index 3033db4..94b1651 100644
--- a/src/com/android/browser/provider/BrowserProvider2.java
+++ b/src/com/android/browser/provider/BrowserProvider2.java
@@ -1142,12 +1142,20 @@ public class BrowserProvider2 extends SQLiteContentProvider {
values.put(Bookmarks.DATE_MODIFIED, now);
values.put(Bookmarks.DIRTY, 1);
+ String accountType = values
+ .getAsString(Bookmarks.ACCOUNT_TYPE);
+ String accountName = values
+ .getAsString(Bookmarks.ACCOUNT_NAME);
+ boolean hasParent = values.containsKey(Bookmarks.PARENT);
+ if (hasParent) {
+ // Let's make sure it's valid
+ long parentId = values.getAsLong(Bookmarks.PARENT);
+ hasParent = isValidParent(
+ accountType, accountName, parentId);
+ }
+
// If no parent is set default to the "Bookmarks Bar" folder
- if (!values.containsKey(Bookmarks.PARENT)) {
- String accountType = values
- .getAsString(Bookmarks.ACCOUNT_TYPE);
- String accountName = values
- .getAsString(Bookmarks.ACCOUNT_NAME);
+ if (!hasParent) {
values.put(Bookmarks.PARENT,
queryDefaultFolderId(accountName, accountType));
}
@@ -1226,6 +1234,27 @@ public class BrowserProvider2 extends SQLiteContentProvider {
}
}
+ private boolean isValidParent(String accountType, String accountName,
+ long parentId) {
+ Uri uri = Bookmarks.buildFolderUri(parentId);
+ Cursor c = query(uri,
+ new String[] { Bookmarks.ACCOUNT_NAME, Bookmarks.ACCOUNT_TYPE },
+ null, null, null);
+ try {
+ if (c.moveToFirst()) {
+ String parentName = c.getString(0);
+ String parentType = c.getString(1);
+ if (TextUtils.equals(accountName, parentName)
+ && TextUtils.equals(accountType, parentType)) {
+ return true;
+ }
+ }
+ return false;
+ } finally {
+ c.close();
+ }
+ }
+
private void filterSearchClient(String[] selectionArgs) {
if (selectionArgs != null) {
for (int i = 0; i < selectionArgs.length; i++) {