dns.go 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219
  1. package controller
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "net/http"
  6. "github.com/gorilla/mux"
  7. "github.com/gravitl/netmaker/database"
  8. "github.com/gravitl/netmaker/logger"
  9. "github.com/gravitl/netmaker/logic"
  10. "github.com/gravitl/netmaker/models"
  11. "github.com/gravitl/netmaker/mq"
  12. "github.com/gravitl/netmaker/servercfg"
  13. )
  14. func dnsHandlers(r *mux.Router) {
  15. r.HandleFunc("/api/dns", securityCheck(true, http.HandlerFunc(getAllDNS))).Methods("GET")
  16. r.HandleFunc("/api/dns/adm/{network}/nodes", securityCheck(false, http.HandlerFunc(getNodeDNS))).Methods("GET")
  17. r.HandleFunc("/api/dns/adm/{network}/custom", securityCheck(false, http.HandlerFunc(getCustomDNS))).Methods("GET")
  18. r.HandleFunc("/api/dns/adm/{network}", securityCheck(false, http.HandlerFunc(getDNS))).Methods("GET")
  19. r.HandleFunc("/api/dns/{network}", securityCheck(false, http.HandlerFunc(createDNS))).Methods("POST")
  20. r.HandleFunc("/api/dns/adm/pushdns", securityCheck(false, http.HandlerFunc(pushDNS))).Methods("POST")
  21. r.HandleFunc("/api/dns/{network}/{domain}", securityCheck(false, http.HandlerFunc(deleteDNS))).Methods("DELETE")
  22. }
  23. //Gets node DNS entries associated with a network
  24. func getNodeDNS(w http.ResponseWriter, r *http.Request) {
  25. w.Header().Set("Content-Type", "application/json")
  26. var dns []models.DNSEntry
  27. var params = mux.Vars(r)
  28. network := params["network"]
  29. dns, err := logic.GetNodeDNS(network)
  30. if err != nil {
  31. logger.Log(0, r.Header.Get("user"),
  32. fmt.Sprintf("failed to get node DNS entries for network [%s]: %v", network, err))
  33. returnErrorResponse(w, r, formatError(err, "internal"))
  34. return
  35. }
  36. w.WriteHeader(http.StatusOK)
  37. json.NewEncoder(w).Encode(dns)
  38. }
  39. //Gets all DNS entries.
  40. func getAllDNS(w http.ResponseWriter, r *http.Request) {
  41. w.Header().Set("Content-Type", "application/json")
  42. dns, err := logic.GetAllDNS()
  43. if err != nil {
  44. logger.Log(0, r.Header.Get("user"), "failed to get all DNS entries: ", err.Error())
  45. returnErrorResponse(w, r, formatError(err, "internal"))
  46. return
  47. }
  48. w.WriteHeader(http.StatusOK)
  49. json.NewEncoder(w).Encode(dns)
  50. }
  51. //Gets custom DNS entries associated with a network
  52. func getCustomDNS(w http.ResponseWriter, r *http.Request) {
  53. w.Header().Set("Content-Type", "application/json")
  54. var dns []models.DNSEntry
  55. var params = mux.Vars(r)
  56. network := params["network"]
  57. dns, err := logic.GetCustomDNS(network)
  58. if err != nil {
  59. logger.Log(0, r.Header.Get("user"),
  60. fmt.Sprintf("failed to get custom DNS entries for network [%s]: %v", network, err.Error()))
  61. returnErrorResponse(w, r, formatError(err, "internal"))
  62. return
  63. }
  64. w.WriteHeader(http.StatusOK)
  65. json.NewEncoder(w).Encode(dns)
  66. }
  67. // Gets all DNS entries associated with the network
  68. func getDNS(w http.ResponseWriter, r *http.Request) {
  69. w.Header().Set("Content-Type", "application/json")
  70. var dns []models.DNSEntry
  71. var params = mux.Vars(r)
  72. network := params["network"]
  73. dns, err := logic.GetDNS(network)
  74. if err != nil {
  75. logger.Log(0, r.Header.Get("user"),
  76. fmt.Sprintf("failed to get all DNS entries for network [%s]: %v", network, err.Error()))
  77. returnErrorResponse(w, r, formatError(err, "internal"))
  78. return
  79. }
  80. w.WriteHeader(http.StatusOK)
  81. json.NewEncoder(w).Encode(dns)
  82. }
  83. func createDNS(w http.ResponseWriter, r *http.Request) {
  84. w.Header().Set("Content-Type", "application/json")
  85. var entry models.DNSEntry
  86. var params = mux.Vars(r)
  87. _ = json.NewDecoder(r.Body).Decode(&entry)
  88. entry.Network = params["network"]
  89. err := logic.ValidateDNSCreate(entry)
  90. if err != nil {
  91. logger.Log(0, r.Header.Get("user"),
  92. fmt.Sprintf("invalid DNS entry %+v: %v", entry, err))
  93. returnErrorResponse(w, r, formatError(err, "badrequest"))
  94. return
  95. }
  96. entry, err = CreateDNS(entry)
  97. if err != nil {
  98. logger.Log(0, r.Header.Get("user"),
  99. fmt.Sprintf("Failed to create DNS entry %+v: %v", entry, err))
  100. returnErrorResponse(w, r, formatError(err, "internal"))
  101. return
  102. }
  103. err = logic.SetDNS()
  104. if err != nil {
  105. logger.Log(0, r.Header.Get("user"),
  106. fmt.Sprintf("Failed to set DNS entries on file: %v", err))
  107. returnErrorResponse(w, r, formatError(err, "internal"))
  108. return
  109. }
  110. logger.Log(1, "new DNS record added:", entry.Name)
  111. if servercfg.IsMessageQueueBackend() {
  112. serverNode, err := logic.GetNetworkServerLocal(entry.Network)
  113. if err != nil {
  114. logger.Log(1, "failed to find server node after DNS update on", entry.Network)
  115. } else {
  116. if err = logic.ServerUpdate(&serverNode, false); err != nil {
  117. logger.Log(1, "failed to update server node after DNS update on", entry.Network)
  118. }
  119. if err = mq.PublishPeerUpdate(&serverNode, false); err != nil {
  120. logger.Log(0, "failed to publish peer update after ACL update on", entry.Network)
  121. }
  122. }
  123. }
  124. logger.Log(2, r.Header.Get("user"),
  125. fmt.Sprintf("DNS entry is set: %+v", entry))
  126. w.WriteHeader(http.StatusOK)
  127. json.NewEncoder(w).Encode(entry)
  128. }
  129. func deleteDNS(w http.ResponseWriter, r *http.Request) {
  130. // Set header
  131. w.Header().Set("Content-Type", "application/json")
  132. // get params
  133. var params = mux.Vars(r)
  134. entrytext := params["domain"] + "." + params["network"]
  135. err := logic.DeleteDNS(params["domain"], params["network"])
  136. if err != nil {
  137. logger.Log(0, "failed to delete dns entry: ", entrytext)
  138. returnErrorResponse(w, r, formatError(err, "internal"))
  139. return
  140. }
  141. logger.Log(1, "deleted dns entry: ", entrytext)
  142. err = logic.SetDNS()
  143. if err != nil {
  144. logger.Log(0, r.Header.Get("user"),
  145. fmt.Sprintf("Failed to set DNS entries on file: %v", err))
  146. returnErrorResponse(w, r, formatError(err, "internal"))
  147. return
  148. }
  149. json.NewEncoder(w).Encode(entrytext + " deleted.")
  150. }
  151. // CreateDNS - creates a DNS entry
  152. func CreateDNS(entry models.DNSEntry) (models.DNSEntry, error) {
  153. data, err := json.Marshal(&entry)
  154. if err != nil {
  155. return models.DNSEntry{}, err
  156. }
  157. key, err := logic.GetRecordKey(entry.Name, entry.Network)
  158. if err != nil {
  159. return models.DNSEntry{}, err
  160. }
  161. err = database.Insert(key, string(data), database.DNS_TABLE_NAME)
  162. return entry, err
  163. }
  164. // GetDNSEntry - gets a DNS entry
  165. func GetDNSEntry(domain string, network string) (models.DNSEntry, error) {
  166. var entry models.DNSEntry
  167. key, err := logic.GetRecordKey(domain, network)
  168. if err != nil {
  169. return entry, err
  170. }
  171. record, err := database.FetchRecord(database.DNS_TABLE_NAME, key)
  172. if err != nil {
  173. return entry, err
  174. }
  175. err = json.Unmarshal([]byte(record), &entry)
  176. return entry, err
  177. }
  178. func pushDNS(w http.ResponseWriter, r *http.Request) {
  179. // Set header
  180. w.Header().Set("Content-Type", "application/json")
  181. err := logic.SetDNS()
  182. if err != nil {
  183. logger.Log(0, r.Header.Get("user"),
  184. fmt.Sprintf("Failed to set DNS entries on file: %v", err))
  185. returnErrorResponse(w, r, formatError(err, "internal"))
  186. return
  187. }
  188. logger.Log(1, r.Header.Get("user"), "pushed DNS updates to nameserver")
  189. json.NewEncoder(w).Encode("DNS Pushed to CoreDNS")
  190. }