rule_headless.go 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. package route
  2. import (
  3. "github.com/sagernet/sing-box/adapter"
  4. C "github.com/sagernet/sing-box/constant"
  5. "github.com/sagernet/sing-box/option"
  6. E "github.com/sagernet/sing/common/exceptions"
  7. )
  8. func NewHeadlessRule(router adapter.Router, options option.HeadlessRule) (adapter.HeadlessRule, error) {
  9. switch options.Type {
  10. case "", C.RuleTypeDefault:
  11. if !options.DefaultOptions.IsValid() {
  12. return nil, E.New("missing conditions")
  13. }
  14. return NewDefaultHeadlessRule(router, options.DefaultOptions)
  15. case C.RuleTypeLogical:
  16. if !options.LogicalOptions.IsValid() {
  17. return nil, E.New("missing conditions")
  18. }
  19. return NewLogicalHeadlessRule(router, options.LogicalOptions)
  20. default:
  21. return nil, E.New("unknown rule type: ", options.Type)
  22. }
  23. }
  24. var _ adapter.HeadlessRule = (*DefaultHeadlessRule)(nil)
  25. type DefaultHeadlessRule struct {
  26. abstractDefaultRule
  27. }
  28. func NewDefaultHeadlessRule(router adapter.Router, options option.DefaultHeadlessRule) (*DefaultHeadlessRule, error) {
  29. rule := &DefaultHeadlessRule{
  30. abstractDefaultRule{
  31. invert: options.Invert,
  32. },
  33. }
  34. if len(options.Network) > 0 {
  35. item := NewNetworkItem(options.Network)
  36. rule.items = append(rule.items, item)
  37. rule.allItems = append(rule.allItems, item)
  38. }
  39. if len(options.Domain) > 0 || len(options.DomainSuffix) > 0 {
  40. item := NewDomainItem(options.Domain, options.DomainSuffix)
  41. rule.destinationAddressItems = append(rule.destinationAddressItems, item)
  42. rule.allItems = append(rule.allItems, item)
  43. } else if options.DomainMatcher != nil {
  44. item := NewRawDomainItem(options.DomainMatcher)
  45. rule.destinationAddressItems = append(rule.destinationAddressItems, item)
  46. rule.allItems = append(rule.allItems, item)
  47. }
  48. if len(options.DomainKeyword) > 0 {
  49. item := NewDomainKeywordItem(options.DomainKeyword)
  50. rule.destinationAddressItems = append(rule.destinationAddressItems, item)
  51. rule.allItems = append(rule.allItems, item)
  52. }
  53. if len(options.DomainRegex) > 0 {
  54. item, err := NewDomainRegexItem(options.DomainRegex)
  55. if err != nil {
  56. return nil, E.Cause(err, "domain_regex")
  57. }
  58. rule.destinationAddressItems = append(rule.destinationAddressItems, item)
  59. rule.allItems = append(rule.allItems, item)
  60. }
  61. if len(options.SourceIPCIDR) > 0 {
  62. item, err := NewIPCIDRItem(true, options.SourceIPCIDR)
  63. if err != nil {
  64. return nil, E.Cause(err, "source_ip_cidr")
  65. }
  66. rule.sourceAddressItems = append(rule.sourceAddressItems, item)
  67. rule.allItems = append(rule.allItems, item)
  68. } else if options.SourceIPSet != nil {
  69. item := NewRawIPCIDRItem(true, options.SourceIPSet)
  70. rule.sourceAddressItems = append(rule.sourceAddressItems, item)
  71. rule.allItems = append(rule.allItems, item)
  72. }
  73. if len(options.IPCIDR) > 0 {
  74. item, err := NewIPCIDRItem(false, options.IPCIDR)
  75. if err != nil {
  76. return nil, E.Cause(err, "ipcidr")
  77. }
  78. rule.destinationIPCIDRItems = append(rule.destinationIPCIDRItems, item)
  79. rule.allItems = append(rule.allItems, item)
  80. } else if options.IPSet != nil {
  81. item := NewRawIPCIDRItem(false, options.IPSet)
  82. rule.destinationIPCIDRItems = append(rule.destinationIPCIDRItems, item)
  83. rule.allItems = append(rule.allItems, item)
  84. }
  85. if len(options.SourcePort) > 0 {
  86. item := NewPortItem(true, options.SourcePort)
  87. rule.sourcePortItems = append(rule.sourcePortItems, item)
  88. rule.allItems = append(rule.allItems, item)
  89. }
  90. if len(options.SourcePortRange) > 0 {
  91. item, err := NewPortRangeItem(true, options.SourcePortRange)
  92. if err != nil {
  93. return nil, E.Cause(err, "source_port_range")
  94. }
  95. rule.sourcePortItems = append(rule.sourcePortItems, item)
  96. rule.allItems = append(rule.allItems, item)
  97. }
  98. if len(options.Port) > 0 {
  99. item := NewPortItem(false, options.Port)
  100. rule.destinationPortItems = append(rule.destinationPortItems, item)
  101. rule.allItems = append(rule.allItems, item)
  102. }
  103. if len(options.PortRange) > 0 {
  104. item, err := NewPortRangeItem(false, options.PortRange)
  105. if err != nil {
  106. return nil, E.Cause(err, "port_range")
  107. }
  108. rule.destinationPortItems = append(rule.destinationPortItems, item)
  109. rule.allItems = append(rule.allItems, item)
  110. }
  111. if len(options.ProcessName) > 0 {
  112. item := NewProcessItem(options.ProcessName)
  113. rule.items = append(rule.items, item)
  114. rule.allItems = append(rule.allItems, item)
  115. }
  116. if len(options.ProcessPath) > 0 {
  117. item := NewProcessPathItem(options.ProcessPath)
  118. rule.items = append(rule.items, item)
  119. rule.allItems = append(rule.allItems, item)
  120. }
  121. if len(options.ProcessPathRegex) > 0 {
  122. item, err := NewProcessPathRegexItem(options.ProcessPathRegex)
  123. if err != nil {
  124. return nil, E.Cause(err, "process_path_regex")
  125. }
  126. rule.items = append(rule.items, item)
  127. rule.allItems = append(rule.allItems, item)
  128. }
  129. if len(options.PackageName) > 0 {
  130. item := NewPackageNameItem(options.PackageName)
  131. rule.items = append(rule.items, item)
  132. rule.allItems = append(rule.allItems, item)
  133. }
  134. if len(options.WIFISSID) > 0 {
  135. if router != nil {
  136. item := NewWIFISSIDItem(router, options.WIFISSID)
  137. rule.items = append(rule.items, item)
  138. rule.allItems = append(rule.allItems, item)
  139. }
  140. }
  141. if len(options.WIFIBSSID) > 0 {
  142. if router != nil {
  143. item := NewWIFIBSSIDItem(router, options.WIFIBSSID)
  144. rule.items = append(rule.items, item)
  145. rule.allItems = append(rule.allItems, item)
  146. }
  147. }
  148. if len(options.AdGuardDomain) > 0 {
  149. item := NewAdGuardDomainItem(options.AdGuardDomain)
  150. rule.destinationAddressItems = append(rule.destinationAddressItems, item)
  151. rule.allItems = append(rule.allItems, item)
  152. } else if options.AdGuardDomainMatcher != nil {
  153. item := NewRawAdGuardDomainItem(options.AdGuardDomainMatcher)
  154. rule.destinationAddressItems = append(rule.destinationAddressItems, item)
  155. rule.allItems = append(rule.allItems, item)
  156. }
  157. return rule, nil
  158. }
  159. var _ adapter.HeadlessRule = (*LogicalHeadlessRule)(nil)
  160. type LogicalHeadlessRule struct {
  161. abstractLogicalRule
  162. }
  163. func NewLogicalHeadlessRule(router adapter.Router, options option.LogicalHeadlessRule) (*LogicalHeadlessRule, error) {
  164. r := &LogicalHeadlessRule{
  165. abstractLogicalRule{
  166. rules: make([]adapter.HeadlessRule, len(options.Rules)),
  167. invert: options.Invert,
  168. },
  169. }
  170. switch options.Mode {
  171. case C.LogicalTypeAnd:
  172. r.mode = C.LogicalTypeAnd
  173. case C.LogicalTypeOr:
  174. r.mode = C.LogicalTypeOr
  175. default:
  176. return nil, E.New("unknown logical mode: ", options.Mode)
  177. }
  178. for i, subRule := range options.Rules {
  179. rule, err := NewHeadlessRule(router, subRule)
  180. if err != nil {
  181. return nil, E.Cause(err, "sub rule[", i, "]")
  182. }
  183. r.rules[i] = rule
  184. }
  185. return r, nil
  186. }