mirror of
https://github.com/cwinfo/yggdrasil-go.git
synced 2025-01-11 10:45:42 +00:00
Raise link error when SNI supplied on unsupported link type
Closes #1196
This commit is contained in:
parent
ff0ef7ff56
commit
eef613993f
@ -126,6 +126,7 @@ const ErrLinkPinnedKeyInvalid = linkError("pinned public key is invalid")
|
|||||||
const ErrLinkPasswordInvalid = linkError("invalid password supplied")
|
const ErrLinkPasswordInvalid = linkError("invalid password supplied")
|
||||||
const ErrLinkUnrecognisedSchema = linkError("link schema unknown")
|
const ErrLinkUnrecognisedSchema = linkError("link schema unknown")
|
||||||
const ErrLinkMaxBackoffInvalid = linkError("max backoff duration invalid")
|
const ErrLinkMaxBackoffInvalid = linkError("max backoff duration invalid")
|
||||||
|
const ErrLinkSNINotSupported = linkError("SNI not supported on this link type")
|
||||||
|
|
||||||
func (l *links) add(u *url.URL, sintf string, linkType linkType) error {
|
func (l *links) add(u *url.URL, sintf string, linkType linkType) error {
|
||||||
var retErr error
|
var retErr error
|
||||||
|
@ -23,6 +23,9 @@ func (l *links) newLinkSOCKS() *linkSOCKS {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (l *linkSOCKS) dial(_ context.Context, url *url.URL, info linkInfo, options linkOptions) (net.Conn, error) {
|
func (l *linkSOCKS) dial(_ context.Context, url *url.URL, info linkInfo, options linkOptions) (net.Conn, error) {
|
||||||
|
if url.Scheme != "sockstls" && options.tlsSNI != "" {
|
||||||
|
return nil, ErrLinkSNINotSupported
|
||||||
|
}
|
||||||
var proxyAuth *proxy.Auth
|
var proxyAuth *proxy.Auth
|
||||||
if url.User != nil && url.User.Username() != "" {
|
if url.User != nil && url.User.Username() != "" {
|
||||||
proxyAuth = &proxy.Auth{
|
proxyAuth = &proxy.Auth{
|
||||||
|
@ -67,6 +67,9 @@ func (l *linkTCP) dialersFor(url *url.URL, info linkInfo) ([]*tcpDialer, error)
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (l *linkTCP) dial(ctx context.Context, url *url.URL, info linkInfo, options linkOptions) (net.Conn, error) {
|
func (l *linkTCP) dial(ctx context.Context, url *url.URL, info linkInfo, options linkOptions) (net.Conn, error) {
|
||||||
|
if options.tlsSNI != "" {
|
||||||
|
return nil, ErrLinkSNINotSupported
|
||||||
|
}
|
||||||
dialers, err := l.dialersFor(url, info)
|
dialers, err := l.dialersFor(url, info)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
@ -31,6 +31,9 @@ func (l *links) newLinkUNIX() *linkUNIX {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (l *linkUNIX) dial(ctx context.Context, url *url.URL, info linkInfo, options linkOptions) (net.Conn, error) {
|
func (l *linkUNIX) dial(ctx context.Context, url *url.URL, info linkInfo, options linkOptions) (net.Conn, error) {
|
||||||
|
if options.tlsSNI != "" {
|
||||||
|
return nil, ErrLinkSNINotSupported
|
||||||
|
}
|
||||||
addr, err := net.ResolveUnixAddr("unix", url.Path)
|
addr, err := net.ResolveUnixAddr("unix", url.Path)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
@ -87,6 +87,9 @@ func (l *links) newLinkWS() *linkWS {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (l *linkWS) dial(ctx context.Context, url *url.URL, info linkInfo, options linkOptions) (net.Conn, error) {
|
func (l *linkWS) dial(ctx context.Context, url *url.URL, info linkInfo, options linkOptions) (net.Conn, error) {
|
||||||
|
if options.tlsSNI != "" {
|
||||||
|
return nil, ErrLinkSNINotSupported
|
||||||
|
}
|
||||||
wsconn, _, err := websocket.Dial(ctx, url.String(), &websocket.DialOptions{
|
wsconn, _, err := websocket.Dial(ctx, url.String(), &websocket.DialOptions{
|
||||||
Subprotocols: []string{"ygg-ws"},
|
Subprotocols: []string{"ygg-ws"},
|
||||||
})
|
})
|
||||||
|
@ -27,6 +27,9 @@ func (l *links) newLinkWSS() *linkWSS {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (l *linkWSS) dial(ctx context.Context, url *url.URL, info linkInfo, options linkOptions) (net.Conn, error) {
|
func (l *linkWSS) dial(ctx context.Context, url *url.URL, info linkInfo, options linkOptions) (net.Conn, error) {
|
||||||
|
if options.tlsSNI != "" {
|
||||||
|
return nil, ErrLinkSNINotSupported
|
||||||
|
}
|
||||||
wsconn, _, err := websocket.Dial(ctx, url.String(), &websocket.DialOptions{
|
wsconn, _, err := websocket.Dial(ctx, url.String(), &websocket.DialOptions{
|
||||||
Subprotocols: []string{"ygg-ws"},
|
Subprotocols: []string{"ygg-ws"},
|
||||||
})
|
})
|
||||||
|
Loading…
Reference in New Issue
Block a user