mirror of
https://github.com/crazy-max/diun.git
synced 2025-12-21 13:23:09 +01:00
Initial commit
This commit is contained in:
94
cmd/main.go
Normal file
94
cmd/main.go
Normal file
@@ -0,0 +1,94 @@
|
||||
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 {}
|
||||
}
|
||||
Reference in New Issue
Block a user