Commit graph

110 commits

Author SHA1 Message Date
世界
8875b52d51
dns: Refactor reordered pool 2026-05-12 00:11:55 +08:00
世界
7b3a1de7bc
dns: Fix conn pool leak 2026-05-11 21:58:14 +08:00
世界
228eb2df78
dns: Fix deadline 2026-05-05 10:48:28 +08:00
世界
98b21227fa
dns: Add mDNS server 2026-05-02 19:18:41 +08:00
世界
fdec2fe051
dns: Add preferred_by rule item 2026-05-02 19:18:41 +08:00
世界
e171852b19
dns: Add neighbor-based hostname resolution to local server 2026-05-02 19:18:41 +08:00
世界
1bad8d87eb
dns: Add timeout configuration 2026-04-28 15:12:39 +08:00
世界
b418ee1a98
Improve oom-killer 2026-04-28 08:55:06 +08:00
世界
d06d3bf2a4
Fix darwin cgo DNS again 2026-04-28 08:04:55 +08:00
世界
6b51bd6778
Log DNS optimistic background refresh outcomes 2026-04-28 08:04:54 +08:00
世界
3c9c4aee07
Strip EDNS padding from upstream DNS responses 2026-04-28 08:04:53 +08:00
世界
90a642ef96
Reject pure-IP rule-set references without match_response
DNS rules referencing rule-sets that contain only ip_cidr predicates
silently stopped matching when legacy DNS mode was disabled, because the
IP-CIDR branch cannot match against an in-flight DNS query. The existing
validation intentionally let every rule_set through on the premise that
mixed sets still work via their non-IP branches, which is only true when
such a branch exists. Track whether a rule-set carries any non-IP-CIDR
predicate and reject pure-IP references the same way bare ip_cidr fields
are already rejected.
2026-04-28 08:04:52 +08:00
世界
6ef38042f3
Standardize hosts path 2026-04-28 08:04:51 +08:00
世界
5a618c6b68
Refactor: HTTP clients, unified HTTP2/QUIC options, Apple engines 2026-04-28 08:04:39 +08:00
世界
0319b22c76
Add optimistic DNS cache 2026-04-28 08:04:34 +08:00
世界
8fb019164e
Fix darwin cgo DNS again 2026-04-28 08:04:33 +08:00
世界
e75e1c98a9
Un-deprecate ip_accept_any DNS rule item 2026-04-28 08:04:32 +08:00
世界
eade67726a
Fix darwin local DNS transport 2026-04-28 08:04:31 +08:00
世界
ec75e5ec0a
Fix rules lock 2026-04-28 08:04:31 +08:00
nekohasekai
e1a7ab3df3
Add evaluate DNS rule action and related rule items 2026-04-28 08:04:30 +08:00
世界
3312b8da50
Clean up DNS transports 2026-04-23 02:30:32 +08:00
世界
8e3176b789
Fix FakeIP returning error for unconfigured address family
Return SUCCESS with empty answers instead of an error when the
queried address family has no range configured. Reject configurations
where neither inet4_range nor inet6_range is set.
2026-04-14 14:15:20 +08:00
Berkay Özdemirci
5a957fd750
Fix EDNS OPT record corruption in DNS cache
The TTL computation and assignment loops treat OPT record's Hdr.Ttl
as a regular TTL, but per RFC 6891 it encodes EDNS0 metadata
(ExtRCode|Version|Flags). This corrupts cached responses causing
systemd-resolved to reject them with EDNS version 255.

Also fix pointer aliasing: storeCache() stored raw *dns.Msg pointer
so subsequent mutations by Exchange() corrupted cached data.

- Skip OPT records in all TTL loops (Exchange + loadResponse)
- Use message.Copy() in storeCache() to isolate cache from mutations
2026-04-10 14:08:24 +08:00
世界
72bc4c1f87
Fix DNS transport returning error for empty AAAA response
Closes #3925
2026-03-23 19:21:55 +08:00
世界
0889ddd001
Fix connector canceled dial cleanup 2026-03-15 17:56:37 +08:00
世界
4d6fb1d38d
Fix legacy DNS client_subnet options not working 2026-03-09 20:18:47 +08:00
世界
aa495fce38
Fix local DNS transport CNAME chain broken with systemd-resolved
Replace D-Bus ResolveRecord API with direct raw DNS queries to upstream
servers obtained from systemd-resolved's per-interface link properties.
2026-03-09 20:06:34 +08:00
世界
e343cec4d5
Fix legacy DNS defaults on final transport 2026-03-09 20:06:34 +08:00
世界
27c5b0b1af
Fix DNS exchange failure and recursion deadlock in connector
Co-authored-by: everyx <lunt.luo@gmail.com>
2026-03-06 15:31:22 +08:00
世界
e62dc7bfa2
Fix rule_set_ip_cidr_accept_empty not working 2026-03-04 11:48:22 +08:00
世界
ab76062a41
Fix fake-ip address allocation 2026-03-03 21:37:24 +08:00
dyhkwong
4c65fea1ac
Fix IPv6 local DNS on Windows 2026-03-01 12:30:43 +08:00
世界
8714c157c9
Fix matching multi predefined 2026-02-15 21:09:06 +08:00
世界
aba8346bd6
Fix DNS cache lock goroutine leak
The cache deduplication in Client.Exchange uses a channel-based lock
per DNS question. Waiting goroutines blocked on <-cond without context
awareness, causing them to accumulate indefinitely when the owning
goroutine's transport call stalls. Add select on ctx.Done() so waiters
respect context cancellation and timeouts.
2026-02-06 22:28:35 +08:00
世界
aa8dd6e44f
Fix DNS transports 2026-01-17 05:48:41 +08:00
世界
a930356b04
Revert "Stop using DHCP on iOS and tvOS" 2026-01-17 05:47:32 +08:00
世界
5bc0dfa9dd
platform: Refactoring libbox to use gRPC-based protocol 2026-01-17 05:47:32 +08:00
世界
fce21607bd
Use a more conservative strategy for resolving with systemd-resolved for local DNS server 2026-01-17 05:46:23 +08:00
世界
ed1ee4c3a4
Update quic-go to v0.55.0 2026-01-17 05:46:13 +08:00
世界
107f92381b
Add support for kTLS
Reference: https://gitlab.com/go-extension/tls
2026-01-17 05:44:42 +08:00
世界
44fafcef73
Fix resolve using resolved 2026-01-17 05:44:29 +08:00
世界
bba92146b1
Stop using DHCP on iOS and tvOS
We do not have the `com.apple.developer.networking.multicast` entitlement and are unable to obtain it for non-technical reasons.
2026-01-17 05:44:28 +08:00
世界
48f84b31d6
Improve local DNS server on darwin
We mistakenly believed that `libresolv`'s `search` function worked correctly in NetworkExtension, but it seems only `getaddrinfo` does.

This commit changes the behavior of the `local` DNS server in NetworkExtension to prefer DHCP, falling back to `getaddrinfo` if DHCP servers are unavailable.

It's worth noting that `prefer_go` does not disable DHCP since it respects Dial Fields, but `getaddrinfo` does the opposite. The new behavior only applies to NetworkExtension, not to all scenarios (primarily command-line binaries) as it did previously.

In addition, this commit also improves the DHCP DNS server to use the same robust query logic as `local`.
2026-01-17 05:44:28 +08:00
世界
1c846df903
Use resolved in local DNS server if available 2026-01-17 05:44:28 +08:00
neletor
1f03080540
Add support for ech retry configs 2026-01-17 05:44:26 +08:00
Gavin Luo
fffe9fc566
Fix reset buffer in dhcp response loop
Previously, the buffer was not reset within the response loop. If a packet
handle failed or completed, the buffer retained its state. Specifically,
if `ReadPacketFrom` returned `io.ErrShortBuffer`, the error was ignored
via `continue`, but the buffer remained full. This caused the next
read attempt to immediately fail with the same error, creating a tight
busy-wait loop that consumed 100% CPU.

Validates `buffer.Reset()` is called at the start of each iteration to
ensure a clean state for 'ReadPacketFrom'.
2026-01-05 17:46:59 +08:00
世界
1ebff74c21
Fix DNS cache not working when domain strategy is set
The cache lookup was performed before rule matching, using the caller's
strategy (usually AsIS/0) instead of the resolved strategy. This caused
cache misses when ipv4_only was configured globally but the cache lookup
expected both A and AAAA records.

Remove LookupCache and ExchangeCache from Router, as the cache checks
inside client.Lookup and client.Exchange already handle caching correctly
after rule matching with the proper strategy and transport.
2025-12-21 16:59:10 +08:00
世界
5658830077
Fix trailing dot handling in local DNS transport 2025-10-16 21:43:12 +08:00
世界
06791470c9
Fix DNS reject panic 2025-10-14 23:40:19 +08:00
世界
36dc883c7c
Fix DNS negative caching to comply with RFC 2308 2025-10-09 23:45:23 +08:00