inbound.go 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. package adapter
  2. import (
  3. "context"
  4. "net/netip"
  5. "time"
  6. "github.com/sagernet/sing-box/common/process"
  7. C "github.com/sagernet/sing-box/constant"
  8. "github.com/sagernet/sing-box/log"
  9. "github.com/sagernet/sing-box/option"
  10. M "github.com/sagernet/sing/common/metadata"
  11. )
  12. type Inbound interface {
  13. Lifecycle
  14. Type() string
  15. Tag() string
  16. }
  17. type TCPInjectableInbound interface {
  18. Inbound
  19. ConnectionHandlerEx
  20. }
  21. type UDPInjectableInbound interface {
  22. Inbound
  23. PacketConnectionHandlerEx
  24. }
  25. type InboundRegistry interface {
  26. option.InboundOptionsRegistry
  27. Create(ctx context.Context, router Router, logger log.ContextLogger, tag string, inboundType string, options any) (Inbound, error)
  28. }
  29. type InboundManager interface {
  30. Lifecycle
  31. Inbounds() []Inbound
  32. Get(tag string) (Inbound, bool)
  33. Remove(tag string) error
  34. Create(ctx context.Context, router Router, logger log.ContextLogger, tag string, inboundType string, options any) error
  35. }
  36. type InboundContext struct {
  37. Inbound string
  38. InboundType string
  39. IPVersion uint8
  40. Network string
  41. Source M.Socksaddr
  42. Destination M.Socksaddr
  43. User string
  44. Outbound string
  45. // sniffer
  46. Protocol string
  47. Domain string
  48. Client string
  49. SniffContext any
  50. // cache
  51. // Deprecated: implement in rule action
  52. InboundDetour string
  53. LastInbound string
  54. OriginDestination M.Socksaddr
  55. RouteOriginalDestination M.Socksaddr
  56. // Deprecated
  57. InboundOptions option.InboundOptions
  58. UDPDisableDomainUnmapping bool
  59. UDPConnect bool
  60. NetworkStrategy C.NetworkStrategy
  61. NetworkType []C.InterfaceType
  62. FallbackNetworkType []C.InterfaceType
  63. FallbackDelay time.Duration
  64. DNSServer string
  65. DestinationAddresses []netip.Addr
  66. SourceGeoIPCode string
  67. GeoIPCode string
  68. ProcessInfo *process.Info
  69. QueryType uint16
  70. FakeIP bool
  71. // rule cache
  72. IPCIDRMatchSource bool
  73. IPCIDRAcceptEmpty bool
  74. SourceAddressMatch bool
  75. SourcePortMatch bool
  76. DestinationAddressMatch bool
  77. DestinationPortMatch bool
  78. DidMatch bool
  79. IgnoreDestinationIPCIDRMatch bool
  80. }
  81. func (c *InboundContext) ResetRuleCache() {
  82. c.IPCIDRMatchSource = false
  83. c.IPCIDRAcceptEmpty = false
  84. c.SourceAddressMatch = false
  85. c.SourcePortMatch = false
  86. c.DestinationAddressMatch = false
  87. c.DestinationPortMatch = false
  88. c.DidMatch = false
  89. }
  90. type inboundContextKey struct{}
  91. func WithContext(ctx context.Context, inboundContext *InboundContext) context.Context {
  92. return context.WithValue(ctx, (*inboundContextKey)(nil), inboundContext)
  93. }
  94. func ContextFrom(ctx context.Context) *InboundContext {
  95. metadata := ctx.Value((*inboundContextKey)(nil))
  96. if metadata == nil {
  97. return nil
  98. }
  99. return metadata.(*InboundContext)
  100. }
  101. func ExtendContext(ctx context.Context) (context.Context, *InboundContext) {
  102. var newMetadata InboundContext
  103. if metadata := ContextFrom(ctx); metadata != nil {
  104. newMetadata = *metadata
  105. }
  106. return WithContext(ctx, &newMetadata), &newMetadata
  107. }
  108. func OverrideContext(ctx context.Context) context.Context {
  109. if metadata := ContextFrom(ctx); metadata != nil {
  110. var newMetadata InboundContext
  111. newMetadata = *metadata
  112. return WithContext(ctx, &newMetadata)
  113. }
  114. return ctx
  115. }