Feature: add option to enable sni sniff

This commit is contained in:
Kr328
2022-07-02 10:59:56 +08:00
parent eb7cd8923f
commit 7b7ee554e3
7 changed files with 22 additions and 11 deletions

View File

@@ -23,7 +23,6 @@ var processors = []processor{
patchDns, patchDns,
patchProviders, patchProviders,
patchTun, patchTun,
patchSniff,
validConfig, validConfig,
} }
@@ -106,5 +105,7 @@ func process(cfg *config.RawConfig, profileDir string) error {
} }
} }
log.Debugln("sni-tls: %t", cfg.Experimental.SniffTLSSNI)
return nil return nil
} }

View File

@@ -7,7 +7,3 @@ import "github.com/Dreamacro/clash/config"
func patchTun(cfg *config.RawConfig, _ string) error { func patchTun(cfg *config.RawConfig, _ string) error {
return nil return nil
} }
func patchSniff(cfg *config.RawConfig, _ string) error {
return nil
}

View File

@@ -9,9 +9,3 @@ func patchTun(cfg *config.RawConfig, _ string) error {
return nil return nil
} }
func patchSniff(cfg *config.RawConfig, _ string) error {
cfg.Experimental.SniffTLSSNI = true
return nil
}

View File

@@ -49,6 +49,9 @@ data class ConfigurationOverride(
@SerialName("clash-for-android") @SerialName("clash-for-android")
val app: App = App(), val app: App = App(),
@SerialName("experimental")
val experimental: Experimental = Experimental()
) : Parcelable { ) : Parcelable {
@Serializable @Serializable
data class Dns( data class Dns(
@@ -107,6 +110,12 @@ data class ConfigurationOverride(
var appendSystemDns: Boolean? = null var appendSystemDns: Boolean? = null
) )
@Serializable
data class Experimental(
@SerialName("sniff-tls-sni")
var sniffTLSSNI: Boolean? = null,
)
@Serializable @Serializable
enum class DnsEnhancedMode { enum class DnsEnhancedMode {
@SerialName("normal") @SerialName("normal")

View File

@@ -223,6 +223,15 @@ class OverrideSettingsDesign(
) )
} }
if (BuildConfig.PREMIUM) {
selectableList(
value = configuration.experimental::sniffTLSSNI,
values = booleanValues,
valuesText = booleanValuesText,
title = R.string.sniff_tls_sni,
)
}
selectableList( selectableList(
value = configuration::logLevel, value = configuration::logLevel,
values = arrayOf( values = arrayOf(

View File

@@ -216,4 +216,5 @@
<string name="geoip_fallback_code">GeoIP Fallback 区域代码</string> <string name="geoip_fallback_code">GeoIP Fallback 区域代码</string>
<string name="allow_bypass">允许应用绕过</string> <string name="allow_bypass">允许应用绕过</string>
<string name="allow_bypass_summary">允许其他应用绕过 VPN</string> <string name="allow_bypass_summary">允许其他应用绕过 VPN</string>
<string name="sniff_tls_sni">嗅探 TLS 的 SNI</string>
</resources> </resources>

View File

@@ -145,6 +145,7 @@
<string name="bind_address">Bind Address</string> <string name="bind_address">Bind Address</string>
<string name="mode">Mode</string> <string name="mode">Mode</string>
<string name="log_level">Log Level</string> <string name="log_level">Log Level</string>
<string name="sniff_tls_sni">Sniff TLS SNI</string>
<string name="ipv6">IPv6</string> <string name="ipv6">IPv6</string>
<string name="hosts">Hosts</string> <string name="hosts">Hosts</string>
<string name="sideload_geoip">Sideload GEOIP</string> <string name="sideload_geoip">Sideload GEOIP</string>