0
0
Fork 0
mirror of https://github.com/crazy-max/diun.git synced 2025-01-12 11:38:11 +00:00
crazy-max_diun/cmd/main.go
2019-06-04 22:11:54 +02:00

94 lines
2.6 KiB
Go

package main
import (
"os"
"os/signal"
"runtime"
"syscall"
"time"
"github.com/crazy-max/cron"
"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"
"gopkg.in/alecthomas/kingpin.v2"
)
var (
diun *app.Diun
flags model.Flags
c *cron.Cron
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("run-once", "Run once on startup.").Envar("RUN_ONCE").Default("false").BoolVar(&flags.RunOnce)
kingpin.Flag("docker", "Enable Docker mode.").Envar("DOCKER").Default("false").BoolVar(&flags.Docker)
kingpin.UsageTemplate(kingpin.CompactUsageTemplate).Version(version).Author("CrazyMax")
kingpin.CommandLine.Name = "diun"
kingpin.CommandLine.Help = `Docker image update notifier. More info on 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
if c != nil {
c.Stop()
}
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")
}
if err := cfg.Check(); err != nil {
cfg.Display()
log.Fatal().Err(err).Msg("Improper configuration")
}
cfg.Display()
// Init
if diun, err = app.New(cfg); err != nil {
log.Fatal().Err(err).Msg("Cannot initialize Diun")
}
// Run once
if flags.RunOnce {
diun.Run()
}
// Start scheduler
c = cron.NewWithLocation(location)
log.Info().Msgf("Start watcher with schedule %s", cfg.Watch.Schedule)
if err := c.AddJob(cfg.Watch.Schedule, diun); err != nil {
log.Fatal().Err(err).Msg("Cannot create cron task")
}
c.Start()
select {}
}