Hunter0x7c7
2022-08-11 b8230139fb40edea387617b6accd8371e37eda58
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
package tls
 
import (
    "context"
    "crypto/tls"
 
    "github.com/v2fly/v2ray-core/v5/common"
    "github.com/v2fly/v2ray-core/v5/common/buf"
    "github.com/v2fly/v2ray-core/v5/common/net"
)
 
//go:generate go run github.com/v2fly/v2ray-core/v5/common/errors/errorgen
 
var _ buf.Writer = (*Conn)(nil)
 
type Conn struct {
    *tls.Conn
}
 
func (c *Conn) WriteMultiBuffer(mb buf.MultiBuffer) error {
    mb = buf.Compact(mb)
    mb, err := buf.WriteMultiBuffer(c, mb)
    buf.ReleaseMulti(mb)
    return err
}
 
func (c *Conn) HandshakeAddress() net.Address {
    if err := c.Handshake(); err != nil {
        return nil
    }
    state := c.ConnectionState()
    if state.ServerName == "" {
        return nil
    }
    return net.ParseAddress(state.ServerName)
}
 
// Client initiates a TLS client handshake on the given connection.
func Client(c net.Conn, config *tls.Config) net.Conn {
    tlsConn := tls.Client(c, config)
    return &Conn{Conn: tlsConn}
}
 
/*
func copyConfig(c *tls.Config) *utls.Config {
    return &utls.Config{
        NextProtos:         c.NextProtos,
        ServerName:         c.ServerName,
        InsecureSkipVerify: c.InsecureSkipVerify,
        MinVersion:         utls.VersionTLS12,
        MaxVersion:         utls.VersionTLS12,
    }
}
 
func UClient(c net.Conn, config *tls.Config) net.Conn {
    uConfig := copyConfig(config)
    return utls.Client(c, uConfig)
}
*/
 
// Server initiates a TLS server handshake on the given connection.
func Server(c net.Conn, config *tls.Config) net.Conn {
    tlsConn := tls.Server(c, config)
    return &Conn{Conn: tlsConn}
}
 
func init() {
    common.Must(common.RegisterConfig((*Config)(nil), func(ctx context.Context, config interface{}) (interface{}, error) {
        return nil, newError("tls should be used with v2tls")
    }))
}