Background
After migrating to Android Q I can no longer find a suitable way to gain write access to the documents folder (/storage/emulated/0/Documents
)
And before anyone mentions the many other questions on scoped storage I've read through many of them and from what I've seen so far all of the solutions use a app specific directory or accessing a media directory only (not documents folder access).
From what I understand in Android Q I can either choose:
- Use a app specific directory that is only accessible by my app (or apps I give permission to)
- Allow the user to select where they want the file stored (I think this can be a public location)
ACTION_OPEN_DOCUMENT_TREE
Problem
The applications I develop are used to conduct tests on subjects, the data from the tests automatically gets stored in the publicly accessible Documents folder somewhat like: /storage/emulated/0/Documents/myAppName/subjectName/testData-todaysDate.pdf
When the user wants to access the test data they plug their smartphone into a computer and navigate to the documents folder and the rest is pretty obvious. For this reason I have to use publicly accessible storage. Also imagine they want to open the test data on their phone via another app, Same deal!
The solution I'm looking for
So the solution I'm looking for needs to be able to do the following:
- Doesn't ask for permission multiple times (once is ok)
- Automatically saves test data without user prompt (as hundreds of tests will be conducted)
- Saves to public documents folder e.g.
/storage/emulated/0/Documents/
- Doesn't involve the user selecting the directory so NOT
ACTION_OPEN_DOCUMENT_TREE
- Ideally the data is persistent so uninstalling the app doesn't cause data lose
I get that these changes in Android Q are to bring users more "into the loop" with how apps are accessing their data but once they understand how your app is using your data there shouldn't be a problem.
Documents/
toDownloads/
, you can useMediaStore.Downloads
. "but once they understand how your app is using your data there shouldn't be a problem" -- by that argument, you should not have a problem withACTION_OPEN_DOCUMENT_TREE
. The user needs to handle that exactly once, after which you can write as many documents into that tree as you like. – AbednegoACTION_OPEN_DOCUMENT_TREE
can they select a public location when they setup the app for example and then we reuse that forever? That might be the best solution then, still dangerous as the user can choose a bad location but better then nothing. – MelindamelindeWhen the user wants to access the test data they plug their smartphone into a computer and navigate to the documents folder
. Is this still possible with an Android Q device? Please report as i have no such device. – LangousteACTION_OPEN_DOCUMENT_TREE
can they select a public location when they setup the app for example and then we reuse that forever?" -- yes. – Abednego