44 lines
855 B
Go
44 lines
855 B
Go
package tls
|
|
|
|
import (
|
|
"crypto/tls"
|
|
"net"
|
|
"time"
|
|
|
|
tls_util "github.com/go-gost/gost/pkg/common/util/tls"
|
|
mdata "github.com/go-gost/gost/pkg/metadata"
|
|
)
|
|
|
|
type metadata struct {
|
|
tlsConfig *tls.Config
|
|
handshakeTimeout time.Duration
|
|
}
|
|
|
|
func (d *tlsDialer) parseMetadata(md mdata.Metadata) (err error) {
|
|
const (
|
|
certFile = "certFile"
|
|
keyFile = "keyFile"
|
|
caFile = "caFile"
|
|
secure = "secure"
|
|
serverName = "serverName"
|
|
|
|
handshakeTimeout = "handshakeTimeout"
|
|
)
|
|
|
|
sn, _, _ := net.SplitHostPort(mdata.GetString(md, serverName))
|
|
if sn == "" {
|
|
sn = "localhost"
|
|
}
|
|
d.md.tlsConfig, err = tls_util.LoadClientConfig(
|
|
mdata.GetString(md, certFile),
|
|
mdata.GetString(md, keyFile),
|
|
mdata.GetString(md, caFile),
|
|
mdata.GetBool(md, secure),
|
|
sn,
|
|
)
|
|
|
|
d.md.handshakeTimeout = mdata.GetDuration(md, handshakeTimeout)
|
|
|
|
return
|
|
}
|