relay.go 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. package controller
  2. import (
  3. "encoding/json"
  4. "errors"
  5. "net/http"
  6. "time"
  7. "github.com/gorilla/mux"
  8. "github.com/gravitl/netmaker/database"
  9. "github.com/gravitl/netmaker/functions"
  10. "github.com/gravitl/netmaker/logger"
  11. "github.com/gravitl/netmaker/logic"
  12. "github.com/gravitl/netmaker/models"
  13. )
  14. func createRelay(w http.ResponseWriter, r *http.Request) {
  15. var relay models.RelayRequest
  16. var params = mux.Vars(r)
  17. w.Header().Set("Content-Type", "application/json")
  18. err := json.NewDecoder(r.Body).Decode(&relay)
  19. if err != nil {
  20. returnErrorResponse(w, r, formatError(err, "internal"))
  21. return
  22. }
  23. relay.NetID = params["network"]
  24. relay.NodeID = params["macaddress"]
  25. node, err := CreateRelay(relay)
  26. if err != nil {
  27. returnErrorResponse(w, r, formatError(err, "internal"))
  28. return
  29. }
  30. logger.Log(1, r.Header.Get("user"), "created relay on node", relay.NodeID, "on network", relay.NetID)
  31. w.WriteHeader(http.StatusOK)
  32. json.NewEncoder(w).Encode(node)
  33. }
  34. // CreateRelay - creates a relay
  35. func CreateRelay(relay models.RelayRequest) (models.Node, error) {
  36. node, err := logic.GetNodeByMacAddress(relay.NetID, relay.NodeID)
  37. if node.OS == "macos" { // add in darwin later
  38. return models.Node{}, errors.New(node.OS + " is unsupported for relay")
  39. }
  40. if err != nil {
  41. return models.Node{}, err
  42. }
  43. err = ValidateRelay(relay)
  44. if err != nil {
  45. return models.Node{}, err
  46. }
  47. node.IsRelay = "yes"
  48. node.RelayAddrs = relay.RelayAddrs
  49. key, err := logic.GetRecordKey(relay.NodeID, relay.NetID)
  50. if err != nil {
  51. return node, err
  52. }
  53. node.SetLastModified()
  54. node.PullChanges = "yes"
  55. nodeData, err := json.Marshal(&node)
  56. if err != nil {
  57. return node, err
  58. }
  59. if err = database.Insert(key, string(nodeData), database.NODES_TABLE_NAME); err != nil {
  60. return models.Node{}, err
  61. }
  62. err = SetRelayedNodes("yes", node.Network, node.RelayAddrs)
  63. if err != nil {
  64. return node, err
  65. }
  66. if err = functions.NetworkNodesUpdatePullChanges(node.Network); err != nil {
  67. return models.Node{}, err
  68. }
  69. return node, nil
  70. }
  71. func deleteRelay(w http.ResponseWriter, r *http.Request) {
  72. w.Header().Set("Content-Type", "application/json")
  73. var params = mux.Vars(r)
  74. nodeMac := params["macaddress"]
  75. netid := params["network"]
  76. node, err := DeleteRelay(netid, nodeMac)
  77. if err != nil {
  78. returnErrorResponse(w, r, formatError(err, "internal"))
  79. return
  80. }
  81. logger.Log(1, r.Header.Get("user"), "deleted egress gateway", nodeMac, "on network", netid)
  82. w.WriteHeader(http.StatusOK)
  83. json.NewEncoder(w).Encode(node)
  84. }
  85. // SetRelayedNodes- set relayed nodes
  86. func SetRelayedNodes(yesOrno string, networkName string, addrs []string) error {
  87. collections, err := database.FetchRecords(database.NODES_TABLE_NAME)
  88. if err != nil {
  89. return err
  90. }
  91. for _, value := range collections {
  92. var node models.Node
  93. err := json.Unmarshal([]byte(value), &node)
  94. if err != nil {
  95. return err
  96. }
  97. if node.Network == networkName {
  98. for _, addr := range addrs {
  99. if addr == node.Address || addr == node.Address6 {
  100. node.IsRelayed = yesOrno
  101. data, err := json.Marshal(&node)
  102. if err != nil {
  103. return err
  104. }
  105. node.SetID()
  106. database.Insert(node.ID, string(data), database.NODES_TABLE_NAME)
  107. }
  108. }
  109. }
  110. }
  111. return nil
  112. }
  113. // ValidateRelay - checks if relay is valid
  114. func ValidateRelay(relay models.RelayRequest) error {
  115. var err error
  116. //isIp := functions.IsIpCIDR(gateway.RangeString)
  117. empty := len(relay.RelayAddrs) == 0
  118. if empty {
  119. err = errors.New("IP Ranges Cannot Be Empty")
  120. }
  121. return err
  122. }
  123. // UpdateRelay - updates a relay
  124. func UpdateRelay(network string, oldAddrs []string, newAddrs []string) {
  125. time.Sleep(time.Second / 4)
  126. err := SetRelayedNodes("no", network, oldAddrs)
  127. if err != nil {
  128. logger.Log(1, err.Error())
  129. }
  130. err = SetRelayedNodes("yes", network, newAddrs)
  131. if err != nil {
  132. logger.Log(1, err.Error())
  133. }
  134. }
  135. // DeleteRelay - deletes a relay
  136. func DeleteRelay(network, macaddress string) (models.Node, error) {
  137. node, err := logic.GetNodeByMacAddress(network, macaddress)
  138. if err != nil {
  139. return models.Node{}, err
  140. }
  141. err = SetRelayedNodes("no", node.Network, node.RelayAddrs)
  142. if err != nil {
  143. return node, err
  144. }
  145. node.IsRelay = "no"
  146. node.RelayAddrs = []string{}
  147. node.SetLastModified()
  148. node.PullChanges = "yes"
  149. key, err := logic.GetRecordKey(node.MacAddress, node.Network)
  150. if err != nil {
  151. return models.Node{}, err
  152. }
  153. data, err := json.Marshal(&node)
  154. if err != nil {
  155. return models.Node{}, err
  156. }
  157. if err = database.Insert(key, string(data), database.NODES_TABLE_NAME); err != nil {
  158. return models.Node{}, err
  159. }
  160. if err = functions.NetworkNodesUpdatePullChanges(network); err != nil {
  161. return models.Node{}, err
  162. }
  163. return node, nil
  164. }