dae/example.dae

84 lines
2.7 KiB
Plaintext
Raw Normal View History

2023-01-28 00:50:21 +07:00
global {
# tproxy port to listen.
tproxy_port: 12345
# Log level: error, warn, info, debug, trace
log_level: info
2023-01-28 00:50:21 +07:00
# Node connectivity check.
# Url and dns should have both IPv4 and IPv6.
tcp_check_url: 'http://cp.cloudflare.com'
udp_check_dns: 'cloudflare-dns.com:53'
2023-01-28 14:47:43 +07:00
check_interval: 30s
2023-01-28 00:50:21 +07:00
# Now only support udp://IP:Port. Empty value '' indicates as-is.
2023-01-28 00:50:21 +07:00
# Please make sure DNS traffic will go through and be forwarded by dae.
2023-02-04 17:18:06 +07:00
# The upstream DNS answer MUST NOT be polluted.
2023-01-30 17:13:43 +07:00
# The request to dns upstream follows routing defined below.
dns_upstream: 'udp://8.8.8.8:53'
2023-01-28 00:50:21 +07:00
# The LAN interface to bind. Use it if you only want to proxy LAN instead of localhost.
# Multiple interfaces split by ",".
2023-01-30 17:13:43 +07:00
# lan_interface: docker0
# The WAN interface to bind. Use it if you want to proxy localhost
2023-02-04 19:53:29 +07:00
# Multiple interfaces split by ",".
2023-01-30 14:50:55 +07:00
wan_interface: wlp5s0
2023-01-28 00:50:21 +07:00
}
2023-01-31 23:02:46 +07:00
# Subscriptions defined here will be resolved as nodes and merged as a part of global node pool.
2023-01-28 00:50:21 +07:00
subscription {
# Add your subscription links here.
}
2023-01-31 23:02:46 +07:00
# Nodes defined here will be merged as a part of global node pool.
2023-01-28 00:50:21 +07:00
node {
# Add your node links here.
# Support socks5, http, https, ss, ssr, vmess, vless, trojan, trojan-go
2023-01-30 17:13:43 +07:00
'socks5://localhost:1080'
2023-01-28 00:50:21 +07:00
'ss://LINK'
}
2023-02-05 12:31:21 +07:00
# Node group (outbound).
2023-01-28 00:50:21 +07:00
group {
my_group {
2023-01-31 23:02:46 +07:00
# Filter nodes from global node pool defined by subscription and node section above.
# Pass node names as input of keyword/regex filter.
filter: name(regex:'HK|SG|TW', keyword:'JP', keyword: SH) && !name(keyword:"GCP")
2023-01-28 00:50:21 +07:00
# Randomly select a node from the group for every connection.
# policy: random
# Select the first node from the group for every connection.
# policy: fixed(0)
# Select the node with min last latency from the group for every connection.
policy: min
2023-01-28 00:50:21 +07:00
}
2023-01-31 23:02:46 +07:00
group2 {
# Filter nodes from global node pool defined by subscription and node section above.
# Pass node names as input of keyword/regex filter.
filter: name(keyword: netflix)
# Select the node with min average of the last 10 latencies from the group for every connection.
policy: min_avg10
}
2023-01-28 00:50:21 +07:00
}
2023-02-05 12:31:21 +07:00
# See routing.md for full examples.
2023-01-28 00:50:21 +07:00
routing {
ip(geoip:private, 224.0.0.0/3, 'ff00::/8') -> direct # Put it first unless you know what you're doing.
2023-02-05 12:31:21 +07:00
# Write your rules below.
2023-01-31 23:02:46 +07:00
2023-02-04 19:53:29 +07:00
# dae arms DNS rush-answer filter so we can use 8.8.8.8 regardless of DNS pollution.
ip(8.8.8.8) && port(53) -> direct
pname(firefox) && domain(ip.sb) -> direct
pname(curl) && domain(ip.sb) -> my_group
2023-01-30 17:13:43 +07:00
2023-01-28 00:50:21 +07:00
ip(geoip:cn) -> direct
domain(geosite:cn) -> direct
final: my_group
}