handler.go 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. package outbound
  2. import (
  3. "context"
  4. "io"
  5. "net"
  6. "time"
  7. "v2ray.com/core/app"
  8. "v2ray.com/core/app/proxyman"
  9. "v2ray.com/core/common/buf"
  10. "v2ray.com/core/common/errors"
  11. "v2ray.com/core/app/log"
  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. ctx = proxy.ContextWithDialer(ctx, h)
  60. err := h.proxy.Process(ctx, outboundRay)
  61. // Ensure outbound ray is properly closed.
  62. if err != nil && errors.Cause(err) != io.EOF {
  63. outboundRay.OutboundOutput().CloseError()
  64. } else {
  65. outboundRay.OutboundOutput().Close()
  66. }
  67. outboundRay.OutboundInput().CloseError()
  68. }
  69. func (h *Handler) Dial(ctx context.Context, dest v2net.Destination) (internet.Connection, error) {
  70. if h.senderSettings != nil {
  71. if h.senderSettings.ProxySettings.HasTag() {
  72. tag := h.senderSettings.ProxySettings.Tag
  73. handler := h.outboundManager.GetHandler(tag)
  74. if handler != nil {
  75. log.Info("Proxyman|OutboundHandler: Proxying to ", tag)
  76. ctx = proxy.ContextWithDestination(ctx, dest)
  77. stream := ray.NewRay(ctx)
  78. go handler.Dispatch(ctx, stream)
  79. return NewConnection(stream), nil
  80. }
  81. log.Warning("Proxyman|OutboundHandler: Failed to get outbound handler with tag: ", tag)
  82. }
  83. if h.senderSettings.Via != nil {
  84. ctx = internet.ContextWithDialerSource(ctx, h.senderSettings.Via.AsAddress())
  85. }
  86. if h.senderSettings != nil {
  87. ctx = internet.ContextWithStreamSettings(ctx, h.senderSettings.StreamSettings)
  88. }
  89. }
  90. return internet.Dial(ctx, dest)
  91. }
  92. type Connection struct {
  93. stream ray.Ray
  94. closed bool
  95. localAddr net.Addr
  96. remoteAddr net.Addr
  97. reader *buf.BufferToBytesReader
  98. writer *buf.BytesToBufferWriter
  99. }
  100. func NewConnection(stream ray.Ray) *Connection {
  101. return &Connection{
  102. stream: stream,
  103. localAddr: &net.TCPAddr{
  104. IP: []byte{0, 0, 0, 0},
  105. Port: 0,
  106. },
  107. remoteAddr: &net.TCPAddr{
  108. IP: []byte{0, 0, 0, 0},
  109. Port: 0,
  110. },
  111. reader: buf.NewBytesReader(stream.InboundOutput()),
  112. writer: buf.NewBytesWriter(stream.InboundInput()),
  113. }
  114. }
  115. // Read implements net.Conn.Read().
  116. func (v *Connection) Read(b []byte) (int, error) {
  117. if v.closed {
  118. return 0, io.EOF
  119. }
  120. return v.reader.Read(b)
  121. }
  122. // Write implements net.Conn.Write().
  123. func (v *Connection) Write(b []byte) (int, error) {
  124. if v.closed {
  125. return 0, io.ErrClosedPipe
  126. }
  127. return v.writer.Write(b)
  128. }
  129. // Close implements net.Conn.Close().
  130. func (v *Connection) Close() error {
  131. v.closed = true
  132. v.stream.InboundInput().Close()
  133. v.stream.InboundOutput().CloseError()
  134. return nil
  135. }
  136. // LocalAddr implements net.Conn.LocalAddr().
  137. func (v *Connection) LocalAddr() net.Addr {
  138. return v.localAddr
  139. }
  140. // RemoteAddr implements net.Conn.RemoteAddr().
  141. func (v *Connection) RemoteAddr() net.Addr {
  142. return v.remoteAddr
  143. }
  144. func (v *Connection) SetDeadline(t time.Time) error {
  145. return nil
  146. }
  147. func (v *Connection) SetReadDeadline(t time.Time) error {
  148. return nil
  149. }
  150. func (v *Connection) SetWriteDeadline(t time.Time) error {
  151. return nil
  152. }
  153. func (v *Connection) Reusable() bool {
  154. return false
  155. }
  156. func (v *Connection) SetReusable(bool) {
  157. }