diff options
| author | 2023-05-24 22:48:37 +0000 | |
|---|---|---|
| committer | 2023-05-24 22:48:37 +0000 | |
| commit | b85f705415f42368fc6cd8e80678863a63bab88d (patch) | |
| tree | e0c8b6b4069f27d9cba1da4ba817e7e46d7b06cd /java/src | |
| parent | 6a00ad32ff1b2c227d40ef766989e4bfd7b0da68 (diff) | |
| parent | 5956b93ceeb7d551bc442b074f20e7c62ee75689 (diff) | |
Merge "Fix ChooserActivity stuck disabled" into udc-dev am: 63d9e20f53 am: 5956b93cee
Original change: https://googleplex-android-review.googlesource.com/c/platform/packages/modules/IntentResolver/+/23390358
Change-Id: Ibfbedf4511f09c4447df003c3923cb33df2b5928
Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
Diffstat (limited to 'java/src')
| -rw-r--r-- | java/src/com/android/intentresolver/ChooserActivityReEnabler.kt | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/java/src/com/android/intentresolver/ChooserActivityReEnabler.kt b/java/src/com/android/intentresolver/ChooserActivityReEnabler.kt new file mode 100644 index 00000000..3236c1be --- /dev/null +++ b/java/src/com/android/intentresolver/ChooserActivityReEnabler.kt @@ -0,0 +1,39 @@ +package com.android.intentresolver + +import android.content.BroadcastReceiver +import android.content.ComponentName +import android.content.Context +import android.content.Intent +import android.content.pm.PackageManager + +/** + * Ensures that the unbundled version of [ChooserActivity] does not get stuck in a disabled state. + */ +class ChooserActivityReEnabler : BroadcastReceiver() { + + override fun onReceive(context: Context, intent: Intent) { + if (intent.action == Intent.ACTION_BOOT_COMPLETED) { + context.packageManager.setComponentEnabledSetting( + CHOOSER_COMPONENT, + PackageManager.COMPONENT_ENABLED_STATE_DEFAULT, + /* flags = */ 0, + ) + + // This only needs to be run once, so we disable ourself to avoid additional startup + // process on future boots + context.packageManager.setComponentEnabledSetting( + SELF_COMPONENT, + PackageManager.COMPONENT_ENABLED_STATE_DISABLED, + /* flags = */ 0, + ) + } + } + + companion object { + private const val CHOOSER_PACKAGE = "com.android.intentresolver" + private val CHOOSER_COMPONENT = + ComponentName(CHOOSER_PACKAGE, "$CHOOSER_PACKAGE.ChooserActivity") + private val SELF_COMPONENT = + ComponentName(CHOOSER_PACKAGE, "$CHOOSER_PACKAGE.ChooserActivityReEnabler") + } +} |