mirror of
https://github.com/crazy-max/diun.git
synced 2025-01-12 11:38:11 +00:00
74 lines
2.1 KiB
Go
74 lines
2.1 KiB
Go
package main
|
|
|
|
import (
|
|
"os"
|
|
"os/signal"
|
|
"runtime"
|
|
"syscall"
|
|
"time"
|
|
|
|
"github.com/alecthomas/kingpin"
|
|
"github.com/crazy-max/diun/internal/app"
|
|
"github.com/crazy-max/diun/internal/config"
|
|
"github.com/crazy-max/diun/internal/logging"
|
|
"github.com/crazy-max/diun/internal/model"
|
|
"github.com/rs/zerolog/log"
|
|
)
|
|
|
|
var (
|
|
diun *app.Diun
|
|
flags model.Flags
|
|
version = "dev"
|
|
)
|
|
|
|
func main() {
|
|
runtime.GOMAXPROCS(runtime.NumCPU())
|
|
|
|
// Parse command line
|
|
kingpin.Flag("config", "Diun configuration file.").Envar("CONFIG").Required().StringVar(&flags.Cfgfile)
|
|
kingpin.Flag("timezone", "Timezone assigned to Diun.").Envar("TZ").Default("UTC").StringVar(&flags.Timezone)
|
|
kingpin.Flag("log-level", "Set log level.").Envar("LOG_LEVEL").Default("info").StringVar(&flags.LogLevel)
|
|
kingpin.Flag("log-json", "Enable JSON logging output.").Envar("LOG_JSON").Default("false").BoolVar(&flags.LogJson)
|
|
kingpin.Flag("log-caller", "Enable to add file:line of the caller.").Envar("LOG_CALLER").Default("false").BoolVar(&flags.LogCaller)
|
|
kingpin.UsageTemplate(kingpin.CompactUsageTemplate).Version(version).Author("CrazyMax")
|
|
kingpin.CommandLine.Name = "diun"
|
|
kingpin.CommandLine.Help = `Docker image update notifier.\nMore info: https://github.com/crazy-max/diun`
|
|
kingpin.Parse()
|
|
|
|
// Load timezone location
|
|
location, err := time.LoadLocation(flags.Timezone)
|
|
if err != nil {
|
|
log.Panic().Err(err).Msgf("Cannot load timezone %s", flags.Timezone)
|
|
}
|
|
|
|
// Init
|
|
logging.Configure(&flags, location)
|
|
log.Info().Msgf("Starting Diun %s", version)
|
|
|
|
// Handle os signals
|
|
channel := make(chan os.Signal)
|
|
signal.Notify(channel, os.Interrupt, syscall.SIGTERM)
|
|
go func() {
|
|
sig := <-channel
|
|
diun.Close()
|
|
log.Warn().Msgf("Caught signal %v", sig)
|
|
os.Exit(0)
|
|
}()
|
|
|
|
// Load and check configuration
|
|
cfg, err := config.Load(flags, version)
|
|
if err != nil {
|
|
log.Fatal().Err(err).Msg("Cannot load configuration")
|
|
}
|
|
cfg.Display()
|
|
|
|
// Init
|
|
if diun, err = app.New(cfg, location); err != nil {
|
|
log.Fatal().Err(err).Msg("Cannot initialize Diun")
|
|
}
|
|
|
|
// Start
|
|
if err = diun.Start(); err != nil {
|
|
log.Fatal().Err(err).Msg("Cannot start Diun")
|
|
}
|
|
}
|