summaryrefslogtreecommitdiffstats
path: root/src/com/android/providers/downloads/DownloadInfo.java
diff options
context:
space:
mode:
authorJeff Sharkey <jsharkey@android.com>2015-07-13 10:25:58 -0700
committerJeff Sharkey <jsharkey@android.com>2015-07-14 13:04:39 -0700
commited30deae5fe5b9de142b44933001c9b098c47712 (patch)
treef2bca00dbce87798aca9e73c43b8abb074e10d14 /src/com/android/providers/downloads/DownloadInfo.java
parentd473cf8f85f60d53b20270a263afe6b138671cb5 (diff)
downloadandroid_packages_providers_DownloadProvider-ed30deae5fe5b9de142b44933001c9b098c47712.tar.gz
android_packages_providers_DownloadProvider-ed30deae5fe5b9de142b44933001c9b098c47712.tar.bz2
android_packages_providers_DownloadProvider-ed30deae5fe5b9de142b44933001c9b098c47712.zip
Relax permissions on package-specific paths.
Normally apps must hold the WRITE_EXTERNAL_STORAGE permission in order to use DownloadManager. However, now that the platform has relaxed permissions on package-specific directories, we relax the DownloadManager check in a similar way. This also opens up using DownloadManager to save files on secondary external storage devices. Fix bug so that we now check the relevant volume state when thinking about resuming a download. Bug: 22135060 Change-Id: If439340ea48789ea167f49709b5b69a4f0883150
Diffstat (limited to 'src/com/android/providers/downloads/DownloadInfo.java')
-rw-r--r--src/com/android/providers/downloads/DownloadInfo.java14
1 files changed, 13 insertions, 1 deletions
diff --git a/src/com/android/providers/downloads/DownloadInfo.java b/src/com/android/providers/downloads/DownloadInfo.java
index 2423c0d7..bee5c4a9 100644
--- a/src/com/android/providers/downloads/DownloadInfo.java
+++ b/src/com/android/providers/downloads/DownloadInfo.java
@@ -16,6 +16,8 @@
package com.android.providers.downloads;
+import static com.android.providers.downloads.Constants.TAG;
+
import android.app.DownloadManager;
import android.content.ContentResolver;
import android.content.ContentUris;
@@ -31,12 +33,14 @@ import android.os.Environment;
import android.provider.Downloads;
import android.provider.Downloads.Impl;
import android.text.TextUtils;
+import android.util.Log;
import android.util.Pair;
import com.android.internal.annotations.GuardedBy;
import com.android.internal.util.IndentingPrintWriter;
import java.io.CharArrayWriter;
+import java.io.File;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
@@ -344,7 +348,15 @@ public class DownloadInfo {
return restartTime(now) <= now;
case Downloads.Impl.STATUS_DEVICE_NOT_FOUND_ERROR:
// is the media mounted?
- return Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED);
+ final Uri uri = Uri.parse(mUri);
+ if (ContentResolver.SCHEME_FILE.equals(uri.getScheme())) {
+ final File file = new File(uri.getPath());
+ return Environment.MEDIA_MOUNTED
+ .equals(Environment.getExternalStorageState(file));
+ } else {
+ Log.w(TAG, "Expected file URI on external storage: " + mUri);
+ return false;
+ }
case Downloads.Impl.STATUS_INSUFFICIENT_SPACE_ERROR:
// avoids repetition of retrying download
return false;