iface.go 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. package ncutils
  2. import (
  3. "net"
  4. "github.com/gravitl/netmaker/models"
  5. )
  6. func IfaceDelta(currentNode *models.Node, newNode *models.Node) bool {
  7. // single comparison statements
  8. if newNode.Endpoint != currentNode.Endpoint ||
  9. newNode.LocalAddress != currentNode.LocalAddress ||
  10. newNode.PublicKey != currentNode.PublicKey ||
  11. newNode.Address != currentNode.Address ||
  12. newNode.IsEgressGateway != currentNode.IsEgressGateway ||
  13. newNode.IsIngressGateway != currentNode.IsIngressGateway ||
  14. newNode.IsRelay != currentNode.IsRelay ||
  15. newNode.UDPHolePunch != currentNode.UDPHolePunch ||
  16. newNode.IsPending != currentNode.IsPending ||
  17. newNode.PersistentKeepalive != currentNode.PersistentKeepalive ||
  18. len(newNode.ExcludedAddrs) != len(currentNode.ExcludedAddrs) ||
  19. len(newNode.AllowedIPs) != len(currentNode.AllowedIPs) {
  20. return true
  21. }
  22. // multi-comparison statements
  23. if newNode.IsDualStack == "yes" {
  24. if newNode.Address6 != currentNode.Address6 {
  25. return true
  26. }
  27. }
  28. if newNode.IsEgressGateway == "yes" {
  29. if len(currentNode.EgressGatewayRanges) != len(newNode.EgressGatewayRanges) {
  30. return true
  31. }
  32. for _, address := range newNode.EgressGatewayRanges {
  33. if !StringSliceContains(currentNode.EgressGatewayRanges, address) {
  34. return true
  35. }
  36. }
  37. }
  38. if newNode.IsRelay == "yes" {
  39. if len(currentNode.RelayAddrs) != len(newNode.RelayAddrs) {
  40. return true
  41. }
  42. for _, address := range newNode.RelayAddrs {
  43. if !StringSliceContains(currentNode.RelayAddrs, address) {
  44. return true
  45. }
  46. }
  47. }
  48. for _, address := range newNode.AllowedIPs {
  49. if !StringSliceContains(currentNode.AllowedIPs, address) {
  50. return true
  51. }
  52. }
  53. return false
  54. }
  55. // StringSliceContains - sees if a string slice contains a string element
  56. func StringSliceContains(slice []string, item string) bool {
  57. for _, s := range slice {
  58. if s == item {
  59. return true
  60. }
  61. }
  62. return false
  63. }
  64. // IfaceExists - return true if you can find the iface
  65. func IfaceExists(ifacename string) bool {
  66. localnets, err := net.Interfaces()
  67. if err != nil {
  68. return false
  69. }
  70. for _, localnet := range localnets {
  71. if ifacename == localnet.Name {
  72. return true
  73. }
  74. }
  75. return false
  76. }