134 lines
3.4 KiB
Go
134 lines
3.4 KiB
Go
package cli
|
|
|
|
import (
|
|
"fmt"
|
|
"io"
|
|
"text/tabwriter"
|
|
|
|
"github.com/go-flucky/flucky/pkg/config"
|
|
"github.com/go-flucky/flucky/pkg/types"
|
|
)
|
|
|
|
// GetSensorsByMeasuredValues returns commulated list of sensors by measured values
|
|
func GetSensorIDsByMeasuredValues(measuredValues []*types.MeasuredValue, cnf *config.Configuration) map[string]*types.Sensor {
|
|
sensors := make(map[string]*types.Sensor)
|
|
for _, measuredValue := range measuredValues {
|
|
if _, ok := sensors[measuredValue.SensorID]; !ok {
|
|
sensors[measuredValue.SensorID] = cnf.GetSensorByID(measuredValue.SensorID)
|
|
}
|
|
}
|
|
return sensors
|
|
}
|
|
|
|
// PrintRGBLEDs displays a list with all configured RGBLEDs
|
|
func PrintRGBLEDs(cnf *config.Configuration, w io.Writer) {
|
|
|
|
// declare tabwriter
|
|
tw := tabwriter.NewWriter(w, 0, 0, 3, ' ', 0)
|
|
|
|
// headline
|
|
fmt.Fprintln(tw, "name\tlocation\tblue\tgreen\tred\tenabled\taction")
|
|
|
|
for _, rgbled := range cnf.RGBLEDs {
|
|
fmt.Fprintf(tw, "%v\t%v\t%v\t%v\t%v\t%v\t", rgbled.RGBLEDName, rgbled.RGBLEDLocation, *rgbled.BaseColorsToGPIO[types.BaseColorBlue], *rgbled.BaseColorsToGPIO[types.BaseColorGreen], *rgbled.BaseColorsToGPIO[types.BaseColorRed], rgbled.RGBLEDEnabled)
|
|
|
|
for action, color := range rgbled.ActionMapping {
|
|
fmt.Fprintf(tw, "%v=%v,", action, color)
|
|
}
|
|
|
|
fmt.Fprintf(tw, "\n")
|
|
}
|
|
|
|
tw.Flush()
|
|
}
|
|
|
|
// PrintSensors displays a list with all configured sensors
|
|
func PrintSensors(cnf *config.Configuration, w io.Writer) error {
|
|
|
|
// declar tabwriter
|
|
tw := tabwriter.NewWriter(w, 0, 0, 3, ' ', 0)
|
|
|
|
fmt.Fprint(tw, "name\tlocation\ttype\twire-id\ti2c-bus\ti2c-address\tgpio\tenabled\n")
|
|
|
|
for _, sensor := range cnf.Sensors {
|
|
fmt.Fprintf(tw, "%v\t%v\t%v\t", sensor.Name, sensor.Location, sensor.Model)
|
|
|
|
if sensor.WireID != nil {
|
|
fmt.Fprintf(tw, "%v\t", *sensor.WireID)
|
|
} else {
|
|
fmt.Fprintf(tw, "\t")
|
|
}
|
|
|
|
if sensor.I2CBus != nil {
|
|
fmt.Fprintf(tw, "%v\t", *sensor.I2CBus)
|
|
} else {
|
|
fmt.Fprintf(tw, "\t")
|
|
}
|
|
|
|
if sensor.I2CAddress != nil {
|
|
fmt.Fprintf(tw, "%v\t", *sensor.I2CAddress)
|
|
} else {
|
|
fmt.Fprintf(tw, "\t")
|
|
}
|
|
|
|
if sensor.GPIONumber != nil {
|
|
fmt.Fprintf(tw, "%v\t", *sensor.GPIONumber)
|
|
} else {
|
|
fmt.Fprintf(tw, "\t")
|
|
}
|
|
|
|
fmt.Fprintf(tw, "%v\n", sensor.Enabled)
|
|
}
|
|
|
|
tw.Flush()
|
|
|
|
return nil
|
|
}
|
|
|
|
// PrintMeasuredValues displays a list of measured values
|
|
func PrintMeasuredValues(measuredValues []*types.MeasuredValue, cnf *config.Configuration, w io.Writer) {
|
|
|
|
sensors := GetSensorIDsByMeasuredValues(measuredValues, cnf)
|
|
|
|
// sort measured values for every sensor
|
|
orderedMeasuredValues := make(map[string][]*types.MeasuredValue)
|
|
for _, measuredValue := range measuredValues {
|
|
orderedMeasuredValues[measuredValue.SensorID] = append(orderedMeasuredValues[measuredValue.SensorID], measuredValue)
|
|
}
|
|
|
|
// declare tabwriter
|
|
tw := tabwriter.NewWriter(w, 0, 0, 3, ' ', 0)
|
|
|
|
// headlines
|
|
i := 0
|
|
for _, sensor := range sensors {
|
|
fmt.Fprintf(tw, "%v\t", sensor.FullName())
|
|
if i == len(sensors)-1 {
|
|
fmt.Fprintf(tw, "\n")
|
|
}
|
|
i++
|
|
}
|
|
|
|
// find sensor with the most measured values
|
|
maxLength := 0
|
|
for _, orderedMeasuredValue := range orderedMeasuredValues {
|
|
if len(orderedMeasuredValue) > maxLength {
|
|
maxLength = len(orderedMeasuredValue)
|
|
}
|
|
}
|
|
|
|
// body
|
|
for i := 0; i < maxLength; i++ {
|
|
for _, sensor := range sensors {
|
|
if len(orderedMeasuredValues[sensor.ID]) > i {
|
|
fmt.Fprintf(tw, "%3.3f\t", orderedMeasuredValues[sensor.ID][i].Value)
|
|
} else {
|
|
fmt.Fprint(tw, "\t")
|
|
}
|
|
|
|
}
|
|
fmt.Fprint(tw, "\n")
|
|
}
|
|
tw.Flush()
|
|
}
|