tls.go 983 B

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. // +build !confonly
  2. package tls
  3. import (
  4. "crypto/tls"
  5. "v2ray.com/core/common/buf"
  6. "v2ray.com/core/common/net"
  7. )
  8. //go:generate errorgen
  9. var (
  10. _ buf.Writer = (*conn)(nil)
  11. )
  12. type conn struct {
  13. *tls.Conn
  14. }
  15. func (c *conn) WriteMultiBuffer(mb buf.MultiBuffer) error {
  16. mb = buf.Compact(mb)
  17. mb, err := buf.WriteMultiBuffer(c, mb)
  18. buf.ReleaseMulti(mb)
  19. return err
  20. }
  21. func (c *conn) HandshakeAddress() net.Address {
  22. if err := c.Handshake(); err != nil {
  23. return nil
  24. }
  25. state := c.Conn.ConnectionState()
  26. if len(state.ServerName) == 0 {
  27. return nil
  28. }
  29. return net.ParseAddress(state.ServerName)
  30. }
  31. // Client initiates a TLS client handshake on the given connection.
  32. func Client(c net.Conn, config *tls.Config) net.Conn {
  33. tlsConn := tls.Client(c, config)
  34. return &conn{Conn: tlsConn}
  35. }
  36. // Server initiates a TLS server handshake on the given connection.
  37. func Server(c net.Conn, config *tls.Config) net.Conn {
  38. tlsConn := tls.Server(c, config)
  39. return &conn{Conn: tlsConn}
  40. }