diff options
author | Jeff Sharkey <jsharkey@android.com> | 2015-07-13 10:25:58 -0700 |
---|---|---|
committer | Jeff Sharkey <jsharkey@android.com> | 2015-07-14 13:04:39 -0700 |
commit | ed30deae5fe5b9de142b44933001c9b098c47712 (patch) | |
tree | f2bca00dbce87798aca9e73c43b8abb074e10d14 /src/com/android/providers/downloads/DownloadInfo.java | |
parent | d473cf8f85f60d53b20270a263afe6b138671cb5 (diff) | |
download | android_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.java | 14 |
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; |