← Back to context

Comment by versteegen

1 day ago

> If your app barely uses any permissions (like TFA's apps), you just need to update the targetSdkVersion in the manifest

And what if you do use permissions for stuff like, say, external storage access, don't you need a recent SDK so you can use the APIs for things like the run-time permission requests now mandatory? But I believe the Android SDK removed support for building with ant years ago. And lets say I'm using a legacy framework with an incredibly contrived ant- (and bash-)based build system which there's no way I'm rewriting. Therefore, I'm in big trouble, am I not? Honest question.

Runtime permissions where introduced in 2015 with Android 6.0 (SDK 23).

So you indeed need to use a new enough Android Studio and compile against SDK 23. You need to use the new API, I think the easiest way is to add a button and call requestPermissions() [1], you can leave the rest of the code unmodified.

Also, note that Google Play does not allow the external storage access permission except if it's a file manager app. It's better to use the SAF API (since Android 4.4 SDK 19) instead. Depending on your app, that may need bigger changes.

By the way, I'm working on a syscall interception framework[2] that could in theory intercept the file io syscalls and redirect them to use the SAF API. That would need only minimal changes to your app and also would allow to run things like syncthing unmodified.

You need to make these changes anyway, because Android 14+ can not install apps with targetSdkVersion < 23.

[1] https://developer.android.com/training/permissions/requestin...

[2] https://github.com/lukasstraub2/intercept-anything