diff options
author | Rasmus Dahlberg <rasmus@rgdd.se> | 2023-12-31 09:39:25 +0100 |
---|---|---|
committer | Rasmus Dahlberg <rasmus@rgdd.se> | 2024-01-07 20:22:23 +0100 |
commit | e18d36ebae30536c77c61cd5da123991e0ca1629 (patch) | |
tree | bf4880c0019a6009ab1b671e23ef4a1a4a5e8e08 /internal/options | |
parent | 54d980afcbd6f0011d6a162e0003587d26a3e311 (diff) |
Add drafty prototype
Diffstat (limited to 'internal/options')
-rw-r--r-- | internal/options/options.go | 97 |
1 files changed, 0 insertions, 97 deletions
diff --git a/internal/options/options.go b/internal/options/options.go deleted file mode 100644 index 3e253c5..0000000 --- a/internal/options/options.go +++ /dev/null @@ -1,97 +0,0 @@ -package options - -import ( - "encoding/json" - "flag" - "fmt" - "os" - - "rgdd.se/silent-ct/internal/manager" - "rgdd.se/silent-ct/pkg/monitor" - "rgdd.se/silent-ct/pkg/server" -) - -const usage = `Usage: - - silent-ct [Options] - -Options: - - -h, --help: Output usage message and exit - -c, --config: Path to a configuration file (Default: %s) - -l, --listen: Listen address to receive submission on (Default: %s) - -s, --state: Path to a directory where state is stored (Default: %s) - -Example configuration file: - - { - "monitor": [ - { - "wildcard": "example.org", - "excludes": [ - "test" - ] - } - ], - "nodes": [ - { - "name": "node_a", - "secret": "aaaa", - "issues": [ - "example.org", - "www.example.org" - ] - } - ] - } - -` - -// Options are command-line options the user can specify -type Options struct { - ListenAddr string - ConfigFile string - StateDir string -} - -func New(cmd string, args []string) (opts Options, err error) { - fs := flag.NewFlagSet(cmd, flag.ContinueOnError) - fs.Usage = func() { - fmt.Fprintf(os.Stderr, usage, server.DefaultConfigFile, server.DefaultAddress, manager.DefaultStateDir) - } - stringOpt(fs, &opts.ConfigFile, "config", "c", server.DefaultConfigFile) - stringOpt(fs, &opts.ListenAddr, "listen", "l", server.DefaultAddress) - stringOpt(fs, &opts.StateDir, "state", "s", manager.DefaultStateDir) - if err = fs.Parse(args); err != nil { - return opts, err - } - - if opts.ConfigFile == "" { - return opts, fmt.Errorf("-c, --config: must not be an empty string") - } - if opts.StateDir == "" { - return opts, fmt.Errorf("-s, --state: must not be an empty string") - } - if opts.ListenAddr == "" { - return opts, fmt.Errorf("-l, --listen: must not be an empty string") - } - return opts, err -} - -func stringOpt(fs *flag.FlagSet, opt *string, short, long, value string) { - fs.StringVar(opt, short, value, "") - fs.StringVar(opt, long, value, "") -} - -type Config struct { - Monitor monitor.MatchWildcards `json:"monitor"` - Nodes server.Nodes `json:"nodes"` -} - -func (c *Config) FromFile(fileName string) error { - b, err := os.ReadFile(fileName) - if err != nil { - return err - } - return json.Unmarshal(b, c) -} |