summaryrefslogtreecommitdiff
path: root/argv.go
blob: 4b062190954111573a6501955a0856d7adefb6c6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
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")
}