From 119f85377ae680dd9779265e1547d481362e3611 Mon Sep 17 00:00:00 2001 From: ThibaultBee <37510686+ThibaultBee@users.noreply.github.com> Date: Tue, 26 Sep 2023 10:24:51 +0200 Subject: [PATCH] feat(java): add support from Android 21 (instead of 24) --- config/android-uploader.yaml | 2 ++ config/android.yaml | 2 ++ .../notifications/NotificationExtensions.mustache | 3 ++- .../java/libraries/okhttp-gson/build.gradle.mustache | 2 +- .../android-uploader/examples/service/build.gradle | 2 +- .../service/example/ReadStorePermissionManager.kt | 12 ++++++++++-- .../examples/workmanager/build.gradle | 2 +- .../work/example/ReadStorePermissionManager.kt | 12 ++++++++++-- .../statics/android/examples/service/build.gradle | 2 +- .../service/example/ReadStorePermissionManager.kt | 12 ++++++++++-- .../android/examples/workmanager/build.gradle | 2 +- .../work/example/ReadStorePermissionManager.kt | 12 ++++++++++-- 12 files changed, 51 insertions(+), 14 deletions(-) diff --git a/config/android-uploader.yaml b/config/android-uploader.yaml index 7526c847..a3c5b714 100644 --- a/config/android-uploader.yaml +++ b/config/android-uploader.yaml @@ -1,4 +1,6 @@ changelog: + - 1.3.2 (2023-09-26): + - Extend Android minSdkVersion to 21 - 1.3.1 (2023-08-22): - Fix cancellation of upload workers for the WorkManager API - 1.3.0 (2023-08-21): diff --git a/config/android.yaml b/config/android.yaml index 18e4456c..e72066fd 100644 --- a/config/android.yaml +++ b/config/android.yaml @@ -1,4 +1,6 @@ changelog: + - 1.5.2 (2023-09-26): + - Extend Android minSdkVersion to 21 - 1.5.1 (2023-08-22): - Fix cancellation of upload workers for the WorkManager API - 1.5.0 (2023-08-21): diff --git a/templates/java/android/notifications/NotificationExtensions.mustache b/templates/java/android/notifications/NotificationExtensions.mustache index 607c63d1..5f211854 100644 --- a/templates/java/android/notifications/NotificationExtensions.mustache +++ b/templates/java/android/notifications/NotificationExtensions.mustache @@ -4,6 +4,7 @@ import android.content.Context import androidx.annotation.ColorRes import androidx.annotation.DrawableRes import androidx.core.app.NotificationCompat +import androidx.core.content.ContextCompat fun NotificationCompat.Builder.setStyle( context: Context, @@ -11,5 +12,5 @@ fun NotificationCompat.Builder.setStyle( @ColorRes notificationColorResourceId: Int ): NotificationCompat.Builder = apply { setSmallIcon(notificationIconResourceId) - color = context.getColor(notificationColorResourceId) + color = ContextCompat.getColor(context, notificationColorResourceId) } \ No newline at end of file diff --git a/templates/java/libraries/okhttp-gson/build.gradle.mustache b/templates/java/libraries/okhttp-gson/build.gradle.mustache index a6eebbb6..1807015c 100644 --- a/templates/java/libraries/okhttp-gson/build.gradle.mustache +++ b/templates/java/libraries/okhttp-gson/build.gradle.mustache @@ -40,7 +40,7 @@ if(hasProperty('target') && target == 'android') { compileSdkVersion 33 buildToolsVersion '30.0.3' defaultConfig { - minSdkVersion 24 + minSdkVersion 21 targetSdkVersion 33 multiDexEnabled true diff --git a/templates/java/statics/android-uploader/examples/service/build.gradle b/templates/java/statics/android-uploader/examples/service/build.gradle index dbd89ddc..864d3121 100644 --- a/templates/java/statics/android-uploader/examples/service/build.gradle +++ b/templates/java/statics/android-uploader/examples/service/build.gradle @@ -8,7 +8,7 @@ android { defaultConfig { applicationId "video.api.uploader.service.example" - minSdk 24 + minSdk 21 targetSdk 33 versionCode 1 versionName "1.0" diff --git a/templates/java/statics/android-uploader/examples/service/src/main/java/video/api/uploader/service/example/ReadStorePermissionManager.kt b/templates/java/statics/android-uploader/examples/service/src/main/java/video/api/uploader/service/example/ReadStorePermissionManager.kt index 627bcd07..42122c4c 100644 --- a/templates/java/statics/android-uploader/examples/service/src/main/java/video/api/uploader/service/example/ReadStorePermissionManager.kt +++ b/templates/java/statics/android-uploader/examples/service/src/main/java/video/api/uploader/service/example/ReadStorePermissionManager.kt @@ -16,13 +16,21 @@ class ReadStorePermissionManager( } else { android.Manifest.permission.READ_EXTERNAL_STORAGE } + private val hasPermission: Boolean - get() = activity.checkSelfPermission(requiredPermission) == PackageManager.PERMISSION_GRANTED + get() = if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) { + activity.checkSelfPermission(requiredPermission) == PackageManager.PERMISSION_GRANTED + } else { + true + } fun requestPermission() { if (hasPermission) { onGranted() } else { + if (Build.VERSION.SDK_INT < Build.VERSION_CODES.M) { + throw IllegalStateException("Permission should be granted") + } if (activity.shouldShowRequestPermissionRationale(requiredPermission)) { onShowPermissionRationale(requiredPermission) { requestPermission.launch(requiredPermission) @@ -41,4 +49,4 @@ class ReadStorePermissionManager( onDenied() } } -} \ No newline at end of file +} diff --git a/templates/java/statics/android-uploader/examples/workmanager/build.gradle b/templates/java/statics/android-uploader/examples/workmanager/build.gradle index aaa9dedc..301c25af 100644 --- a/templates/java/statics/android-uploader/examples/workmanager/build.gradle +++ b/templates/java/statics/android-uploader/examples/workmanager/build.gradle @@ -8,7 +8,7 @@ android { defaultConfig { applicationId "video.api.uploader.work.example" - minSdkVersion 24 + minSdkVersion 21 targetSdkVersion 33 versionCode 1 versionName "1.0" diff --git a/templates/java/statics/android-uploader/examples/workmanager/src/main/java/video/api/uploader/work/example/ReadStorePermissionManager.kt b/templates/java/statics/android-uploader/examples/workmanager/src/main/java/video/api/uploader/work/example/ReadStorePermissionManager.kt index 4f58a600..6e34e760 100644 --- a/templates/java/statics/android-uploader/examples/workmanager/src/main/java/video/api/uploader/work/example/ReadStorePermissionManager.kt +++ b/templates/java/statics/android-uploader/examples/workmanager/src/main/java/video/api/uploader/work/example/ReadStorePermissionManager.kt @@ -16,13 +16,21 @@ class ReadStorePermissionManager( } else { android.Manifest.permission.READ_EXTERNAL_STORAGE } + private val hasPermission: Boolean - get() = activity.checkSelfPermission(requiredPermission) == PackageManager.PERMISSION_GRANTED + get() = if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) { + activity.checkSelfPermission(requiredPermission) == PackageManager.PERMISSION_GRANTED + } else { + true + } fun requestPermission() { if (hasPermission) { onGranted() } else { + if (Build.VERSION.SDK_INT < Build.VERSION_CODES.M) { + throw IllegalStateException("Permission should be granted") + } if (activity.shouldShowRequestPermissionRationale(requiredPermission)) { onShowPermissionRationale(requiredPermission) { requestPermission.launch(requiredPermission) @@ -41,4 +49,4 @@ class ReadStorePermissionManager( onDenied() } } -} \ No newline at end of file +} diff --git a/templates/java/statics/android/examples/service/build.gradle b/templates/java/statics/android/examples/service/build.gradle index 70d8d42a..d69ab5eb 100644 --- a/templates/java/statics/android/examples/service/build.gradle +++ b/templates/java/statics/android/examples/service/build.gradle @@ -8,7 +8,7 @@ android { defaultConfig { applicationId "video.api.client.service.example" - minSdkVersion 24 + minSdkVersion 21 targetSdkVersion 33 versionCode 1 versionName "1.0" diff --git a/templates/java/statics/android/examples/service/src/main/java/video/api/client/service/example/ReadStorePermissionManager.kt b/templates/java/statics/android/examples/service/src/main/java/video/api/client/service/example/ReadStorePermissionManager.kt index 91adf163..680eb8dc 100644 --- a/templates/java/statics/android/examples/service/src/main/java/video/api/client/service/example/ReadStorePermissionManager.kt +++ b/templates/java/statics/android/examples/service/src/main/java/video/api/client/service/example/ReadStorePermissionManager.kt @@ -16,13 +16,21 @@ class ReadStorePermissionManager( } else { android.Manifest.permission.READ_EXTERNAL_STORAGE } + private val hasPermission: Boolean - get() = activity.checkSelfPermission(requiredPermission) == PackageManager.PERMISSION_GRANTED + get() = if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) { + activity.checkSelfPermission(requiredPermission) == PackageManager.PERMISSION_GRANTED + } else { + true + } fun requestPermission() { if (hasPermission) { onGranted() } else { + if (Build.VERSION.SDK_INT < Build.VERSION_CODES.M) { + throw IllegalStateException("Permission should be granted") + } if (activity.shouldShowRequestPermissionRationale(requiredPermission)) { onShowPermissionRationale(requiredPermission) { requestPermission.launch(requiredPermission) @@ -41,4 +49,4 @@ class ReadStorePermissionManager( onDenied() } } -} \ No newline at end of file +} diff --git a/templates/java/statics/android/examples/workmanager/build.gradle b/templates/java/statics/android/examples/workmanager/build.gradle index 7f976dab..cc355f88 100644 --- a/templates/java/statics/android/examples/workmanager/build.gradle +++ b/templates/java/statics/android/examples/workmanager/build.gradle @@ -8,7 +8,7 @@ android { defaultConfig { applicationId "video.api.client.work.example" - minSdkVersion 24 + minSdkVersion 21 targetSdkVersion 33 versionCode 1 versionName "1.0" diff --git a/templates/java/statics/android/examples/workmanager/src/main/java/video/api/client/work/example/ReadStorePermissionManager.kt b/templates/java/statics/android/examples/workmanager/src/main/java/video/api/client/work/example/ReadStorePermissionManager.kt index b1430d55..92bae483 100644 --- a/templates/java/statics/android/examples/workmanager/src/main/java/video/api/client/work/example/ReadStorePermissionManager.kt +++ b/templates/java/statics/android/examples/workmanager/src/main/java/video/api/client/work/example/ReadStorePermissionManager.kt @@ -16,13 +16,21 @@ class ReadStorePermissionManager( } else { android.Manifest.permission.READ_EXTERNAL_STORAGE } + private val hasPermission: Boolean - get() = activity.checkSelfPermission(requiredPermission) == PackageManager.PERMISSION_GRANTED + get() = if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) { + activity.checkSelfPermission(requiredPermission) == PackageManager.PERMISSION_GRANTED + } else { + true + } fun requestPermission() { if (hasPermission) { onGranted() } else { + if (Build.VERSION.SDK_INT < Build.VERSION_CODES.M) { + throw IllegalStateException("Permission should be granted") + } if (activity.shouldShowRequestPermissionRationale(requiredPermission)) { onShowPermissionRationale(requiredPermission) { requestPermission.launch(requiredPermission) @@ -41,4 +49,4 @@ class ReadStorePermissionManager( onDenied() } } -} \ No newline at end of file +}