Dedup resolvedActivity by packageName

This commit is contained in:
Mygod
2023-04-15 09:17:58 -04:00
parent ffa3d7d612
commit 629d0c4b16
2 changed files with 8 additions and 8 deletions

View File

@@ -42,7 +42,7 @@ class TetherTimeoutMonitor(private val timeout: Long = 0,
if (Build.VERSION.SDK_INT < 30) Resources.getSystem().run {
getInteger(getIdentifier("config_wifi_framework_soft_ap_timeout_delay", "integer", "android"))
} else {
val info = WifiApManager.resolvedActivity.activityInfo
val info = WifiApManager.resolvedActivity
val resources = app.packageManager.getResourcesForApplication(info.applicationInfo)
resources.getInteger(resources.findIdentifier(
"config_wifiFrameworkSoftApShutDownTimeoutMilliseconds", "integer",
@@ -59,7 +59,7 @@ class TetherTimeoutMonitor(private val timeout: Long = 0,
}
@get:RequiresApi(31)
val defaultTimeoutBridged: Int get() = try {
val info = WifiApManager.resolvedActivity.activityInfo
val info = WifiApManager.resolvedActivity
val resources = app.packageManager.getResourcesForApplication(info.applicationInfo)
resources.getInteger(resources.findIdentifier(
"config_wifiFrameworkSoftApShutDownIdleInstanceInBridgedModeTimeoutMillisecond", "integer",

View File

@@ -2,8 +2,8 @@ package be.mygod.vpnhotspot.net.wifi
import android.annotation.TargetApi
import android.content.Intent
import android.content.pm.ActivityInfo
import android.content.pm.PackageManager
import android.content.pm.ResolveInfo
import android.content.res.Resources
import android.net.wifi.SoftApConfiguration
import android.net.wifi.WifiManager
@@ -31,20 +31,20 @@ object WifiApManager {
* Based on: https://cs.android.com/android/platform/superproject/+/master:packages/modules/Wifi/framework/java/android/net/wifi/WifiContext.java;l=66;drc=5ca657189aac546af0aafaba11bbc9c5d889eab3
*/
@get:RequiresApi(30)
val resolvedActivity: ResolveInfo get() {
val resolvedActivity: ActivityInfo get() {
val list = app.packageManager.queryIntentActivities(Intent(ACTION_RESOURCES_APK),
PackageManager.MATCH_SYSTEM_ONLY)
PackageManager.MATCH_SYSTEM_ONLY).distinctBy { it.activityInfo.applicationInfo.packageName }
require(list.isNotEmpty()) { "Missing $ACTION_RESOURCES_APK" }
if (list.size > 1) {
list.singleOrNull {
it.activityInfo.applicationInfo.sourceDir.startsWith("/apex/com.android.wifi")
}?.let { return it }
}?.let { return it.activityInfo }
Timber.w(Exception("Found > 1 apk: " + list.joinToString {
val info = it.activityInfo.applicationInfo
"${info.packageName} (${info.sourceDir})"
}))
}
return list[0]
return list[0].activityInfo
}
private const val CONFIG_P2P_MAC_RANDOMIZATION_SUPPORTED = "config_wifi_p2p_mac_randomization_supported"
@@ -54,7 +54,7 @@ object WifiApManager {
getBoolean(getIdentifier(CONFIG_P2P_MAC_RANDOMIZATION_SUPPORTED, "bool", "android"))
}
in 30..Int.MAX_VALUE -> @TargetApi(30) {
val info = resolvedActivity.activityInfo
val info = resolvedActivity
val resources = app.packageManager.getResourcesForApplication(info.applicationInfo)
resources.getBoolean(resources.findIdentifier(CONFIG_P2P_MAC_RANDOMIZATION_SUPPORTED, "bool",
RESOURCES_PACKAGE, info.packageName))