metrics.go 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. package ee_controllers
  2. import (
  3. "encoding/json"
  4. "net/http"
  5. "github.com/gorilla/mux"
  6. "github.com/gravitl/netmaker/logger"
  7. "github.com/gravitl/netmaker/logic"
  8. "github.com/gravitl/netmaker/models"
  9. )
  10. // MetricHandlers - How we handle EE Metrics
  11. func MetricHandlers(r *mux.Router) {
  12. r.HandleFunc("/api/metrics/{network}/{nodeid}", logic.SecurityCheck(true, http.HandlerFunc(getNodeMetrics))).Methods("GET")
  13. r.HandleFunc("/api/metrics/{network}", logic.SecurityCheck(true, http.HandlerFunc(getNetworkNodesMetrics))).Methods("GET")
  14. r.HandleFunc("/api/metrics", logic.SecurityCheck(true, http.HandlerFunc(getAllMetrics))).Methods("GET")
  15. }
  16. // get the metrics of a given node
  17. func getNodeMetrics(w http.ResponseWriter, r *http.Request) {
  18. // set header.
  19. w.Header().Set("Content-Type", "application/json")
  20. var params = mux.Vars(r)
  21. nodeID := params["nodeid"]
  22. logger.Log(1, r.Header.Get("user"), "requested fetching metrics for node", nodeID, "on network", params["network"])
  23. metrics, err := logic.GetMetrics(nodeID)
  24. if err != nil {
  25. logger.Log(1, r.Header.Get("user"), "failed to fetch metrics of node", nodeID, err.Error())
  26. logic.ReturnErrorResponse(w, r, logic.FormatError(err, "internal"))
  27. return
  28. }
  29. logger.Log(1, r.Header.Get("user"), "fetched metrics for node", params["nodeid"])
  30. w.WriteHeader(http.StatusOK)
  31. json.NewEncoder(w).Encode(metrics)
  32. }
  33. // get the metrics of all nodes in given network
  34. func getNetworkNodesMetrics(w http.ResponseWriter, r *http.Request) {
  35. // set header.
  36. w.Header().Set("Content-Type", "application/json")
  37. var params = mux.Vars(r)
  38. network := params["network"]
  39. logger.Log(1, r.Header.Get("user"), "requested fetching network node metrics on network", network)
  40. networkNodes, err := logic.GetNetworkNodes(network)
  41. if err != nil {
  42. logger.Log(1, r.Header.Get("user"), "failed to fetch metrics of all nodes in network", network, err.Error())
  43. logic.ReturnErrorResponse(w, r, logic.FormatError(err, "internal"))
  44. return
  45. }
  46. networkMetrics := models.NetworkMetrics{}
  47. networkMetrics.Nodes = make(models.MetricsMap)
  48. for i := range networkNodes {
  49. id := networkNodes[i].ID
  50. metrics, err := logic.GetMetrics(id)
  51. if err != nil {
  52. logger.Log(1, r.Header.Get("user"), "failed to append metrics of node", id, "during network metrics fetch", err.Error())
  53. continue
  54. }
  55. networkMetrics.Nodes[id] = *metrics
  56. }
  57. logger.Log(1, r.Header.Get("user"), "fetched metrics for network", network)
  58. w.WriteHeader(http.StatusOK)
  59. json.NewEncoder(w).Encode(networkMetrics)
  60. }
  61. // get Metrics of all nodes on server, lots of data
  62. func getAllMetrics(w http.ResponseWriter, r *http.Request) {
  63. w.Header().Set("Content-Type", "application/json")
  64. logger.Log(1, r.Header.Get("user"), "requested fetching all metrics")
  65. allNodes, err := logic.GetAllNodes()
  66. if err != nil {
  67. logger.Log(1, r.Header.Get("user"), "failed to fetch metrics of all nodes on server", err.Error())
  68. logic.ReturnErrorResponse(w, r, logic.FormatError(err, "internal"))
  69. return
  70. }
  71. networkMetrics := models.NetworkMetrics{}
  72. networkMetrics.Nodes = make(models.MetricsMap)
  73. for i := range allNodes {
  74. id := allNodes[i].ID
  75. metrics, err := logic.GetMetrics(id)
  76. if err != nil {
  77. logger.Log(1, r.Header.Get("user"), "failed to append metrics of node", id, "during all nodes metrics fetch", err.Error())
  78. continue
  79. }
  80. networkMetrics.Nodes[id] = *metrics
  81. }
  82. logger.Log(1, r.Header.Get("user"), "fetched metrics for all nodes on server")
  83. w.WriteHeader(http.StatusOK)
  84. json.NewEncoder(w).Encode(networkMetrics)
  85. }