chore: proxy's ech should fetch from proxy-nameserver

This commit is contained in:
wwqgtxx 2025-05-22 17:42:40 +08:00
parent 5a21bf3642
commit b1d12a15db
2 changed files with 13 additions and 9 deletions

View File

@ -1,10 +1,12 @@
package outbound package outbound
import ( import (
"context"
"encoding/base64" "encoding/base64"
"fmt" "fmt"
"github.com/metacubex/mihomo/component/ech" "github.com/metacubex/mihomo/component/ech"
"github.com/metacubex/mihomo/component/resolver"
) )
type ECHOptions struct { type ECHOptions struct {
@ -22,7 +24,13 @@ func (o ECHOptions) Parse() (*ech.Config, error) {
if err != nil { if err != nil {
return nil, fmt.Errorf("base64 decode ech config string failed: %v", err) return nil, fmt.Errorf("base64 decode ech config string failed: %v", err)
} }
echConfig.EncryptedClientHelloConfigList = list echConfig.GetEncryptedClientHelloConfigList = func(ctx context.Context, serverName string) ([]byte, error) {
return list, nil
}
} else {
echConfig.GetEncryptedClientHelloConfigList = func(ctx context.Context, serverName string) ([]byte, error) {
return resolver.ResolveECHWithResolver(ctx, serverName, resolver.ProxyServerHostResolver)
}
} }
return echConfig, nil return echConfig, nil
} }

View File

@ -4,24 +4,20 @@ import (
"context" "context"
"fmt" "fmt"
"github.com/metacubex/mihomo/component/resolver"
tlsC "github.com/metacubex/mihomo/component/tls" tlsC "github.com/metacubex/mihomo/component/tls"
) )
type Config struct { type Config struct {
EncryptedClientHelloConfigList []byte GetEncryptedClientHelloConfigList func(ctx context.Context, serverName string) ([]byte, error)
} }
func (cfg *Config) ClientHandle(ctx context.Context, tlsConfig *tlsC.Config) (err error) { func (cfg *Config) ClientHandle(ctx context.Context, tlsConfig *tlsC.Config) (err error) {
if cfg == nil { if cfg == nil {
return nil return nil
} }
echConfigList := cfg.EncryptedClientHelloConfigList echConfigList, err := cfg.GetEncryptedClientHelloConfigList(ctx, tlsConfig.ServerName)
if len(echConfigList) == 0 { if err != nil {
echConfigList, err = resolver.ResolveECH(ctx, tlsConfig.ServerName) return fmt.Errorf("resolve ECH config error: %w", err)
if err != nil {
return fmt.Errorf("resolve ECH config error: %w", err)
}
} }
tlsConfig.EncryptedClientHelloConfigList = echConfigList tlsConfig.EncryptedClientHelloConfigList = echConfigList