inet_gws.go 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "errors"
  5. "net/http"
  6. "github.com/gorilla/mux"
  7. "github.com/gravitl/netmaker/logger"
  8. "github.com/gravitl/netmaker/logic"
  9. "github.com/gravitl/netmaker/models"
  10. "github.com/gravitl/netmaker/mq"
  11. proLogic "github.com/gravitl/netmaker/pro/logic"
  12. "github.com/gravitl/netmaker/servercfg"
  13. )
  14. // InetHandlers - handlers for internet gw
  15. func InetHandlers(r *mux.Router) {
  16. r.HandleFunc("/api/nodes/{network}/{nodeid}/inet_gw", logic.SecurityCheck(true, http.HandlerFunc(createInternetGw))).
  17. Methods(http.MethodPost)
  18. r.HandleFunc("/api/nodes/{network}/{nodeid}/inet_gw", logic.SecurityCheck(true, http.HandlerFunc(updateInternetGw))).
  19. Methods(http.MethodPut)
  20. r.HandleFunc("/api/nodes/{network}/{nodeid}/inet_gw", logic.SecurityCheck(true, http.HandlerFunc(deleteInternetGw))).
  21. Methods(http.MethodDelete)
  22. }
  23. // @Summary Create an internet gateway
  24. // @Router /api/nodes/{network}/{nodeid}/inet_gw [post]
  25. // @Tags PRO
  26. // @Accept json
  27. // @Param network path string true "Network ID"
  28. // @Param nodeid path string true "Node ID"
  29. // @Param body body models.InetNodeReq true "Internet gateway request"
  30. // @Success 200 {object} models.Node
  31. // @Failure 400 {object} models.ErrorResponse
  32. // @Failure 500 {object} models.ErrorResponse
  33. func createInternetGw(w http.ResponseWriter, r *http.Request) {
  34. var params = mux.Vars(r)
  35. w.Header().Set("Content-Type", "application/json")
  36. nodeid := params["nodeid"]
  37. netid := params["network"]
  38. node, err := logic.ValidateParams(nodeid, netid)
  39. if err != nil {
  40. logic.ReturnErrorResponse(w, r, logic.FormatError(err, "badrequest"))
  41. return
  42. }
  43. if node.IsInternetGateway {
  44. logic.ReturnSuccessResponse(w, r, "node is already acting as internet gateway")
  45. return
  46. }
  47. var request models.InetNodeReq
  48. err = json.NewDecoder(r.Body).Decode(&request)
  49. if err != nil {
  50. logic.ReturnErrorResponse(w, r, logic.FormatError(err, "badrequest"))
  51. return
  52. }
  53. host, err := logic.GetHost(node.HostID.String())
  54. if err != nil {
  55. logic.ReturnErrorResponse(w, r, logic.FormatError(err, "internal"))
  56. return
  57. }
  58. if host.OS != models.OS_Types.Linux {
  59. logic.ReturnErrorResponse(
  60. w,
  61. r,
  62. logic.FormatError(
  63. errors.New("only linux nodes can be made internet gws"),
  64. "badrequest",
  65. ),
  66. )
  67. return
  68. }
  69. err = proLogic.ValidateInetGwReq(node, request, false)
  70. if err != nil {
  71. logic.ReturnErrorResponse(w, r, logic.FormatError(err, "badrequest"))
  72. return
  73. }
  74. proLogic.SetInternetGw(&node, request)
  75. if servercfg.IsPro {
  76. if _, exists := proLogic.FailOverExists(node.Network); exists {
  77. go func() {
  78. proLogic.ResetFailedOverPeer(&node)
  79. mq.PublishPeerUpdate(false)
  80. }()
  81. }
  82. }
  83. if node.IsGw && node.IngressDNS == "" {
  84. node.IngressDNS = "1.1.1.1"
  85. }
  86. err = logic.UpsertNode(&node)
  87. if err != nil {
  88. logic.ReturnErrorResponse(w, r, logic.FormatError(err, "internal"))
  89. return
  90. }
  91. apiNode := node.ConvertToAPINode()
  92. logger.Log(
  93. 1,
  94. r.Header.Get("user"),
  95. "created ingress gateway on node",
  96. nodeid,
  97. "on network",
  98. netid,
  99. )
  100. w.WriteHeader(http.StatusOK)
  101. json.NewEncoder(w).Encode(apiNode)
  102. go mq.PublishPeerUpdate(false)
  103. }
  104. // @Summary Update an internet gateway
  105. // @Router /api/nodes/{network}/{nodeid}/inet_gw [put]
  106. // @Tags PRO
  107. // @Accept json
  108. // @Param network path string true "Network ID"
  109. // @Param nodeid path string true "Node ID"
  110. // @Param body body models.InetNodeReq true "Internet gateway request"
  111. // @Success 200 {object} models.Node
  112. // @Failure 400 {object} models.ErrorResponse
  113. // @Failure 500 {object} models.ErrorResponse
  114. func updateInternetGw(w http.ResponseWriter, r *http.Request) {
  115. var params = mux.Vars(r)
  116. w.Header().Set("Content-Type", "application/json")
  117. nodeid := params["nodeid"]
  118. netid := params["network"]
  119. node, err := logic.ValidateParams(nodeid, netid)
  120. if err != nil {
  121. logic.ReturnErrorResponse(w, r, logic.FormatError(err, "badrequest"))
  122. return
  123. }
  124. var request models.InetNodeReq
  125. err = json.NewDecoder(r.Body).Decode(&request)
  126. if err != nil {
  127. logic.ReturnErrorResponse(w, r, logic.FormatError(err, "badrequest"))
  128. return
  129. }
  130. if !node.IsInternetGateway {
  131. logic.ReturnErrorResponse(
  132. w,
  133. r,
  134. logic.FormatError(errors.New("node is not a internet gw"), "badrequest"),
  135. )
  136. return
  137. }
  138. err = proLogic.ValidateInetGwReq(node, request, true)
  139. if err != nil {
  140. logic.ReturnErrorResponse(w, r, logic.FormatError(err, "badrequest"))
  141. return
  142. }
  143. proLogic.UnsetInternetGw(&node)
  144. proLogic.SetInternetGw(&node, request)
  145. err = logic.UpsertNode(&node)
  146. if err != nil {
  147. logic.ReturnErrorResponse(w, r, logic.FormatError(err, "internal"))
  148. return
  149. }
  150. apiNode := node.ConvertToAPINode()
  151. logger.Log(
  152. 1,
  153. r.Header.Get("user"),
  154. "created ingress gateway on node",
  155. nodeid,
  156. "on network",
  157. netid,
  158. )
  159. w.WriteHeader(http.StatusOK)
  160. json.NewEncoder(w).Encode(apiNode)
  161. go mq.PublishPeerUpdate(false)
  162. }
  163. // @Summary Delete an internet gateway
  164. // @Router /api/nodes/{network}/{nodeid}/inet_gw [delete]
  165. // @Tags PRO
  166. // @Param network path string true "Network ID"
  167. // @Param nodeid path string true "Node ID"
  168. // @Success 200 {object} models.Node
  169. // @Failure 400 {object} models.ErrorResponse
  170. // @Failure 500 {object} models.ErrorResponse
  171. func deleteInternetGw(w http.ResponseWriter, r *http.Request) {
  172. var params = mux.Vars(r)
  173. w.Header().Set("Content-Type", "application/json")
  174. nodeid := params["nodeid"]
  175. netid := params["network"]
  176. node, err := logic.ValidateParams(nodeid, netid)
  177. if err != nil {
  178. logic.ReturnErrorResponse(w, r, logic.FormatError(err, "badrequest"))
  179. return
  180. }
  181. proLogic.UnsetInternetGw(&node)
  182. err = logic.UpsertNode(&node)
  183. if err != nil {
  184. logic.ReturnErrorResponse(w, r, logic.FormatError(err, "internal"))
  185. return
  186. }
  187. apiNode := node.ConvertToAPINode()
  188. logger.Log(
  189. 1,
  190. r.Header.Get("user"),
  191. "created ingress gateway on node",
  192. nodeid,
  193. "on network",
  194. netid,
  195. )
  196. w.WriteHeader(http.StatusOK)
  197. json.NewEncoder(w).Encode(apiNode)
  198. go mq.PublishPeerUpdate(false)
  199. }