| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164 | package controllersimport (	"encoding/json"	proLogic "github.com/gravitl/netmaker/pro/logic"	"net/http"	"github.com/gorilla/mux"	"github.com/gravitl/netmaker/database"	"github.com/gravitl/netmaker/logger"	"github.com/gravitl/netmaker/logic"	"github.com/gravitl/netmaker/models")// MetricHandlers - How we handle Pro Metricsfunc MetricHandlers(r *mux.Router) {	r.HandleFunc("/api/metrics/{network}/{nodeid}", logic.SecurityCheck(true, http.HandlerFunc(getNodeMetrics))).Methods(http.MethodGet)	r.HandleFunc("/api/metrics/{network}", logic.SecurityCheck(true, http.HandlerFunc(getNetworkNodesMetrics))).Methods(http.MethodGet)	r.HandleFunc("/api/metrics", logic.SecurityCheck(true, http.HandlerFunc(getAllMetrics))).Methods(http.MethodGet)	r.HandleFunc("/api/metrics-ext/{network}", logic.SecurityCheck(true, http.HandlerFunc(getNetworkExtMetrics))).Methods(http.MethodGet)}// get the metrics of a given nodefunc getNodeMetrics(w http.ResponseWriter, r *http.Request) {	// set header.	w.Header().Set("Content-Type", "application/json")	var params = mux.Vars(r)	nodeID := params["nodeid"]	logger.Log(1, r.Header.Get("user"), "requested fetching metrics for node", nodeID, "on network", params["network"])	metrics, err := logic.GetMetrics(nodeID)	if err != nil {		logger.Log(1, r.Header.Get("user"), "failed to fetch metrics of node", nodeID, err.Error())		logic.ReturnErrorResponse(w, r, logic.FormatError(err, "internal"))		return	}	logger.Log(1, r.Header.Get("user"), "fetched metrics for node", params["nodeid"])	w.WriteHeader(http.StatusOK)	json.NewEncoder(w).Encode(metrics)}// get the metrics of all nodes in given networkfunc getNetworkNodesMetrics(w http.ResponseWriter, r *http.Request) {	// set header.	w.Header().Set("Content-Type", "application/json")	var params = mux.Vars(r)	network := params["network"]	logger.Log(1, r.Header.Get("user"), "requested fetching network node metrics on network", network)	networkNodes, err := logic.GetNetworkNodes(network)	if err != nil {		logger.Log(1, r.Header.Get("user"), "failed to fetch metrics of all nodes in network", network, err.Error())		logic.ReturnErrorResponse(w, r, logic.FormatError(err, "internal"))		return	}	networkMetrics := models.NetworkMetrics{}	networkMetrics.Nodes = make(models.MetricsMap)	for i := range networkNodes {		id := networkNodes[i].ID		metrics, err := proLogic.GetMetrics(id.String())		if err != nil {			logger.Log(1, r.Header.Get("user"), "failed to append metrics of node", id.String(), "during network metrics fetch", err.Error())			continue		}		networkMetrics.Nodes[id.String()] = *metrics	}	logger.Log(1, r.Header.Get("user"), "fetched metrics for network", network)	w.WriteHeader(http.StatusOK)	json.NewEncoder(w).Encode(networkMetrics)}// get the metrics for ext clients on a given networkfunc getNetworkExtMetrics(w http.ResponseWriter, r *http.Request) {	// set header.	w.Header().Set("Content-Type", "application/json")	var params = mux.Vars(r)	network := params["network"]	logger.Log(1, r.Header.Get("user"), "requested fetching external client metrics on network", network)	ingresses, err := proLogic.GetNetworkIngresses(network) // grab all the ingress gateways	if err != nil {		logger.Log(1, r.Header.Get("user"), "failed to fetch metrics of ext clients in network", network, err.Error())		logic.ReturnErrorResponse(w, r, logic.FormatError(err, "internal"))		return	}	clients, err := logic.GetNetworkExtClients(network) // grab all the network ext clients	if err != nil {		if database.IsEmptyRecord(err) {			var metrics struct{}			w.WriteHeader(http.StatusOK)			json.NewEncoder(w).Encode(metrics)			return		}		logger.Log(1, r.Header.Get("user"), "failed to fetch metrics of ext clients in network", network, err.Error())		logic.ReturnErrorResponse(w, r, logic.FormatError(err, "internal"))		return	}	networkMetrics := models.Metrics{}	networkMetrics.Connectivity = make(map[string]models.Metric)	for i := range ingresses {		id := ingresses[i].ID		ingressMetrics, err := proLogic.GetMetrics(id.String())		if err != nil {			logger.Log(1, r.Header.Get("user"), "failed to append external client metrics from ingress node", id.String(), err.Error())			continue		}		if ingressMetrics.Connectivity == nil {			continue		}		for j := range clients {			if clients[j].Network != network {				continue			}			// if metrics for that client have been reported, append them			if len(ingressMetrics.Connectivity[clients[j].ClientID].NodeName) > 0 {				networkMetrics.Connectivity[clients[j].ClientID] = ingressMetrics.Connectivity[clients[j].ClientID]			}		}	}	logger.Log(1, r.Header.Get("user"), "fetched ext client metrics for network", network)	w.WriteHeader(http.StatusOK)	json.NewEncoder(w).Encode(networkMetrics.Connectivity)}// get Metrics of all nodes on server, lots of datafunc getAllMetrics(w http.ResponseWriter, r *http.Request) {	w.Header().Set("Content-Type", "application/json")	logger.Log(1, r.Header.Get("user"), "requested fetching all metrics")	allNodes, err := logic.GetAllNodes()	if err != nil {		logger.Log(1, r.Header.Get("user"), "failed to fetch metrics of all nodes on server", err.Error())		logic.ReturnErrorResponse(w, r, logic.FormatError(err, "internal"))		return	}	networkMetrics := models.NetworkMetrics{}	networkMetrics.Nodes = make(models.MetricsMap)	for i := range allNodes {		id := allNodes[i].ID		metrics, err := proLogic.GetMetrics(id.String())		if err != nil {			logger.Log(1, r.Header.Get("user"), "failed to append metrics of node", id.String(), "during all nodes metrics fetch", err.Error())			continue		}		networkMetrics.Nodes[id.String()] = *metrics	}	logger.Log(1, r.Header.Get("user"), "fetched metrics for all nodes on server")	w.WriteHeader(http.StatusOK)	json.NewEncoder(w).Encode(networkMetrics)}
 |