mirror of
https://gitclone.com/github.com/MetaCubeX/Clash.Meta
synced 2024-11-15 21:51:23 +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
|
|
}
|