wireguard.go 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. package logic
  2. import (
  3. "github.com/gravitl/netmaker/models"
  4. )
  5. // IfaceDelta - checks if the new node causes an interface change
  6. func IfaceDelta(currentNode *models.Node, newNode *models.Node) bool {
  7. // single comparison statements
  8. if newNode.Address.String() != currentNode.Address.String() ||
  9. newNode.Address6.String() != currentNode.Address6.String() ||
  10. newNode.IsEgressGateway != currentNode.IsEgressGateway ||
  11. newNode.IsIngressGateway != currentNode.IsIngressGateway ||
  12. newNode.IsRelay != currentNode.IsRelay ||
  13. newNode.PersistentKeepalive != currentNode.PersistentKeepalive ||
  14. newNode.DNSOn != currentNode.DNSOn ||
  15. newNode.Connected != currentNode.Connected {
  16. return true
  17. }
  18. // multi-comparison statements
  19. if newNode.IsEgressGateway {
  20. if len(currentNode.EgressGatewayRanges) != len(newNode.EgressGatewayRanges) {
  21. return true
  22. }
  23. for _, address := range newNode.EgressGatewayRanges {
  24. if !StringSliceContains(currentNode.EgressGatewayRanges, address) {
  25. return true
  26. }
  27. }
  28. }
  29. if newNode.IsRelay {
  30. if len(currentNode.RelayAddrs) != len(newNode.RelayAddrs) {
  31. return true
  32. }
  33. for _, address := range newNode.RelayAddrs {
  34. if !StringSliceContains(currentNode.RelayAddrs, address) {
  35. return true
  36. }
  37. }
  38. }
  39. return false
  40. }
  41. // == Private Functions ==