relay.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. package logic
  2. import (
  3. "encoding/json"
  4. "errors"
  5. "time"
  6. "github.com/gravitl/netmaker/database"
  7. "github.com/gravitl/netmaker/logger"
  8. "github.com/gravitl/netmaker/models"
  9. )
  10. // CreateRelay - creates a relay
  11. func CreateRelay(relay models.RelayRequest) (models.Node, error) {
  12. node, err := GetNodeByID(relay.NodeID)
  13. if err != nil {
  14. return models.Node{}, err
  15. }
  16. err = ValidateRelay(relay)
  17. if err != nil {
  18. return models.Node{}, err
  19. }
  20. node.IsRelay = "yes"
  21. node.RelayAddrs = relay.RelayAddrs
  22. node.SetLastModified()
  23. node.PullChanges = "yes"
  24. nodeData, err := json.Marshal(&node)
  25. if err != nil {
  26. return node, err
  27. }
  28. if err = database.Insert(node.ID, string(nodeData), database.NODES_TABLE_NAME); err != nil {
  29. return models.Node{}, err
  30. }
  31. err = SetRelayedNodes("yes", node.Network, node.RelayAddrs)
  32. if err != nil {
  33. return node, err
  34. }
  35. if err = NetworkNodesUpdatePullChanges(node.Network); err != nil {
  36. return models.Node{}, err
  37. }
  38. return node, nil
  39. }
  40. // SetRelayedNodes- set relayed nodes
  41. func SetRelayedNodes(yesOrno string, networkName string, addrs []string) error {
  42. collections, err := database.FetchRecords(database.NODES_TABLE_NAME)
  43. if err != nil {
  44. return err
  45. }
  46. network, err := GetNetworkSettings(networkName)
  47. if err != nil {
  48. return err
  49. }
  50. for _, value := range collections {
  51. var node models.Node
  52. err := json.Unmarshal([]byte(value), &node)
  53. if err != nil {
  54. return err
  55. }
  56. if node.Network == networkName {
  57. for _, addr := range addrs {
  58. if addr == node.Address || addr == node.Address6 {
  59. node.IsRelayed = yesOrno
  60. if yesOrno == "yes" {
  61. node.UDPHolePunch = "no"
  62. } else {
  63. node.UDPHolePunch = network.DefaultUDPHolePunch
  64. }
  65. data, err := json.Marshal(&node)
  66. if err != nil {
  67. return err
  68. }
  69. database.Insert(node.ID, string(data), database.NODES_TABLE_NAME)
  70. }
  71. }
  72. }
  73. }
  74. return nil
  75. }
  76. // ValidateRelay - checks if relay is valid
  77. func ValidateRelay(relay models.RelayRequest) error {
  78. var err error
  79. //isIp := functions.IsIpCIDR(gateway.RangeString)
  80. empty := len(relay.RelayAddrs) == 0
  81. if empty {
  82. err = errors.New("IP Ranges Cannot Be Empty")
  83. }
  84. return err
  85. }
  86. // UpdateRelay - updates a relay
  87. func UpdateRelay(network string, oldAddrs []string, newAddrs []string) {
  88. time.Sleep(time.Second / 4)
  89. err := SetRelayedNodes("no", network, oldAddrs)
  90. if err != nil {
  91. logger.Log(1, err.Error())
  92. }
  93. err = SetRelayedNodes("yes", network, newAddrs)
  94. if err != nil {
  95. logger.Log(1, err.Error())
  96. }
  97. }
  98. // DeleteRelay - deletes a relay
  99. func DeleteRelay(network, nodeid string) (models.Node, error) {
  100. node, err := GetNodeByID(nodeid)
  101. if err != nil {
  102. return models.Node{}, err
  103. }
  104. err = SetRelayedNodes("no", node.Network, node.RelayAddrs)
  105. if err != nil {
  106. return node, err
  107. }
  108. node.IsRelay = "no"
  109. node.RelayAddrs = []string{}
  110. node.SetLastModified()
  111. node.PullChanges = "yes"
  112. data, err := json.Marshal(&node)
  113. if err != nil {
  114. return models.Node{}, err
  115. }
  116. if err = database.Insert(nodeid, string(data), database.NODES_TABLE_NAME); err != nil {
  117. return models.Node{}, err
  118. }
  119. if err = NetworkNodesUpdatePullChanges(network); err != nil {
  120. return models.Node{}, err
  121. }
  122. return node, nil
  123. }