Skip to content

Commit f4a048a

Browse files
committed
Merge branch 'main' into dns
2 parents 90c81e8 + bf94fb5 commit f4a048a

7 files changed

Lines changed: 44 additions & 30 deletions

File tree

core/core.go

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -18,7 +18,7 @@ import (
1818
)
1919

2020
var (
21-
version = "1.4.1"
21+
version = "1.4.2"
2222
build = "Custom"
2323
codename = "Xray, Penetrates Everything."
2424
intro = "A unified platform for anti-censorship."

transport/internet/grpc/dial.go

Lines changed: 7 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -90,8 +90,14 @@ func getGrpcClient(ctx context.Context, dest net.Destination, tlsConfig *tls.Con
9090
dialOption = grpc.WithTransportCredentials(credentials.NewTLS(tlsConfig.GetTLSConfig()))
9191
}
9292

93+
var grpcDestHost string
94+
if dest.Address.Family().IsDomain() {
95+
grpcDestHost = dest.Address.Domain()
96+
} else {
97+
grpcDestHost = dest.Address.IP().String()
98+
}
9399
conn, err := grpc.Dial(
94-
gonet.JoinHostPort(dest.Address.String(), dest.Port.String()),
100+
gonet.JoinHostPort(grpcDestHost, dest.Port.String()),
95101
dialOption,
96102
grpc.WithConnectParams(grpc.ConnectParams{
97103
Backoff: backoff.Config{

transport/internet/quic/dialer.go

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -148,7 +148,7 @@ func (s *clientSessions) openConnection(destAddr net.Addr, config *Config, tlsCo
148148

149149
quicConfig := &quic.Config{
150150
ConnectionIDLength: 12,
151-
MaxIdleTimeout: time.Second * 30,
151+
KeepAlive: true,
152152
}
153153

154154
conn, err := wrapSysConn(rawConn, config)

transport/internet/quic/hub.go

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -103,7 +103,7 @@ func Listen(ctx context.Context, address net.Address, port net.Port, streamSetti
103103

104104
quicConfig := &quic.Config{
105105
ConnectionIDLength: 12,
106-
MaxIdleTimeout: time.Second * 45,
106+
KeepAlive: true,
107107
MaxIncomingStreams: 32,
108108
MaxIncomingUniStreams: -1,
109109
}

transport/internet/tcp/dialer.go

Lines changed: 4 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -3,8 +3,6 @@ package tcp
33
import (
44
"context"
55

6-
utls "github.com/refraction-networking/utls"
7-
86
"github.com/xtls/xray-core/common"
97
"github.com/xtls/xray-core/common/net"
108
"github.com/xtls/xray-core/common/session"
@@ -24,7 +22,10 @@ func Dial(ctx context.Context, dest net.Destination, streamSettings *internet.Me
2422
if config := tls.ConfigFromStreamSettings(streamSettings); config != nil {
2523
tlsConfig := config.GetTLSConfig(tls.WithDestination(dest))
2624
if fingerprint, ok := tls.Fingerprints[config.Fingerprint]; ok {
27-
conn = utls.UClient(conn, tls.CopyConfig(tlsConfig), fingerprint)
25+
conn = tls.UClient(conn, tlsConfig, fingerprint)
26+
if err := conn.(*tls.UConn).Handshake(); err != nil {
27+
return nil, err
28+
}
2829
} else {
2930
conn = tls.Client(conn, tlsConfig)
3031
}

transport/internet/tls/config.go

Lines changed: 0 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -18,8 +18,6 @@ var (
1818
globalSessionCache = tls.NewLRUClientSessionCache(128)
1919
)
2020

21-
const exp8357 = "experiment:8357"
22-
2321
// ParseCertificate converts a cert.Certificate to Certificate.
2422
func ParseCertificate(c *cert.Certificate) *Certificate {
2523
if c != nil {
@@ -240,15 +238,7 @@ func getNewGetCertficateFunc(certs []*tls.Certificate) func(hello *tls.ClientHel
240238
}
241239
}
242240

243-
func (c *Config) IsExperiment8357() bool {
244-
return strings.HasPrefix(c.ServerName, exp8357)
245-
}
246-
247241
func (c *Config) parseServerName() string {
248-
if c.IsExperiment8357() {
249-
return c.ServerName[len(exp8357):]
250-
}
251-
252242
return c.ServerName
253243
}
254244

transport/internet/tls/tls.go

Lines changed: 30 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -43,26 +43,43 @@ func Client(c net.Conn, config *tls.Config) net.Conn {
4343
return &Conn{Conn: tlsConn}
4444
}
4545

46-
var Fingerprints = map[string]utls.ClientHelloID{
47-
"chrome": utls.HelloChrome_Auto,
48-
"firefox": utls.HelloFirefox_Auto,
49-
"safari": utls.HelloIOS_Auto,
50-
"randomized": utls.HelloRandomized,
46+
// Server initiates a TLS server handshake on the given connection.
47+
func Server(c net.Conn, config *tls.Config) net.Conn {
48+
tlsConn := tls.Server(c, config)
49+
return &Conn{Conn: tlsConn}
50+
}
51+
52+
type UConn struct {
53+
*utls.UConn
54+
}
55+
56+
func (c *UConn) HandshakeAddress() net.Address {
57+
if err := c.Handshake(); err != nil {
58+
return nil
59+
}
60+
state := c.ConnectionState()
61+
if state.ServerName == "" {
62+
return nil
63+
}
64+
return net.ParseAddress(state.ServerName)
5165
}
5266

53-
func CopyConfig(c *tls.Config) *utls.Config {
67+
func UClient(c net.Conn, config *tls.Config, fingerprint *utls.ClientHelloID) net.Conn {
68+
utlsConn := utls.UClient(c, copyConfig(config), *fingerprint)
69+
return &UConn{UConn: utlsConn}
70+
}
71+
72+
func copyConfig(c *tls.Config) *utls.Config {
5473
return &utls.Config{
5574
RootCAs: c.RootCAs,
56-
NextProtos: c.NextProtos,
5775
ServerName: c.ServerName,
5876
InsecureSkipVerify: c.InsecureSkipVerify,
59-
MinVersion: c.MinVersion,
60-
MaxVersion: c.MaxVersion,
6177
}
6278
}
6379

64-
// Server initiates a TLS server handshake on the given connection.
65-
func Server(c net.Conn, config *tls.Config) net.Conn {
66-
tlsConn := tls.Server(c, config)
67-
return &Conn{Conn: tlsConn}
80+
var Fingerprints = map[string]*utls.ClientHelloID{
81+
"chrome": &utls.HelloChrome_Auto,
82+
"firefox": &utls.HelloFirefox_Auto,
83+
"safari": &utls.HelloIOS_Auto,
84+
"randomized": &utls.HelloRandomized,
6885
}

0 commit comments

Comments
 (0)