mirror of
https://github.com/daeuniverse/dae.git
synced 2025-01-24 10:03:07 +07:00
63 lines
1.2 KiB
Go
63 lines
1.2 KiB
Go
|
package tls
|
||
|
|
||
|
import (
|
||
|
"crypto/tls"
|
||
|
"fmt"
|
||
|
"golang.org/x/net/proxy"
|
||
|
"net"
|
||
|
"net/url"
|
||
|
)
|
||
|
|
||
|
// Tls is a base Tls struct
|
||
|
type Tls struct {
|
||
|
dialer proxy.Dialer
|
||
|
addr string
|
||
|
serverName string
|
||
|
skipVerify bool
|
||
|
tlsConfig *tls.Config
|
||
|
}
|
||
|
|
||
|
// NewTls returns a Tls infra.
|
||
|
func NewTls(s string, d proxy.Dialer) (*Tls, error) {
|
||
|
u, err := url.Parse(s)
|
||
|
if err != nil {
|
||
|
return nil, fmt.Errorf("NewTls: %w", err)
|
||
|
}
|
||
|
|
||
|
t := &Tls{
|
||
|
dialer: d,
|
||
|
addr: u.Host,
|
||
|
}
|
||
|
|
||
|
query := u.Query()
|
||
|
t.serverName = query.Get("sni")
|
||
|
|
||
|
// skipVerify
|
||
|
if query.Get("allowInsecure") == "true" || query.Get("allowInsecure") == "1" ||
|
||
|
query.Get("skipVerify") == "true" || query.Get("skipVerify") == "1" {
|
||
|
t.skipVerify = true
|
||
|
}
|
||
|
if t.serverName == "" {
|
||
|
t.serverName = u.Hostname()
|
||
|
}
|
||
|
t.tlsConfig = &tls.Config{
|
||
|
ServerName: t.serverName,
|
||
|
InsecureSkipVerify: t.skipVerify,
|
||
|
}
|
||
|
|
||
|
return t, nil
|
||
|
}
|
||
|
|
||
|
func (s *Tls) Dial(network, addr string) (conn net.Conn, err error) {
|
||
|
rc, err := s.dialer.Dial("tcp", addr)
|
||
|
if err != nil {
|
||
|
return nil, fmt.Errorf("[Tls]: dial to %s: %w", s.addr, err)
|
||
|
}
|
||
|
|
||
|
tlsConn := tls.Client(rc, s.tlsConfig)
|
||
|
if err := tlsConn.Handshake(); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return tlsConn, err
|
||
|
}
|