Add support for -get in yggdrasilconf

This commit is contained in:
Neil Alexander 2019-02-10 16:34:45 +00:00
parent 1b42357889
commit 0fd6f57124
No known key found for this signature in database
GPG key ID: A02A2019A2BB0944

View file

@ -12,6 +12,8 @@ import (
"flag" "flag"
"fmt" "fmt"
"io/ioutil" "io/ioutil"
"os"
"reflect"
"strconv" "strconv"
"github.com/hjson/hjson-go" "github.com/hjson/hjson-go"
@ -25,6 +27,7 @@ type nodeConfig = config.NodeConfig
func main() { func main() {
useconffile := flag.String("useconffile", "/etc/yggdrasil.conf", "update config at specified file path") useconffile := flag.String("useconffile", "/etc/yggdrasil.conf", "update config at specified file path")
usejson := flag.Bool("json", false, "write out new config as JSON instead of HJSON") usejson := flag.Bool("json", false, "write out new config as JSON instead of HJSON")
get := flag.Bool("get", false, "get value instead of setting it")
flag.Parse() flag.Parse()
cfg := nodeConfig{} cfg := nodeConfig{}
var config []byte var config []byte
@ -51,45 +54,75 @@ func main() {
panic(err) panic(err)
} }
json.Unmarshal(confJSON, &cfg) json.Unmarshal(confJSON, &cfg)
switch flag.Arg(0) { if *get {
case "setMTU": item := reflect.ValueOf(cfg)
cfg.IfMTU, err = strconv.Atoi(flag.Arg(1)) for _, arg := range flag.Args() {
if err != nil { if item.Kind() == reflect.Map {
cfg.IfMTU = 1280 for _, key := range item.MapKeys() {
if key.String() == arg {
item = item.MapIndex(key)
}
}
} else {
item = item.FieldByName(arg)
}
if !item.IsValid() {
os.Exit(1)
return
}
} }
if mtu, _ := strconv.Atoi(flag.Arg(1)); mtu < 1280 { var bs []byte
cfg.IfMTU = 1280 if *usejson {
} bs, err = json.Marshal(item.Interface())
case "setIfName":
cfg.IfName = flag.Arg(1)
case "setListen":
cfg.Listen = flag.Arg(1)
case "setAdminListen":
cfg.AdminListen = flag.Arg(1)
case "setIfTapMode":
if flag.Arg(1) == "true" {
cfg.IfTAPMode = true
} else { } else {
cfg.IfTAPMode = false bs, err = hjson.Marshal(item.Interface())
} }
case "addPeer": if err != nil {
found := false panic(err)
for _, v := range cfg.Peers { }
if v == flag.Arg(1) { fmt.Println(string(bs))
found = true os.Exit(0)
} else {
switch flag.Arg(0) {
case "setMTU":
cfg.IfMTU, err = strconv.Atoi(flag.Arg(1))
if err != nil {
cfg.IfMTU = 1280
} }
} if mtu, _ := strconv.Atoi(flag.Arg(1)); mtu < 1280 {
if !found { cfg.IfMTU = 1280
cfg.Peers = append(cfg.Peers, flag.Arg(1))
}
case "removePeer":
for k, v := range cfg.Peers {
if v == flag.Arg(1) {
cfg.Peers = append(cfg.Peers[:k], cfg.Peers[k+1:]...)
} }
case "setIfName":
cfg.IfName = flag.Arg(1)
case "setListen":
cfg.Listen = flag.Arg(1)
case "setAdminListen":
cfg.AdminListen = flag.Arg(1)
case "setIfTapMode":
if flag.Arg(1) == "true" {
cfg.IfTAPMode = true
} else {
cfg.IfTAPMode = false
}
case "addPeer":
found := false
for _, v := range cfg.Peers {
if v == flag.Arg(1) {
found = true
}
}
if !found {
cfg.Peers = append(cfg.Peers, flag.Arg(1))
}
case "removePeer":
for k, v := range cfg.Peers {
if v == flag.Arg(1) {
cfg.Peers = append(cfg.Peers[:k], cfg.Peers[k+1:]...)
}
}
case "setNodeInfoName":
cfg.NodeInfo["name"] = flag.Arg(1)
} }
case "setNodeInfoName":
cfg.NodeInfo["name"] = flag.Arg(1)
} }
var bs []byte var bs []byte
if *usejson { if *usejson {