Commit Graph

2309 Commits

Author SHA1 Message Date
世界
a7c4096a07 dns: fix err shadowing in buildRules
Reuse the outer err variable in the rule-construction and rule-startup
loops instead of redeclaring it with :=, and declare dnsRule separately.
2026-03-31 17:13:18 +08:00
世界
0e87476ee5 dns: return immediately on context cancellation in evaluate exchange 2026-03-31 17:08:52 +08:00
世界
21f3acef81 dns: reject method reply is not supported for DNS rules
Add config-time validation in NewDNSRule that rejects
RejectMethodReply for both default and logical DNS rules,
matching the existing TCP/UDP validation in route/route.go.
2026-03-31 16:53:57 +08:00
世界
861fa897e0 dns: improve test coverage and cleanup
- Add t.Cleanup(router.Close) in newTestRouter for automatic cleanup
- Remove unnecessary testCase loop variable capture (Go 1.22+)
- Add tests for reject drop action, route_options effect, and
  chained evaluate response overwrite
2026-03-31 15:53:38 +08:00
世界
c471d7fee7 dns: fix test style issues in repro_test.go
- Rename addrs to addresses per naming conventions
- Replace errors.New with E.New per error-handling rules
2026-03-31 15:53:30 +08:00
世界
7de00c7cd1 fix: add missing EnvName, document Strategy invariant, improve rcode display
- Add EnvName to four new deprecation constants so users can suppress
  warnings via ENABLE_DEPRECATED_* environment variables
- Add comment explaining why applyDNSRouteOptions skips Strategy
- Use dns.RcodeToString in DNSResponseRCodeItem.String() for readability
- Remove redundant Fqdn(FqdnToDomain(domain)) round-trip
2026-03-31 15:47:29 +08:00
世界
29024191ee docs: fix strategy deprecation format, explain legacyDNSMode, unify CN/EN order
- Use standard !!! failure block for strategy deprecation notice
- Add Legacy DNS Mode section explaining automatic mode detection
- Reorder ip_accept_any/rule_set_ip_cidr_accept_empty in Chinese docs
  to match English
2026-03-31 15:43:04 +08:00
世界
16480095f7 dns: populate reverse mapping for legacy predefined responses
The legacy path returned predefined responses early, bypassing the
reverse mapping cache. Use goto to reach the shared post-exchange
block so both legacy and new paths record predefined A/AAAA answers.
2026-03-31 15:37:10 +08:00
世界
cf33f1f375 route/rule: remove dead IgnoreDestinationIPCIDRMatch field
The field was never set to true after the legacy pre-match refactor
in 3549c02b8. Remove the declaration, guard check, and redundant
false assignments.
2026-03-31 15:29:50 +08:00
世界
1d872a6835 dns: use refcounted snapshot to narrow rule lock scope
Exchange and Lookup held rulesAccess.RLock across all DNS network I/O,
blocking rebuildRules from swapping in new rules until every in-flight
query finished. Replace the RWMutex with an atomic pointer to a
refcounted rulesSnapshot so queries only hold a snapshot reference
during execution, allowing concurrent rule rebuilds.
2026-03-31 15:29:16 +08:00
世界
fb19bf6111 dns: serialize rebuilds and keep last good rules on failure 2026-03-31 13:15:25 +08:00
世界
da210af48d docs: fix grammar errors and typos 2026-03-31 10:24:40 +08:00
世界
6a351be73a Suppress SA1019 lint warnings for intentional deprecated field usage 2026-03-31 07:56:13 +08:00
世界
1913376113 docs: add evaluate action, response matching fields, and deprecation notices 2026-03-31 07:56:13 +08:00
世界
b05f58b469 Use typed SVCB hint structs instead of string parsing 2026-03-31 07:56:13 +08:00
世界
baf1da892b option: reject nested rule actions 2026-03-31 07:56:13 +08:00
世界
f3c8fe59ac dns: make rule strategy legacy-only 2026-03-31 07:56:13 +08:00
世界
117422db68 Make DNS match_response fail as a normal condition 2026-03-31 07:56:13 +08:00
世界
5b32dbf57f Fix DNS rule-set ref handling 2026-03-31 07:56:12 +08:00
世界
d103fc2aea Fix legacy DNS rule_set accept_empty matching 2026-03-31 07:56:12 +08:00
世界
532f350637 dns: restore lookup reject semantics 2026-03-31 07:56:12 +08:00
世界
d82e7cd4b6 Fix DNS record parser file inclusion and rule match log index
Remove SetIncludeAllowed(true) from the DNS record zone parser.
The $INCLUDE directive allows opening arbitrary files via os.Open,
which is unnecessary and dangerous when parsing a single record string
from configuration (especially remote profiles).

Fix displayRuleIndex arithmetic in dns/router.go that computed
2*index+1 instead of the correct 0-based index. This was a
reintroduction of a bug previously fixed in be8ee370a. Both
matchDNS and logRuleMatch now use the index directly, matching
the pattern in route/route.go.
2026-03-31 07:56:12 +08:00
世界
f628519333 Fix DNS record parsing and shutdown race 2026-03-31 07:56:12 +08:00
世界
7def08b5a1 dns: restore init validation and fix rule-set query type 2026-03-31 07:56:12 +08:00
世界
8ba8ad5f0c dns: make rule path selection rule-set aware 2026-03-31 07:56:12 +08:00
世界
07f2fd65b2 dns: complete lookup rule execution in new mode 2026-03-31 07:56:11 +08:00
世界
31c707f8e8 Fix legacy DNS negation expansion 2026-03-31 07:56:11 +08:00
世界
3549c02b8c dns: isolate legacy pre-match semantics 2026-03-31 07:56:11 +08:00
世界
e5aaf782c6 dns: preserve legacy address-filter pre-match semantics
Legacy DNS address-filter mode still accepts destination-side IP
predicates with a deprecation warning, but the recent evaluate/
match_response refactor started evaluating those predicates during
pre-response Match(). That broke rules whose transport selection must
be deferred until MatchAddressLimit() can inspect the upstream reply.

Restore the old defer behavior by reintroducing an internal
IgnoreDestinationIPCIDRMatch flag on InboundContext and using it only
for legacy pre-response DNS matching. Default and logical DNS rules now
carry the legacy mode bit, set the ignore flag on metadata copies while
performing pre-response Match(), and explicitly clear it again for
match_response and MatchAddressLimit() so response-phase matching still
checks the returned addresses.

Add regression coverage for direct legacy destination-IP rules,
rule_set-backed CIDR rules, logical wrappers, and the legacy Lookup
router path, including fallback after a rejected response. This keeps
legacy configs working without changing new-mode evaluate semantics.

Tests: go test ./route/rule ./dns
Tests: make
2026-03-31 07:56:11 +08:00
世界
5b08ae150f Remove legacy DNS server formats 2026-03-31 07:56:11 +08:00
世界
704482bb4a dns: document non-response rule_set address-filter semantics 2026-03-31 07:56:11 +08:00
世界
5436192ada Fix DNS pre-match CIDR fail-closed semantics 2026-03-31 07:56:10 +08:00
世界
d2f005aea3 Fix DNS evaluate regressions 2026-03-31 07:56:10 +08:00
世界
dc9b2089ea dns: use response-only address matching 2026-03-31 07:56:10 +08:00
世界
b16b6f8b18 Fix DNS match_response response address handling 2026-03-31 07:56:10 +08:00
世界
ab414f20f5 Fix DNS record parsing and matching regressions 2026-03-31 07:56:10 +08:00
世界
f8cbe27b39 Fix DNS evaluate routing regressions 2026-03-31 07:56:10 +08:00
世界
2544d26664 Reorder DNS rule item fields: match_response above address filter and response items, deprecated fields at bottom 2026-03-31 07:56:09 +08:00
世界
bcaba94c61 Add evaluate DNS rule action and related rule items 2026-03-31 07:56:09 +08:00
世界
ebf8a213b6 Bump version v1.14.0-alpha.8 2026-03-31 00:38:42 +08:00
世界
ab323e0eb9 Add BBR profile and hop interval randomization for Hysteria2 2026-03-31 00:38:42 +08:00
nekohasekai
2132e68d3a Refactor ACME support to certificate provider 2026-03-30 23:21:50 +08:00
世界
47742abe93 cronet-go: Update chromium to 145.0.7632.159 2026-03-30 23:21:50 +08:00
世界
77e51035bd documentation: Update descriptions for neighbor rules 2026-03-30 23:21:50 +08:00
世界
eeb5dead2a Add macOS support for MAC and hostname rule items 2026-03-30 23:21:50 +08:00
世界
45339d101b Add Android support for MAC and hostname rule items 2026-03-30 23:21:50 +08:00
世界
04c0490992 Add MAC and hostname rule items 2026-03-30 23:21:50 +08:00
世界
7ffdc48b49 Bump version v1.13.5 2026-03-30 23:03:43 +08:00
世界
e15bdf11eb sing: Minor fixes 2026-03-30 22:58:11 +08:00
世界
e3bcb06c3e platform: Add HTTPResponse.WriteToWithProgress 2026-03-30 22:42:36 +08:00