| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159 | package localimport (	"fmt"	"net"	"strings"	"github.com/gravitl/netmaker/logger"	"github.com/gravitl/netmaker/netclient/ncutils"	"golang.zx2c4.com/wireguard/wgctrl/wgtypes")// TODO handle ipv6 in future// SetPeerRoutes - sets/removes ip routes for each peer on a networkfunc SetPeerRoutes(iface string, oldPeers map[string]bool, newPeers []wgtypes.PeerConfig) {	// get the default route	var hasRoute bool	gwIP, gwIface, err := GetDefaultRoute()	if err != nil {		logger.Log(0, "error getting default route:", err.Error())	}	if gwIP != "" && gwIface != "" && err == nil {		hasRoute = true	}	// traverse through all recieved peers	for _, peer := range newPeers {		for _, allowedIP := range peer.AllowedIPs {			if !oldPeers[allowedIP.String()] {				if err := setRoute(iface, &allowedIP, allowedIP.IP.String()); err != nil {					logger.Log(1, err.Error())				}			} else {				delete(oldPeers, allowedIP.String())			}		}		if peer.Endpoint == nil {			continue		}		if hasRoute && !ncutils.IpIsPrivate(peer.Endpoint.IP) {			ipNet, err := ncutils.GetIPNetFromString(peer.Endpoint.IP.String())			if err != nil {				logger.Log(0, "error parsing ip:", err.Error())			}			SetExplicitRoute(gwIface, &ipNet, gwIP)		}	}	// traverse through all remaining existing peers	for i := range oldPeers {		ip, err := ncutils.GetIPNetFromString(i)		if err != nil {			logger.Log(1, err.Error())		} else {			deleteRoute(iface, &ip, ip.IP.String())		}	}}// SetCurrentPeerRoutes - sets all the current peersfunc SetCurrentPeerRoutes(iface, currentAddr string, peers []wgtypes.PeerConfig) {	// get the default route	var hasRoute bool	gwIP, gwIface, err := GetDefaultRoute()	if err != nil {		logger.Log(0, "error getting default route:", err.Error())	}	if gwIP != "" && gwIface != "" && err == nil {		hasRoute = true	}	// traverse through all recieved peers	for _, peer := range peers {		for _, allowedIP := range peer.AllowedIPs {			setRoute(iface, &allowedIP, currentAddr)		}		if peer.Endpoint == nil {			continue		}		if hasRoute && !ncutils.IpIsPrivate(peer.Endpoint.IP) {			ipNet, err := ncutils.GetIPNetFromString(peer.Endpoint.IP.String())			if err != nil {				logger.Log(0, "error parsing ip:", err.Error())			}			SetExplicitRoute(gwIface, &ipNet, gwIP)		}	}}// FlushPeerRoutes - removes all current peer routesfunc FlushPeerRoutes(iface, currentAddr string, peers []wgtypes.Peer) {	// get the default route	var hasRoute bool	gwIP, gwIface, err := GetDefaultRoute()	if err != nil {		logger.Log(0, "error getting default route:", err.Error())	}	if gwIP != "" && gwIface != "" && err == nil {		hasRoute = true	}	for _, peer := range peers {		for _, allowedIP := range peer.AllowedIPs {			deleteRoute(iface, &allowedIP, currentAddr)		}		if peer.Endpoint == nil {			continue		}		if hasRoute && !ncutils.IpIsPrivate(peer.Endpoint.IP) {			ipNet, err := ncutils.GetIPNetFromString(peer.Endpoint.IP.String())			if err != nil {				logger.Log(0, "error parsing ip:", err.Error())			}			deleteRoute(gwIface, &ipNet, gwIP)		}	}}// SetCIDRRoute - sets the CIDR route, used on join and restartsfunc SetCIDRRoute(iface, currentAddr string, cidr *net.IPNet) {	setCidr(iface, currentAddr, cidr)}// RemoveCIDRRoute - removes a static cidr routefunc RemoveCIDRRoute(iface, currentAddr string, cidr *net.IPNet) {	removeCidr(iface, cidr, currentAddr)}// SetNetmakerDomainRoute - sets explicit route over Gateway for a given DNS namefunc SetNetmakerDomainRoute(domainRaw string) error {	parts := strings.Split(domainRaw, ":")	hostname := parts[0]	var address net.IPNet	gwIP, gwIface, err := GetDefaultRoute()	if err != nil {		return fmt.Errorf("error getting default route: %w", err)	}	ips, err := net.LookupIP(hostname)	if err != nil {		return err	}	for _, ip := range ips {		if ipv4 := ip.To4(); ipv4 != nil {			address, err = ncutils.GetIPNetFromString(ipv4.String())			if err == nil {				break			}		}	}	if err != nil || address.IP == nil {		return fmt.Errorf("address not found")	}	return SetExplicitRoute(gwIface, &address, gwIP)}
 |