package resource import ( "github.com/derailed/k9s/internal/k8s" "github.com/rs/zerolog" v1 "k8s.io/api/core/v1" mv1beta1 "k8s.io/metrics/pkg/apis/metrics/v1beta1" ) type ( // ClusterMeta represents metadata about a Kubernetes cluster. ClusterMeta interface { Connection Version() (string, error) ContextName() string ClusterName() string UserName() string GetNodes() ([]v1.Node, error) } // MetricsServer gather metrics information from pods and nodes. MetricsServer interface { MetricsService ClusterLoad([]v1.Node, []mv1beta1.NodeMetrics) k8s.ClusterMetrics NodesMetrics([]v1.Node, []mv1beta1.NodeMetrics, k8s.NodesMetrics) PodsMetrics([]mv1beta1.PodMetrics, k8s.PodsMetrics) } // MetricsService calls the metrics server for metrics info. MetricsService interface { HasMetrics() bool FetchNodesMetrics() ([]mv1beta1.NodeMetrics, error) FetchPodsMetrics(ns string) ([]mv1beta1.PodMetrics, error) } // Cluster represents a kubernetes resource. Cluster struct { api ClusterMeta mx MetricsServer } ) // NewCluster returns a new cluster info resource. func NewCluster(c Connection, log *zerolog.Logger, mx MetricsServer) *Cluster { return NewClusterWithArgs(k8s.NewCluster(c, log), mx) } // NewClusterWithArgs for tests only! func NewClusterWithArgs(ci ClusterMeta, mx MetricsServer) *Cluster { return &Cluster{api: ci, mx: mx} } // Version returns the current K8s cluster version. func (c *Cluster) Version() string { info, err := c.api.Version() if err != nil { return "n/a" } return info } // ContextName returns the context name. func (c *Cluster) ContextName() string { return c.api.ContextName() } // ClusterName returns the cluster name. func (c *Cluster) ClusterName() string { return c.api.ClusterName() } // UserName returns the user name. func (c *Cluster) UserName() string { return c.api.UserName() } // Metrics gathers node level metrics and compute utilization percentages. func (c *Cluster) Metrics(nodes []v1.Node, nmx []mv1beta1.NodeMetrics) k8s.ClusterMetrics { return c.mx.ClusterLoad(nodes, nmx) } // FetchNodesMetrics fetch all nodes metrics. func (c *Cluster) FetchNodesMetrics() ([]mv1beta1.NodeMetrics, error) { return c.mx.FetchNodesMetrics() } // GetNodes fetch all available nodes. func (c *Cluster) GetNodes() ([]v1.Node, error) { return c.api.GetNodes() }