mirror of
https://github.com/MetaCubeX/mihomo.git
synced 2025-01-06 01:23:38 +08:00
58 lines
1.0 KiB
Go
58 lines
1.0 KiB
Go
package inbound
|
|
|
|
import (
|
|
"net"
|
|
"net/netip"
|
|
|
|
C "github.com/metacubex/mihomo/constant"
|
|
)
|
|
|
|
var lanAllowedIPs []netip.Prefix
|
|
var lanDisAllowedIPs []netip.Prefix
|
|
|
|
func SetAllowedIPs(prefixes []netip.Prefix) {
|
|
lanAllowedIPs = prefixes
|
|
}
|
|
|
|
func SetDisAllowedIPs(prefixes []netip.Prefix) {
|
|
lanDisAllowedIPs = prefixes
|
|
}
|
|
|
|
func AllowedIPs() []netip.Prefix {
|
|
return lanAllowedIPs
|
|
}
|
|
|
|
func DisAllowedIPs() []netip.Prefix {
|
|
return lanDisAllowedIPs
|
|
}
|
|
|
|
func IsRemoteAddrDisAllowed(addr net.Addr) bool {
|
|
m := C.Metadata{}
|
|
if err := m.SetRemoteAddr(addr); err != nil {
|
|
return false
|
|
}
|
|
return isAllowed(m.AddrPort().Addr().Unmap()) && !isDisAllowed(m.AddrPort().Addr().Unmap())
|
|
}
|
|
|
|
func isAllowed(addr netip.Addr) bool {
|
|
if addr.IsValid() {
|
|
for _, prefix := range lanAllowedIPs {
|
|
if prefix.Contains(addr) {
|
|
return true
|
|
}
|
|
}
|
|
}
|
|
return false
|
|
}
|
|
|
|
func isDisAllowed(addr netip.Addr) bool {
|
|
if addr.IsValid() {
|
|
for _, prefix := range lanDisAllowedIPs {
|
|
if prefix.Contains(addr) {
|
|
return true
|
|
}
|
|
}
|
|
}
|
|
return false
|
|
}
|