|
@@ -635,6 +635,63 @@ func IsNodeInComms(node *models.Node) bool {
|
|
|
return node.Network == servercfg.GetCommsID() && node.IsServer != "yes"
|
|
|
}
|
|
|
|
|
|
+// IfaceDelta - checks if the new node causes an interface change
|
|
|
+func IfaceDelta(currentNode *models.Node, newNode *models.Node) bool {
|
|
|
+ // single comparison statements
|
|
|
+ if newNode.Endpoint != currentNode.Endpoint ||
|
|
|
+ newNode.LocalAddress != currentNode.LocalAddress ||
|
|
|
+ newNode.PublicKey != currentNode.PublicKey ||
|
|
|
+ newNode.Address != currentNode.Address ||
|
|
|
+ newNode.IsEgressGateway != currentNode.IsEgressGateway ||
|
|
|
+ newNode.IsIngressGateway != currentNode.IsIngressGateway ||
|
|
|
+ newNode.IsRelay != currentNode.IsRelay ||
|
|
|
+ newNode.UDPHolePunch != currentNode.UDPHolePunch ||
|
|
|
+ newNode.IsPending != currentNode.IsPending ||
|
|
|
+ newNode.ListenPort != currentNode.ListenPort ||
|
|
|
+ newNode.MTU != currentNode.MTU ||
|
|
|
+ newNode.PersistentKeepalive != currentNode.PersistentKeepalive ||
|
|
|
+ newNode.DNSOn != currentNode.DNSOn ||
|
|
|
+ len(newNode.AllowedIPs) != len(currentNode.AllowedIPs) {
|
|
|
+ return true
|
|
|
+ }
|
|
|
+
|
|
|
+ // multi-comparison statements
|
|
|
+ if newNode.IsDualStack == "yes" {
|
|
|
+ if newNode.Address6 != currentNode.Address6 {
|
|
|
+ return true
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ if newNode.IsEgressGateway == "yes" {
|
|
|
+ if len(currentNode.EgressGatewayRanges) != len(newNode.EgressGatewayRanges) {
|
|
|
+ return true
|
|
|
+ }
|
|
|
+ for _, address := range newNode.EgressGatewayRanges {
|
|
|
+ if !StringSliceContains(currentNode.EgressGatewayRanges, address) {
|
|
|
+ return true
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ if newNode.IsRelay == "yes" {
|
|
|
+ if len(currentNode.RelayAddrs) != len(newNode.RelayAddrs) {
|
|
|
+ return true
|
|
|
+ }
|
|
|
+ for _, address := range newNode.RelayAddrs {
|
|
|
+ if !StringSliceContains(currentNode.RelayAddrs, address) {
|
|
|
+ return true
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ for _, address := range newNode.AllowedIPs {
|
|
|
+ if !StringSliceContains(currentNode.AllowedIPs, address) {
|
|
|
+ return true
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return false
|
|
|
+}
|
|
|
+
|
|
|
// validateServer - make sure servers dont change port or address
|
|
|
func validateServer(currentNode, newNode *models.Node) bool {
|
|
|
return (newNode.Address == currentNode.Address &&
|