diff --git a/app/src/main/java/io/nekohasekai/sagernet/group/RawUpdater.kt b/app/src/main/java/io/nekohasekai/sagernet/group/RawUpdater.kt index 02041af..e2d0f72 100644 --- a/app/src/main/java/io/nekohasekai/sagernet/group/RawUpdater.kt +++ b/app/src/main/java/io/nekohasekai/sagernet/group/RawUpdater.kt @@ -760,9 +760,25 @@ object RawUpdater : GroupUpdater() { } json.has("outbounds") -> { - return listOf(ConfigBean().applyDefaultValues().apply { - config = json.toStringPretty() - }) + return json.getJSONArray("outbounds") + .filterIsInstance() + .mapNotNull { + val ty = it.getStr("type") + if (ty == null || ty == "" || + ty == "dns" || ty == "block" || ty == "direct" || ty == "selector" || ty == "urltest" + ) { + null + } else { + it + } + }.map { + ConfigBean().apply { + applyDefaultValues() + type = 1 + config = it.toStringPretty() + name = it.getStr("tag") + } + } } json.has("server") && json.has("server_port") -> { diff --git a/app/src/main/java/moe/matsuri/nb4a/Protocols.kt b/app/src/main/java/moe/matsuri/nb4a/Protocols.kt index 2bbafbf..e280d6f 100644 --- a/app/src/main/java/moe/matsuri/nb4a/Protocols.kt +++ b/app/src/main/java/moe/matsuri/nb4a/Protocols.kt @@ -6,6 +6,7 @@ import io.nekohasekai.sagernet.database.ProxyEntity.Companion.TYPE_NEKO import io.nekohasekai.sagernet.fmt.AbstractBean import io.nekohasekai.sagernet.ktx.app import io.nekohasekai.sagernet.ktx.getColorAttr +import moe.matsuri.nb4a.proxy.config.ConfigBean // Settings for all protocols, built-in or plugin object Protocols { @@ -17,6 +18,9 @@ object Protocols { ) { fun hash(): String { + if (bean is ConfigBean) { + return bean.config + } return bean.serverAddress + bean.serverPort + type }