summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author Jeff Sharkey <jsharkey@android.com> 2019-04-27 17:03:54 -0600
committer Jeff Sharkey <jsharkey@google.com> 2019-04-28 13:43:52 +0000
commit488162bfef392b298b9ba33e34a781270bc5629e (patch)
treefe78f01f741ffeb59939cf609f8cfacb9f22fc96
parent09f2e5c3fa9687d671890ac706e485c65d35624c (diff)
Make it clear that legacy storage is deprecated.
Bug: 131469880 Test: none Change-Id: I52e009c1ebfc59958d04e5b33a6f4228cdecfcf4
-rw-r--r--api/current.txt4
-rw-r--r--core/java/android/os/Environment.java23
2 files changed, 24 insertions, 3 deletions
diff --git a/api/current.txt b/api/current.txt
index f62c689943d8..049f51e7ff7d 100644
--- a/api/current.txt
+++ b/api/current.txt
@@ -34429,8 +34429,8 @@ package android.os {
ctor public Environment();
method public static java.io.File getDataDirectory();
method public static java.io.File getDownloadCacheDirectory();
- method public static java.io.File getExternalStorageDirectory();
- method public static java.io.File getExternalStoragePublicDirectory(String);
+ method @Deprecated public static java.io.File getExternalStorageDirectory();
+ method @Deprecated public static java.io.File getExternalStoragePublicDirectory(String);
method public static String getExternalStorageState();
method public static String getExternalStorageState(java.io.File);
method @NonNull public static java.io.File getRootDirectory();
diff --git a/core/java/android/os/Environment.java b/core/java/android/os/Environment.java
index 45946e331ef9..3716b3edaed4 100644
--- a/core/java/android/os/Environment.java
+++ b/core/java/android/os/Environment.java
@@ -24,8 +24,10 @@ import android.app.AppGlobals;
import android.app.AppOpsManager;
import android.app.admin.DevicePolicyManager;
import android.content.Context;
+import android.content.Intent;
import android.os.storage.StorageManager;
import android.os.storage.StorageVolume;
+import android.provider.MediaStore;
import android.text.TextUtils;
import android.util.Log;
@@ -529,7 +531,8 @@ public class Environment {
* <p>
* Writing to this path requires the
* {@link android.Manifest.permission#WRITE_EXTERNAL_STORAGE} permission,
- * and starting in {@link android.os.Build.VERSION_CODES#KITKAT}, read access requires the
+ * and starting in {@link android.os.Build.VERSION_CODES#KITKAT}, read
+ * access requires the
* {@link android.Manifest.permission#READ_EXTERNAL_STORAGE} permission,
* which is automatically granted if you hold the write permission.
* <p>
@@ -551,7 +554,16 @@ public class Environment {
*
* @see #getExternalStorageState()
* @see #isExternalStorageRemovable()
+ * @deprecated To improve user privacy, direct access to shared/external
+ * storage devices is deprecated. When an app targets
+ * {@link android.os.Build.VERSION_CODES#Q}, the path returned
+ * from this method is no longer directly accessible to apps.
+ * Apps can continue to access content stored on shared/external
+ * storage by migrating to alternatives such as
+ * {@link Context#getExternalFilesDir(String)},
+ * {@link MediaStore}, or {@link Intent#ACTION_OPEN_DOCUMENT}.
*/
+ @Deprecated
public static File getExternalStorageDirectory() {
throwIfUserRequired();
return sCurrentUser.getExternalDirs()[0];
@@ -827,7 +839,16 @@ public class Environment {
* @return Returns the File path for the directory. Note that this directory
* may not yet exist, so you must make sure it exists before using
* it such as with {@link File#mkdirs File.mkdirs()}.
+ * @deprecated To improve user privacy, direct access to shared/external
+ * storage devices is deprecated. When an app targets
+ * {@link android.os.Build.VERSION_CODES#Q}, the path returned
+ * from this method is no longer directly accessible to apps.
+ * Apps can continue to access content stored on shared/external
+ * storage by migrating to alternatives such as
+ * {@link Context#getExternalFilesDir(String)},
+ * {@link MediaStore}, or {@link Intent#ACTION_OPEN_DOCUMENT}.
*/
+ @Deprecated
public static File getExternalStoragePublicDirectory(String type) {
throwIfUserRequired();
return sCurrentUser.buildExternalStoragePublicDirs(type)[0];