2020-04-03 16:04:24 +08:00
|
|
|
package vmess
|
|
|
|
|
|
|
|
import (
|
2022-01-15 19:33:21 +08:00
|
|
|
"context"
|
2020-04-03 16:04:24 +08:00
|
|
|
"crypto/tls"
|
2023-03-08 17:18:46 +08:00
|
|
|
"errors"
|
2020-04-03 16:04:24 +08:00
|
|
|
"net"
|
2022-01-15 19:33:21 +08:00
|
|
|
|
2023-11-03 21:01:45 +08:00
|
|
|
"github.com/metacubex/mihomo/component/ca"
|
|
|
|
tlsC "github.com/metacubex/mihomo/component/tls"
|
2020-04-03 16:04:24 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
type TLSConfig struct {
|
2023-02-01 22:16:06 +08:00
|
|
|
Host string
|
|
|
|
SkipCertVerify bool
|
|
|
|
FingerPrint string
|
|
|
|
ClientFingerprint string
|
|
|
|
NextProtos []string
|
2023-03-08 17:18:46 +08:00
|
|
|
Reality *tlsC.RealityConfig
|
2020-04-03 16:04:24 +08:00
|
|
|
}
|
|
|
|
|
2023-05-18 13:15:08 +08:00
|
|
|
func StreamTLSConn(ctx context.Context, conn net.Conn, cfg *TLSConfig) (net.Conn, error) {
|
2022-07-11 13:42:28 +08:00
|
|
|
tlsConfig := &tls.Config{
|
2020-04-03 16:04:24 +08:00
|
|
|
ServerName: cfg.Host,
|
|
|
|
InsecureSkipVerify: cfg.SkipCertVerify,
|
2020-09-26 20:33:57 +08:00
|
|
|
NextProtos: cfg.NextProtos,
|
2022-07-11 13:42:28 +08:00
|
|
|
}
|
|
|
|
|
2023-09-22 14:45:34 +08:00
|
|
|
var err error
|
|
|
|
tlsConfig, err = ca.GetSpecifiedFingerprintTLSConfig(tlsConfig, cfg.FingerPrint)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
2022-07-11 13:42:28 +08:00
|
|
|
}
|
2020-04-03 16:04:24 +08:00
|
|
|
|
2025-04-29 21:15:48 +08:00
|
|
|
if clientFingerprint, ok := tlsC.GetFingerprint(cfg.ClientFingerprint); ok {
|
2023-03-08 17:18:46 +08:00
|
|
|
if cfg.Reality == nil {
|
2025-04-29 21:15:48 +08:00
|
|
|
tlsConn := tlsC.UClient(conn, tlsC.UConfig(tlsConfig), clientFingerprint)
|
|
|
|
err = tlsConn.HandshakeContext(ctx)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
2023-03-08 17:18:46 +08:00
|
|
|
}
|
2025-04-29 21:15:48 +08:00
|
|
|
return tlsConn, nil
|
2023-03-08 17:18:46 +08:00
|
|
|
} else {
|
2025-04-19 02:04:09 +08:00
|
|
|
return tlsC.GetRealityConn(ctx, conn, clientFingerprint, tlsConfig, cfg.Reality)
|
2023-02-01 22:16:06 +08:00
|
|
|
}
|
|
|
|
}
|
2023-03-08 17:18:46 +08:00
|
|
|
if cfg.Reality != nil {
|
|
|
|
return nil, errors.New("REALITY is based on uTLS, please set a client-fingerprint")
|
|
|
|
}
|
|
|
|
|
2020-04-03 16:04:24 +08:00
|
|
|
tlsConn := tls.Client(conn, tlsConfig)
|
2022-01-15 19:33:21 +08:00
|
|
|
|
2023-09-22 14:45:34 +08:00
|
|
|
err = tlsConn.HandshakeContext(ctx)
|
2020-04-03 16:04:24 +08:00
|
|
|
return tlsConn, err
|
|
|
|
}
|