43 lines
960 B
Go
Raw Normal View History

2020-04-03 16:04:24 +08:00
package vmess
import (
"context"
2020-04-03 16:04:24 +08:00
"crypto/tls"
2022-07-11 12:37:27 +08:00
tlsC "github.com/Dreamacro/clash/component/tls"
2020-04-03 16:04:24 +08:00
"net"
C "github.com/Dreamacro/clash/constant"
2020-04-03 16:04:24 +08:00
)
type TLSConfig struct {
Host string
SkipCertVerify bool
2022-07-11 13:42:28 +08:00
FingerPrint string
NextProtos []string
2020-04-03 16:04:24 +08:00
}
func StreamTLSConn(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,
NextProtos: cfg.NextProtos,
2022-07-11 13:42:28 +08:00
}
if len(cfg.FingerPrint) == 0 {
tlsConfig = tlsC.GetGlobalFingerprintTLCConfig(tlsConfig)
} else {
var err error
if tlsConfig, err = tlsC.GetSpecifiedFingerprintTLSConfig(tlsConfig, cfg.FingerPrint); err != nil {
return nil, err
}
}
2020-04-03 16:04:24 +08:00
tlsConn := tls.Client(conn, tlsConfig)
// fix tls handshake not timeout
ctx, cancel := context.WithTimeout(context.Background(), C.DefaultTLSTimeout)
defer cancel()
err := tlsConn.HandshakeContext(ctx)
2020-04-03 16:04:24 +08:00
return tlsConn, err
}