Compare commits

..

1 commit

Author SHA1 Message Date
45e443a622
refactor: improve partner customization 2025-07-14 22:08:13 +08:00

View file

@ -11,28 +11,23 @@ class Partner {
companion object { companion object {
private const val ACTION = "com.google.android.euicc.action.PARTNER_CUSTOMIZATION" private const val ACTION = "com.google.android.euicc.action.PARTNER_CUSTOMIZATION"
private val instances = mutableMapOf<String, Partner?>() fun getInstance(context: Context, action: String = ACTION): Partner? {
var flags = if (BuildConfig.DEBUG)
private val packageFlags: Int
get() {
val flags = if (BuildConfig.DEBUG)
PackageManager.MATCH_UNINSTALLED_PACKAGES else PackageManager.MATCH_UNINSTALLED_PACKAGES else
PackageManager.MATCH_SYSTEM_ONLY PackageManager.MATCH_SYSTEM_ONLY
return flags or PackageManager.MATCH_DISABLED_COMPONENTS flags = flags or PackageManager.MATCH_DISABLED_COMPONENTS
} val apps = context.packageManager
.queryBroadcastReceivers(Intent(action), flags)
fun getInstance(context: Context, action: String = ACTION) = instances.getOrPut(action) {
context.packageManager
.queryBroadcastReceivers(Intent(action), packageFlags)
.mapNotNull { it.activityInfo?.applicationInfo } .mapNotNull { it.activityInfo?.applicationInfo }
.firstNotNullOfOrNull { for (app in apps) {
try { try {
context.packageManager.getResourcesForApplication(it) val resources = context.packageManager.getResourcesForApplication(app)
return Partner(resources)
} catch (_: PackageManager.NameNotFoundException) { } catch (_: PackageManager.NameNotFoundException) {
null continue
} }
} }
?.let(::Partner) return null
} }
} }