Utku Ozdemir f55f5df739
feat: move dashboard package & run it in tty2
Move dashboard package into a common location where both Talos and talosctl can use it.

Add support for overriding stdin, stdout, stderr and ctt in process runner.

Create a dashboard service which runs the dashboard on /dev/tty2.

Redirect kernel messages to tty1 and switch to tty2 after starting the dashboard on it.

Related to siderolabs/talos#6841, siderolabs/talos#4791.

Signed-off-by: Utku Ozdemir <utku.ozdemir@siderolabs.com>
2023-02-28 12:00:25 +01:00

77 lines
2.0 KiB
Go

// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at http://mozilla.org/MPL/2.0/.
package components
import (
ui "github.com/gizak/termui/v3"
"github.com/gizak/termui/v3/widgets"
"github.com/siderolabs/talos/internal/pkg/dashboard/data"
)
// BaseSparklineGroup represents the widget with some sparklines.
type BaseSparklineGroup struct {
widgets.SparklineGroup
dataLabels []string
}
// NewBaseSparklineGroup initializes BaseSparklineGroup.
func NewBaseSparklineGroup(title string, labels, dataLabels []string) *BaseSparklineGroup {
sparklines := make([]*widgets.Sparkline, len(labels))
for i := range sparklines {
sparklines[i] = widgets.NewSparkline()
sparklines[i].Title = labels[i]
sparklines[i].Data = []float64{0, 0}
sparklines[i].LineColor = ui.Theme.Plot.Lines[i]
}
widget := &BaseSparklineGroup{
SparklineGroup: *widgets.NewSparklineGroup(sparklines...),
dataLabels: dataLabels,
}
widget.Border = false
widget.Title = title
return widget
}
// Update implements the DataWidget interface.
func (widget *BaseSparklineGroup) Update(node string, data *data.Data) {
nodeData := data.Nodes[node]
if nodeData == nil {
for i := range widget.Sparklines {
widget.Sparklines[i].Data = []float64{0, 0}
}
return
}
width := widget.Inner.Dx()
for i, name := range widget.dataLabels {
series := nodeData.Series[name]
if len(series) < width {
width = len(series)
}
widget.Sparklines[i].Data = series[len(series)-width:]
}
}
// NewNetSparkline creates network sparkline.
func NewNetSparkline() *BaseSparklineGroup {
return NewBaseSparklineGroup("NET", []string{"RX", "TX"}, []string{"netrxbytes", "nettxbytes"})
}
// NewDiskSparkline creates disk sparkline.
func NewDiskSparkline() *BaseSparklineGroup {
return NewBaseSparklineGroup("DISK", []string{"READ", "WRITE"}, []string{"diskrdsectors", "diskwrsectors"})
}