package main import "go.wit.com/log" /* this parses the command line arguements this enables command line options from other packages like 'gui' and 'log' */ var argv args type args struct { Xml []string `arg:"--add-xml" help:"add libvirt xml files"` CfgDir string `arg:"--dir" help:"defaults to ~/.config/virtigo/"` Hosts []string `arg:"--hosts" help:"hosts to connect to"` Port int `arg:"--port" default:"8080" help:"allow droplet events via http"` Uptime bool `arg:"--uptime" default:"true" help:"allow uptime checks for things like Kuma"` Daemon bool `arg:"--daemon" help:"run in daemon mode"` Save bool `arg:"--save" default:"false" help:"save xml changes to the protobuf values"` } func (a args) Description() string { return ` virtigo will help control your cluster of hypervisiors This maintains a master list of all your vm's (aka 'droplets') in your homelab cloud. You can import libvirt xml files. This app talks to your hypervisors via the virtigod daemon. ` } func (args) Version() string { return "virtigo " + Version } var INFO *log.LogFlag var POLL *log.LogFlag var WARN *log.LogFlag var SPEW *log.LogFlag var EVENT *log.LogFlag func init() { full := "go.wit.com/apps/virtigo" short := "virtigo" INFO = log.NewFlag("INFO", false, full, short, "general virtigo") POLL = log.NewFlag("POLL", false, full, short, "virtigo polling") SPEW = log.NewFlag("SPEW", true, full, short, "bad things") EVENT = log.NewFlag("EVENT", true, full, short, "hypeprvisor/droplet events") }