connection_adaptor.go 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. package packetaddr
  2. import (
  3. "context"
  4. gonet "net"
  5. "sync"
  6. "time"
  7. "github.com/v2fly/v2ray-core/v5/common"
  8. "github.com/v2fly/v2ray-core/v5/common/buf"
  9. "github.com/v2fly/v2ray-core/v5/common/errors"
  10. "github.com/v2fly/v2ray-core/v5/common/net"
  11. "github.com/v2fly/v2ray-core/v5/features/routing"
  12. "github.com/v2fly/v2ray-core/v5/transport"
  13. )
  14. var (
  15. errNotPacketConn = errors.New("not a packet connection")
  16. errUnsupported = errors.New("unsupported action")
  17. )
  18. func ToPacketAddrConn(link *transport.Link, dest net.Destination) (net.PacketConn, error) {
  19. if !dest.Address.Family().IsDomain() {
  20. return nil, errNotPacketConn
  21. }
  22. switch dest.Address.Domain() {
  23. case seqPacketMagicAddress:
  24. return &packetConnectionAdaptor{
  25. readerAccess: &sync.Mutex{},
  26. readerBuffer: nil,
  27. link: link,
  28. }, nil
  29. default:
  30. return nil, errNotPacketConn
  31. }
  32. }
  33. func CreatePacketAddrConn(ctx context.Context, dispatcher routing.Dispatcher, isStream bool) (net.PacketConn, error) {
  34. if isStream {
  35. return nil, errUnsupported
  36. }
  37. packetDest := net.Destination{
  38. Address: net.DomainAddress(seqPacketMagicAddress),
  39. Port: 0,
  40. Network: net.Network_UDP,
  41. }
  42. link, err := dispatcher.Dispatch(ctx, packetDest)
  43. if err != nil {
  44. return nil, err
  45. }
  46. return &packetConnectionAdaptor{
  47. readerAccess: &sync.Mutex{},
  48. readerBuffer: nil,
  49. link: link,
  50. }, nil
  51. }
  52. type packetConnectionAdaptor struct {
  53. readerAccess *sync.Mutex
  54. readerBuffer buf.MultiBuffer
  55. link *transport.Link
  56. }
  57. func (c *packetConnectionAdaptor) ReadFrom(p []byte) (n int, addr gonet.Addr, err error) {
  58. c.readerAccess.Lock()
  59. defer c.readerAccess.Unlock()
  60. if c.readerBuffer.IsEmpty() {
  61. c.readerBuffer, err = c.link.Reader.ReadMultiBuffer()
  62. if err != nil {
  63. return 0, nil, err
  64. }
  65. }
  66. c.readerBuffer, n = buf.SplitFirstBytes(c.readerBuffer, p)
  67. var w *buf.Buffer
  68. w, addr, err = ExtractAddressFromPacket(buf.FromBytes(p[:n]))
  69. n = copy(p, w.Bytes())
  70. w.Release()
  71. return
  72. }
  73. func (c *packetConnectionAdaptor) WriteTo(p []byte, addr gonet.Addr) (n int, err error) {
  74. _, ok := addr.(*gonet.UDPAddr)
  75. if !ok {
  76. // address other than UDPAddr is not supported, and will be dropped.
  77. return 0, nil
  78. }
  79. payloadLen := len(p)
  80. var buffer *buf.Buffer
  81. buffer, err = AttachAddressToPacket(buf.FromBytes(p), addr)
  82. if err != nil {
  83. return 0, err
  84. }
  85. mb := buf.MultiBuffer{buffer}
  86. err = c.link.Writer.WriteMultiBuffer(mb)
  87. if err != nil {
  88. return 0, err
  89. }
  90. return payloadLen, nil
  91. }
  92. func (c *packetConnectionAdaptor) Close() error {
  93. c.readerAccess.Lock()
  94. defer c.readerAccess.Unlock()
  95. c.readerBuffer = buf.ReleaseMulti(c.readerBuffer)
  96. return common.Interrupt(c.link)
  97. }
  98. func (c packetConnectionAdaptor) LocalAddr() gonet.Addr {
  99. return &gonet.UnixAddr{Name: "unsupported"}
  100. }
  101. func (c packetConnectionAdaptor) SetDeadline(t time.Time) error {
  102. return nil
  103. }
  104. func (c packetConnectionAdaptor) SetReadDeadline(t time.Time) error {
  105. return nil
  106. }
  107. func (c packetConnectionAdaptor) SetWriteDeadline(t time.Time) error {
  108. return nil
  109. }
  110. func ToPacketAddrConnWrapper(conn net.PacketConn, isStream bool) FusedConnection {
  111. return &packetConnWrapper{conn}
  112. }
  113. type packetConnWrapper struct {
  114. net.PacketConn
  115. }
  116. func (pc *packetConnWrapper) RemoteAddr() gonet.Addr {
  117. return nil
  118. }
  119. type FusedConnection interface {
  120. net.PacketConn
  121. net.Conn
  122. }
  123. func (pc *packetConnWrapper) Read(p []byte) (n int, err error) {
  124. recbuf := buf.StackNew()
  125. recbuf.Extend(2048)
  126. n, addr, err := pc.PacketConn.ReadFrom(recbuf.Bytes())
  127. if err != nil {
  128. return 0, err
  129. }
  130. recbuf.Resize(0, int32(n))
  131. result, err := AttachAddressToPacket(&recbuf, addr)
  132. if err != nil {
  133. return 0, err
  134. }
  135. n = copy(p, result.Bytes())
  136. result.Release()
  137. return n, nil
  138. }
  139. func (pc *packetConnWrapper) Write(p []byte) (n int, err error) {
  140. data, addr, err := ExtractAddressFromPacket(buf.FromBytes(p))
  141. if err != nil {
  142. return 0, err
  143. }
  144. _, err = pc.PacketConn.WriteTo(data.Bytes(), addr)
  145. if err != nil {
  146. return 0, err
  147. }
  148. data.Release()
  149. return len(p), nil
  150. }
  151. func (pc *packetConnWrapper) Close() error {
  152. return pc.PacketConn.Close()
  153. }
  154. func GetDestinationSubsetOf(dest net.Destination) (bool, error) {
  155. if !dest.Address.Family().IsDomain() {
  156. return false, errNotPacketConn
  157. }
  158. switch dest.Address.Domain() {
  159. case seqPacketMagicAddress:
  160. return false, nil
  161. default:
  162. return false, errNotPacketConn
  163. }
  164. }