metrics.go 3.4 KB

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