handler.go 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. package outbound
  2. import (
  3. "context"
  4. "io"
  5. "net"
  6. "time"
  7. "v2ray.com/core/app"
  8. "v2ray.com/core/app/log"
  9. "v2ray.com/core/app/proxyman"
  10. "v2ray.com/core/common/buf"
  11. "v2ray.com/core/common/errors"
  12. v2net "v2ray.com/core/common/net"
  13. "v2ray.com/core/proxy"
  14. "v2ray.com/core/transport/internet"
  15. "v2ray.com/core/transport/ray"
  16. )
  17. type Handler struct {
  18. config *proxyman.OutboundHandlerConfig
  19. senderSettings *proxyman.SenderConfig
  20. proxy proxy.Outbound
  21. outboundManager proxyman.OutboundHandlerManager
  22. }
  23. func NewHandler(ctx context.Context, config *proxyman.OutboundHandlerConfig) (*Handler, error) {
  24. h := &Handler{
  25. config: config,
  26. }
  27. space := app.SpaceFromContext(ctx)
  28. if space == nil {
  29. return nil, errors.New("Proxyman|OutboundHandler: No space in context.")
  30. }
  31. space.OnInitialize(func() error {
  32. ohm := proxyman.OutboundHandlerManagerFromSpace(space)
  33. if ohm == nil {
  34. return errors.New("Proxyman|OutboundHandler: No OutboundManager in space.")
  35. }
  36. h.outboundManager = ohm
  37. return nil
  38. })
  39. if config.SenderSettings != nil {
  40. senderSettings, err := config.SenderSettings.GetInstance()
  41. if err != nil {
  42. return nil, err
  43. }
  44. switch s := senderSettings.(type) {
  45. case *proxyman.SenderConfig:
  46. h.senderSettings = s
  47. default:
  48. return nil, errors.New("Proxyman|DefaultOutboundHandler: settings is not SenderConfig.")
  49. }
  50. }
  51. proxyHandler, err := config.GetProxyHandler(ctx)
  52. if err != nil {
  53. return nil, err
  54. }
  55. h.proxy = proxyHandler
  56. return h, nil
  57. }
  58. func (h *Handler) Dispatch(ctx context.Context, outboundRay ray.OutboundRay) {
  59. err := h.proxy.Process(ctx, outboundRay, h)
  60. // Ensure outbound ray is properly closed.
  61. if err != nil {
  62. log.Warning("Proxyman|OutboundHandler: Failed to process outbound traffic.")
  63. if errors.Cause(err) != io.EOF {
  64. outboundRay.OutboundOutput().CloseError()
  65. } else {
  66. outboundRay.OutboundOutput().Close()
  67. }
  68. }
  69. outboundRay.OutboundInput().CloseError()
  70. }
  71. func (h *Handler) Dial(ctx context.Context, dest v2net.Destination) (internet.Connection, error) {
  72. if h.senderSettings != nil {
  73. if h.senderSettings.ProxySettings.HasTag() {
  74. tag := h.senderSettings.ProxySettings.Tag
  75. handler := h.outboundManager.GetHandler(tag)
  76. if handler != nil {
  77. log.Info("Proxyman|OutboundHandler: Proxying to ", tag)
  78. ctx = proxy.ContextWithTarget(ctx, dest)
  79. stream := ray.NewRay(ctx)
  80. go handler.Dispatch(ctx, stream)
  81. return NewConnection(stream), nil
  82. }
  83. log.Warning("Proxyman|OutboundHandler: Failed to get outbound handler with tag: ", tag)
  84. }
  85. if h.senderSettings.Via != nil {
  86. ctx = internet.ContextWithDialerSource(ctx, h.senderSettings.Via.AsAddress())
  87. }
  88. if h.senderSettings.StreamSettings != nil {
  89. ctx = internet.ContextWithStreamSettings(ctx, h.senderSettings.StreamSettings)
  90. }
  91. }
  92. return internet.Dial(ctx, dest)
  93. }
  94. type Connection struct {
  95. stream ray.Ray
  96. closed bool
  97. localAddr net.Addr
  98. remoteAddr net.Addr
  99. reader *buf.BufferToBytesReader
  100. writer *buf.BytesToBufferWriter
  101. }
  102. func NewConnection(stream ray.Ray) *Connection {
  103. return &Connection{
  104. stream: stream,
  105. localAddr: &net.TCPAddr{
  106. IP: []byte{0, 0, 0, 0},
  107. Port: 0,
  108. },
  109. remoteAddr: &net.TCPAddr{
  110. IP: []byte{0, 0, 0, 0},
  111. Port: 0,
  112. },
  113. reader: buf.NewBytesReader(stream.InboundOutput()),
  114. writer: buf.NewBytesWriter(stream.InboundInput()),
  115. }
  116. }
  117. // Read implements net.Conn.Read().
  118. func (v *Connection) Read(b []byte) (int, error) {
  119. if v.closed {
  120. return 0, io.EOF
  121. }
  122. return v.reader.Read(b)
  123. }
  124. // Write implements net.Conn.Write().
  125. func (v *Connection) Write(b []byte) (int, error) {
  126. if v.closed {
  127. return 0, io.ErrClosedPipe
  128. }
  129. return v.writer.Write(b)
  130. }
  131. // Close implements net.Conn.Close().
  132. func (v *Connection) Close() error {
  133. v.closed = true
  134. v.stream.InboundInput().Close()
  135. v.stream.InboundOutput().CloseError()
  136. return nil
  137. }
  138. // LocalAddr implements net.Conn.LocalAddr().
  139. func (v *Connection) LocalAddr() net.Addr {
  140. return v.localAddr
  141. }
  142. // RemoteAddr implements net.Conn.RemoteAddr().
  143. func (v *Connection) RemoteAddr() net.Addr {
  144. return v.remoteAddr
  145. }
  146. func (v *Connection) SetDeadline(t time.Time) error {
  147. return nil
  148. }
  149. func (v *Connection) SetReadDeadline(t time.Time) error {
  150. return nil
  151. }
  152. func (v *Connection) SetWriteDeadline(t time.Time) error {
  153. return nil
  154. }
  155. func (v *Connection) Reusable() bool {
  156. return false
  157. }
  158. func (v *Connection) SetReusable(bool) {
  159. }