v2ray.go 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. package core
  2. import (
  3. "v2ray.com/core/app"
  4. "v2ray.com/core/app/dispatcher"
  5. dispatchers "v2ray.com/core/app/dispatcher/impl"
  6. "v2ray.com/core/app/dns"
  7. proxydialer "v2ray.com/core/app/proxy"
  8. "v2ray.com/core/app/proxyman"
  9. "v2ray.com/core/common"
  10. "v2ray.com/core/common/log"
  11. v2net "v2ray.com/core/common/net"
  12. "v2ray.com/core/proxy"
  13. proxyregistry "v2ray.com/core/proxy/registry"
  14. )
  15. // Point shell of V2Ray.
  16. type Point struct {
  17. inboundHandlers []InboundDetourHandler
  18. taggedInboundHandlers map[string]InboundDetourHandler
  19. outboundHandlers []proxy.OutboundHandler
  20. taggedOutboundHandlers map[string]proxy.OutboundHandler
  21. space app.Space
  22. }
  23. // NewPoint returns a new Point server based on given configuration.
  24. // The server is not started at this point.
  25. func NewPoint(pConfig *Config) (*Point, error) {
  26. var vpoint = new(Point)
  27. if err := pConfig.Transport.Apply(); err != nil {
  28. return nil, err
  29. }
  30. if err := pConfig.Log.Apply(); err != nil {
  31. return nil, err
  32. }
  33. space := app.NewSpace()
  34. vpoint.space = space
  35. vpoint.space.BindApp(proxyman.APP_ID_INBOUND_MANAGER, vpoint)
  36. outboundHandlerManager := proxyman.NewDefaultOutboundHandlerManager()
  37. vpoint.space.BindApp(proxyman.APP_ID_OUTBOUND_MANAGER, outboundHandlerManager)
  38. proxyDialer := proxydialer.NewOutboundProxy(space)
  39. proxyDialer.RegisterDialer()
  40. space.BindApp(proxydialer.APP_ID, proxyDialer)
  41. for _, app := range pConfig.App {
  42. settings, err := app.GetInstance()
  43. if err != nil {
  44. return nil, err
  45. }
  46. if err := space.BindFromConfig(app.Type, settings); err != nil {
  47. return nil, err
  48. }
  49. }
  50. if !space.HasApp(dns.APP_ID) {
  51. dnsServer := dns.NewCacheServer(space, &dns.Config{
  52. NameServers: []*v2net.Endpoint{
  53. {
  54. Address: &v2net.IPOrDomain{
  55. Address: &v2net.IPOrDomain_Domain{
  56. Domain: "localhost",
  57. },
  58. },
  59. },
  60. },
  61. })
  62. space.BindApp(dns.APP_ID, dnsServer)
  63. }
  64. vpoint.space.BindApp(dispatcher.APP_ID, dispatchers.NewDefaultDispatcher(vpoint.space))
  65. vpoint.inboundHandlers = make([]InboundDetourHandler, 0, 8)
  66. vpoint.taggedInboundHandlers = make(map[string]InboundDetourHandler)
  67. for _, inbound := range pConfig.Inbound {
  68. allocConfig := inbound.GetAllocationStrategyValue()
  69. var inboundHandler InboundDetourHandler
  70. switch allocConfig.Type {
  71. case AllocationStrategy_Always:
  72. dh, err := NewInboundDetourHandlerAlways(vpoint.space, inbound)
  73. if err != nil {
  74. log.Error("Point: Failed to create detour handler: ", err)
  75. return nil, common.ErrBadConfiguration
  76. }
  77. inboundHandler = dh
  78. case AllocationStrategy_Random:
  79. dh, err := NewInboundDetourHandlerDynamic(vpoint.space, inbound)
  80. if err != nil {
  81. log.Error("Point: Failed to create detour handler: ", err)
  82. return nil, common.ErrBadConfiguration
  83. }
  84. inboundHandler = dh
  85. default:
  86. log.Error("Point: Unknown allocation strategy: ", allocConfig.Type)
  87. return nil, common.ErrBadConfiguration
  88. }
  89. vpoint.inboundHandlers = append(vpoint.inboundHandlers, inboundHandler)
  90. if len(inbound.Tag) > 0 {
  91. vpoint.taggedInboundHandlers[inbound.Tag] = inboundHandler
  92. }
  93. }
  94. vpoint.outboundHandlers = make([]proxy.OutboundHandler, 0, 8)
  95. vpoint.taggedOutboundHandlers = make(map[string]proxy.OutboundHandler)
  96. for idx, outbound := range pConfig.Outbound {
  97. outboundSettings, err := outbound.GetTypedSettings()
  98. if err != nil {
  99. return nil, err
  100. }
  101. outboundHandler, err := proxyregistry.CreateOutboundHandler(
  102. outbound.Settings.Type, vpoint.space, outboundSettings, &proxy.OutboundHandlerMeta{
  103. Tag: outbound.Tag,
  104. Address: outbound.GetSendThroughValue(),
  105. StreamSettings: outbound.StreamSettings,
  106. ProxySettings: outbound.ProxySettings,
  107. })
  108. if err != nil {
  109. log.Error("Point: Failed to create detour outbound connection handler: ", err)
  110. return nil, err
  111. }
  112. if idx == 0 {
  113. outboundHandlerManager.SetDefaultHandler(outboundHandler)
  114. }
  115. if len(outbound.Tag) > 0 {
  116. outboundHandlerManager.SetHandler(outbound.Tag, outboundHandler)
  117. vpoint.taggedOutboundHandlers[outbound.Tag] = outboundHandler
  118. }
  119. vpoint.outboundHandlers = append(vpoint.outboundHandlers, outboundHandler)
  120. }
  121. if err := vpoint.space.Initialize(); err != nil {
  122. return nil, err
  123. }
  124. return vpoint, nil
  125. }
  126. func (this *Point) Close() {
  127. for _, inbound := range this.inboundHandlers {
  128. inbound.Close()
  129. }
  130. }
  131. // Start starts the Point server, and return any error during the process.
  132. // In the case of any errors, the state of the server is unpredicatable.
  133. func (this *Point) Start() error {
  134. for _, inbound := range this.inboundHandlers {
  135. err := inbound.Start()
  136. if err != nil {
  137. return err
  138. }
  139. }
  140. log.Warning("V2Ray started.")
  141. return nil
  142. }
  143. func (this *Point) GetHandler(tag string) (proxy.InboundHandler, int) {
  144. handler, found := this.taggedInboundHandlers[tag]
  145. if !found {
  146. log.Warning("Point: Unable to find an inbound handler with tag: ", tag)
  147. return nil, 0
  148. }
  149. return handler.GetConnectionHandler()
  150. }
  151. func (this *Point) Release() {
  152. }