llmongodb/options.go

76 lines
2 KiB
Go
Raw Normal View History

2015-11-20 15:23:12 +01:00
// options
package main
import (
// "encoding/json"
2015-11-20 15:23:12 +01:00
"flag"
"fmt"
// "io/ioutil"
2015-11-20 15:23:12 +01:00
"log"
"os"
"path"
"path/filepath"
"time"
)
2016-10-05 11:55:50 +02:00
// Options structure
2015-11-20 15:23:12 +01:00
type Options struct {
RedisTTL time.Duration
CurrentPath string
Exe string
LogFile string
ConfigFile string
Timeout time.Duration
MaxLogins int
2015-11-20 15:23:12 +01:00
Debug bool
Version bool
Bulk bool
MaxError int
Influxdb string
Hostname string
Month string
Pidfile string
2015-11-20 15:23:12 +01:00
}
var (
opts = Options{
RedisTTL: time.Hour * 11688, // 16 mesi
LogFile: "log/llmongo.log",
MaxLogins: -1,
}
)
2015-11-20 15:23:12 +01:00
func usage() {
fmt.Println("Usage: llmongo -m <mongo uri> -r <redis uri> -t <redis keys ttl> -l <logfile> -T <running ttl> -x <xymon server> -H <hostname> -i <influxdb uri> -v")
2016-10-05 11:55:50 +02:00
fmt.Println()
2015-11-20 15:23:12 +01:00
os.Exit(0)
}
func init() {
var err error
opts.CurrentPath, err = filepath.Abs(filepath.Dir(os.Args[0]))
if err != nil {
log.Fatal(err)
}
opts.LogFile = path.Join(opts.CurrentPath, opts.LogFile)
2016-05-16 16:17:53 +02:00
opts.Pidfile = path.Join(opts.CurrentPath, "run", path.Base(os.Args[0])+".pid")
2015-11-20 15:23:12 +01:00
opts.Exe = path.Base(os.Args[0])
flag.StringVar(&opts.Influxdb, "i", "", "influxdb server")
flag.StringVar(&opts.Hostname, "H", "", "hostname")
2016-11-10 09:01:10 +01:00
flag.StringVar(&dbs.MongoURI, "m", "", "Mongodb")
flag.StringVar(&dbs.Database, "d", dbs.Database, "Mongodb Database")
2016-10-05 11:55:50 +02:00
flag.StringVar(&dbs.RedisURI, "r", dbs.RedisURI, "Redis")
2016-11-10 09:01:10 +01:00
flag.StringVar(&dbs.RethinkURI, "R", "", "Rethink DB")
2015-11-20 15:23:12 +01:00
flag.StringVar(&opts.LogFile, "l", opts.LogFile, "Logs filename")
flag.IntVar(&opts.MaxLogins, "L", opts.MaxLogins, "Max lastlogins")
flag.DurationVar(&opts.RedisTTL, "t", opts.RedisTTL, "Redis keys TTL")
2015-11-20 15:23:12 +01:00
flag.BoolVar(&opts.Version, "v", false, "Version")
2015-11-20 16:31:39 +01:00
flag.DurationVar(&opts.Timeout, "T", 0, "Running timeout")
2015-11-20 15:23:12 +01:00
flag.BoolVar(&opts.Debug, "D", false, "Debug")
flag.BoolVar(&opts.Bulk, "B", false, "Bulk")
flag.IntVar(&opts.MaxError, "E", 100, "Max Mongodb Error")
flag.StringVar(&opts.Pidfile, "p", opts.Pidfile, "pid file")
2015-11-20 15:23:12 +01:00
}