mirror of
https://github.com/XTLS/Xray-core.git
synced 2026-07-05 11:18:37 +00:00
Finalmask UDP: Support WireGuard & Shadowsocks AEAD/2022 (#5643)
https://github.com/XTLS/Xray-core/pull/5633#issuecomment-3833910076
This commit is contained in:
@@ -54,15 +54,15 @@ func DialKCP(ctx context.Context, dest net.Destination, streamSettings *internet
|
|||||||
return nil, errors.New("failed to dial to dest: ", err).AtWarning().Base(err)
|
return nil, errors.New("failed to dial to dest: ", err).AtWarning().Base(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
wrapper, ok := rawConn.(*internet.PacketConnWrapper)
|
|
||||||
if !ok {
|
|
||||||
rawConn.Close()
|
|
||||||
return nil, errors.New("raw is not PacketConnWrapper")
|
|
||||||
}
|
|
||||||
|
|
||||||
raw := wrapper.Conn
|
|
||||||
|
|
||||||
if streamSettings.UdpmaskManager != nil {
|
if streamSettings.UdpmaskManager != nil {
|
||||||
|
wrapper, ok := rawConn.(*internet.PacketConnWrapper)
|
||||||
|
if !ok {
|
||||||
|
rawConn.Close()
|
||||||
|
return nil, errors.New("raw is not PacketConnWrapper")
|
||||||
|
}
|
||||||
|
|
||||||
|
raw := wrapper.Conn
|
||||||
|
|
||||||
wrapper.Conn, err = streamSettings.UdpmaskManager.WrapPacketConnClient(raw)
|
wrapper.Conn, err = streamSettings.UdpmaskManager.WrapPacketConnClient(raw)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
raw.Close()
|
raw.Close()
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ import (
|
|||||||
"context"
|
"context"
|
||||||
|
|
||||||
"github.com/xtls/xray-core/common"
|
"github.com/xtls/xray-core/common"
|
||||||
|
"github.com/xtls/xray-core/common/errors"
|
||||||
"github.com/xtls/xray-core/common/net"
|
"github.com/xtls/xray-core/common/net"
|
||||||
"github.com/xtls/xray-core/transport/internet"
|
"github.com/xtls/xray-core/transport/internet"
|
||||||
"github.com/xtls/xray-core/transport/internet/stat"
|
"github.com/xtls/xray-core/transport/internet/stat"
|
||||||
@@ -20,7 +21,24 @@ func init() {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if streamSettings != nil && streamSettings.UdpmaskManager != nil {
|
||||||
|
wrapper, ok := conn.(*internet.PacketConnWrapper)
|
||||||
|
if !ok {
|
||||||
|
conn.Close()
|
||||||
|
return nil, errors.New("conn is not PacketConnWrapper")
|
||||||
|
}
|
||||||
|
|
||||||
|
raw := wrapper.Conn
|
||||||
|
|
||||||
|
wrapper.Conn, err = streamSettings.UdpmaskManager.WrapPacketConnClient(raw)
|
||||||
|
if err != nil {
|
||||||
|
raw.Close()
|
||||||
|
return nil, errors.New("mask err").Base(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// TODO: handle dialer options
|
// TODO: handle dialer options
|
||||||
return stat.Connection(conn), nil
|
return conn, nil
|
||||||
}))
|
}))
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user