batmon/main.go
2025-01-08 11:07:46 +03:00

61 lines
1.4 KiB
Go

package main
import (
"sync"
"github.com/sirupsen/logrus"
"github.com/spf13/cobra"
"github.com/spf13/viper"
"batmon/internal/battery"
"batmon/internal/config"
"batmon/internal/model"
)
func main() {
var rootCmd = &cobra.Command{
Use: "batmon",
Short: "Dead-simple battery monitor for Linux",
Long: `TODO`,
Run: func(cmd *cobra.Command, args []string) {
// load the battery configuration
config, err := config.Load(viper.GetString("config"))
if err != nil {
logrus.WithFields(logrus.Fields{
"error": err,
}).Fatal("Failed to load configuration")
}
// create a WaitGroup to wait for all goroutines to finish
var wg sync.WaitGroup
wg.Add(len(config.BatPaths))
// start a goroutine for each battery
for _, bat := range config.BatPaths {
go func(bat model.Battery) {
defer wg.Done()
err := battery.Monitor(bat)
if err != nil {
logrus.WithFields(logrus.Fields{
"error": err,
"battery": bat.Path,
}).Error("Failed to monitor battery")
}
}(bat)
}
// wait for all goroutines to finish
wg.Wait()
},
}
rootCmd.PersistentFlags().StringP("config", "c", "config.json", "Path to the configuration file")
viper.BindPFlag("config", rootCmd.PersistentFlags().Lookup("config"))
if err := rootCmd.Execute(); err != nil {
logrus.WithFields(logrus.Fields{
"error": err,
}).Fatal("Failed to execute root command")
}
}