Improve iproute2 rules

This commit is contained in:
世界 2024-05-30 22:25:26 +08:00
parent 9939b78c88
commit ad763519ff
No known key found for this signature in database
GPG key ID: CD109927C34A63C4

View file

@ -516,7 +516,7 @@ func (t *NativeTun) rules() []*netlink.Rule {
if runtime.GOOS == "android" && t.options.InterfaceMonitor.AndroidVPNEnabled() { if runtime.GOOS == "android" && t.options.InterfaceMonitor.AndroidVPNEnabled() {
const protectedFromVPN = 0x20000 const protectedFromVPN = 0x20000
if p4 || t.options.StrictRoute { if p4 {
it = netlink.NewRule() it = netlink.NewRule()
if t.options.InterfaceMonitor.OverrideAndroidVPN() { if t.options.InterfaceMonitor.OverrideAndroidVPN() {
it.Mark = protectedFromVPN it.Mark = protectedFromVPN
@ -528,7 +528,7 @@ func (t *NativeTun) rules() []*netlink.Rule {
rules = append(rules, it) rules = append(rules, it)
priority++ priority++
} }
if p6 || t.options.StrictRoute { if p6 {
it = netlink.NewRule() it = netlink.NewRule()
if t.options.InterfaceMonitor.OverrideAndroidVPN() { if t.options.InterfaceMonitor.OverrideAndroidVPN() {
it.Mark = protectedFromVPN it.Mark = protectedFromVPN
@ -627,74 +627,78 @@ func (t *NativeTun) rules() []*netlink.Rule {
priority6++ priority6++
} }
} }
if p4 { if p4 {
if t.options.StrictRoute { it = netlink.NewRule()
it = netlink.NewRule() it.Priority = priority
it.Priority = priority it.IifName = t.options.Name
it.Table = t.options.TableIndex it.Goto = nopPriority
it.Family = unix.AF_INET it.Family = unix.AF_INET
rules = append(rules, it) rules = append(rules, it)
} else { priority++
it = netlink.NewRule()
it.Priority = priority
it.Invert = true
it.IifName = "lo"
it.Table = t.options.TableIndex
it.Family = unix.AF_INET
rules = append(rules, it)
it = netlink.NewRule()
it.Priority = priority
it.Invert = true
it.IifName = "lo"
it.Table = t.options.TableIndex
it.Family = unix.AF_INET
rules = append(rules, it)
it = netlink.NewRule()
it.Priority = priority
it.IifName = "lo"
it.Src = netip.PrefixFrom(netip.IPv4Unspecified(), 32)
it.Table = t.options.TableIndex
it.Family = unix.AF_INET
rules = append(rules, it)
for _, address := range t.options.Inet4Address {
it = netlink.NewRule() it = netlink.NewRule()
it.Priority = priority it.Priority = priority
it.IifName = "lo" it.IifName = "lo"
it.Src = netip.PrefixFrom(netip.IPv4Unspecified(), 32) it.Src = address.Masked()
it.Table = t.options.TableIndex it.Table = t.options.TableIndex
it.Family = unix.AF_INET it.Family = unix.AF_INET
rules = append(rules, it) rules = append(rules, it)
for _, address := range t.options.Inet4Address {
it = netlink.NewRule()
it.Priority = priority
it.IifName = "lo"
it.Src = address.Masked()
it.Table = t.options.TableIndex
it.Family = unix.AF_INET
rules = append(rules, it)
}
} }
priority++ priority++
} }
if p6 { if p6 {
if !t.options.StrictRoute { for _, address := range t.options.Inet6Address {
for _, address := range t.options.Inet6Address {
it = netlink.NewRule()
it.Priority = priority6
it.IifName = "lo"
it.Src = address.Masked()
it.Table = t.options.TableIndex
it.Family = unix.AF_INET6
rules = append(rules, it)
}
priority6++
it = netlink.NewRule() it = netlink.NewRule()
it.Priority = priority6 it.Priority = priority6
it.IifName = "lo" it.IifName = "lo"
it.Src = netip.PrefixFrom(netip.IPv6Unspecified(), 1) it.Src = address.Masked()
it.Goto = nopPriority it.Table = t.options.TableIndex
it.Family = unix.AF_INET6 it.Family = unix.AF_INET6
rules = append(rules, it) rules = append(rules, it)
it = netlink.NewRule()
it.Priority = priority6
it.IifName = "lo"
it.Src = netip.PrefixFrom(netip.AddrFrom16([16]byte{0: 128}), 1)
it.Goto = nopPriority
it.Family = unix.AF_INET6
rules = append(rules, it)
priority6++
} }
priority6++
it = netlink.NewRule()
it.Priority = priority6
it.IifName = t.options.Name
it.Goto = nopPriority
it.Family = unix.AF_INET6
rules = append(rules, it)
it = netlink.NewRule()
it.Priority = priority6
it.IifName = "lo"
it.Src = netip.PrefixFrom(netip.IPv6Unspecified(), 1)
it.Goto = nopPriority
it.Family = unix.AF_INET6
rules = append(rules, it)
it = netlink.NewRule()
it.Priority = priority6
it.IifName = "lo"
it.Src = netip.PrefixFrom(netip.AddrFrom16([16]byte{0: 128}), 1)
it.Goto = nopPriority
it.Family = unix.AF_INET6
rules = append(rules, it)
priority6++
it = netlink.NewRule() it = netlink.NewRule()
it.Priority = priority6 it.Priority = priority6