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