relay.go 4.6 KB

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