relay.go 4.6 KB

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