I'm trying to share my internal logfile with the use of the FileProvider
content provider. I have the following <provider>
entry in the manifest:
<provider
android:name="android.support.v4.content.FileProvider"
android:authorities="nl.charm.nedradio"
android:exported="false"
android:grantUriPermissions="true">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/file_provider_paths" />
</provider>
The file_provider_paths.xml
contains:
<?xml version="1.0" encoding="utf-8"?>
<paths>
<external-files-path name="files" path="." />
</paths>
The code to create the share intent is:
private static final String LOGFILE_NAME = "log.txt";
private static final String AUTHORITY = "nl.charm.nedradio";
public static Intent getShareIntent(Context context)
{
Intent intent = new Intent(Intent.ACTION_SEND);
intent.setType("text/plain");
intent.putExtra(Intent.EXTRA_SUBJECT, "Log File");
intent.putExtra(Intent.EXTRA_TEXT, "App logfile.");
// Allow access outside of share application's realm
intent.setFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION);
intent.setFlags(Intent.FLAG_GRANT_WRITE_URI_PERMISSION);
File logFile = new File(context.getExternalFilesDir(null), LOGFILE_NAME);
Uri logURI = FileProvider.getUriForFile(context, AUTHORITY, logFile);
intent.putExtra(Intent.EXTRA_STREAM, logURI);
return intent;
}
The creation of the intent is working as it should but when I try to share with e.g. Gmail I get the following error in logcat:
2018-10-18 10:16:49.536 4585-4585/com.google.android.gm E/Gmail: Gmail:Error adding attachment
exk: FileNotFoundException when openFileDescriptor.
I've searched for an answer but couldn't find one. So any suggestions on what I'm doing wrong?