Allow setting non-array values

This commit is contained in:
Neil Alexander 2019-02-10 22:02:39 +00:00
parent 6ef4a42ab7
commit 7d4689cc12
No known key found for this signature in database
GPG key ID: A02A2019A2BB0944

View file

@ -14,6 +14,8 @@ import (
"io/ioutil" "io/ioutil"
"os" "os"
"reflect" "reflect"
"strconv"
"strings"
"github.com/hjson/hjson-go" "github.com/hjson/hjson-go"
"golang.org/x/text/encoding/unicode" "golang.org/x/text/encoding/unicode"
@ -26,19 +28,23 @@ 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")
flag.Parse()
var action string flags := flag.Args()
switch flag.Arg(0) { if len(flags) == 0 {
fmt.Println("No arguments given")
os.Exit(1)
}
action := flags[0]
switch strings.ToLower(flags[0]) {
case "get": case "get":
case "set": case "set":
case "add": case "add":
case "remove": case "remove":
action = flag.Arg(0) action = strings.ToLower(flags[0])
default: default:
fmt.Errorf("Action must be get, set, add or remove") fmt.Println("Unknown action", flags[0])
os.Exit(1)
} }
flag.Parse()
cfg := nodeConfig{} cfg := nodeConfig{}
var config []byte var config []byte
var err error var err error
@ -64,89 +70,93 @@ func main() {
panic(err) panic(err)
} }
json.Unmarshal(confJSON, &cfg) json.Unmarshal(confJSON, &cfg)
item := reflect.ValueOf(&cfg).Elem()
item := reflect.ValueOf(cfg) for index, arg := range flags {
for index, arg := range flag.Args() { switch index {
if *set || *add || *remove { case 0:
continue
} case len(flags) - 2:
if item.Kind() == reflect.Map { fallthrough
for _, key := range item.MapKeys() { case len(flags) - 1:
if key.String() == arg { if action != "get" {
item = item.MapIndex(key) continue
}
fallthrough
default:
switch item.Kind() {
case reflect.Map:
for _, key := range item.MapKeys() {
if key.String() == arg {
item = item.MapIndex(key)
}
} }
case reflect.Struct:
item = item.FieldByName(arg)
}
if !item.IsValid() {
os.Exit(1)
return
}
}
}
switch action {
case "get":
var bs []byte
if *usejson {
if bs, err = json.Marshal(item.Interface()); err == nil {
fmt.Println(string(bs))
} }
} else { } else {
item = item.FieldByName(arg) if bs, err = hjson.Marshal(item.Interface()); err == nil {
fmt.Println(string(bs))
}
} }
if !item.IsValid() { if err != nil {
os.Exit(1) panic(err)
return
} }
} case "set":
var bs []byte name := flags[len(flags)-2:][0]
if *usejson { value := flags[len(flags)-1:][0]
bs, err = json.Marshal(item.Interface()) switch item.Kind() {
} else { case reflect.Struct:
bs, err = hjson.Marshal(item.Interface()) field := item.FieldByName(name)
} if !field.IsValid() {
if err != nil { fmt.Println("Invalid option:", strings.Join(flags[1:len(flags)-1], " "))
panic(err) os.Exit(1)
}
fmt.Println(string(bs))
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 { switch field.Kind() {
cfg.IfMTU = 1280 case reflect.String:
} field.SetString(value)
case "setIfName": case reflect.Bool:
cfg.IfName = flag.Arg(1) field.SetBool(value == "true")
case "setListen": case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64:
cfg.Listen = flag.Arg(1) if int, ierr := strconv.ParseInt(value, 10, 64); ierr == nil {
case "setAdminListen": field.SetInt(int)
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
} }
} case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64:
if !found { if uint, uerr := strconv.ParseUint(value, 10, 64); uerr == nil {
cfg.Peers = append(cfg.Peers, flag.Arg(1)) field.SetUint(uint)
}
case "removePeer":
for k, v := range cfg.Peers {
if v == flag.Arg(1) {
cfg.Peers = append(cfg.Peers[:k], cfg.Peers[k+1:]...)
} }
default:
fmt.Println("Invalid type for option:", name)
os.Exit(1)
} }
case "setNodeInfoName": case reflect.Map:
cfg.NodeInfo["name"] = flag.Arg(1) intf := item.Interface().(map[string]interface{})
intf[name] = value
} }
}*/ var bs []byte
var bs []byte if *usejson {
if *usejson { if bs, err = json.Marshal(cfg); err == nil {
bs, err = json.Marshal(cfg) fmt.Println(string(bs))
} else { }
bs, err = hjson.Marshal(cfg) } else {
if bs, err = hjson.Marshal(cfg); err == nil {
fmt.Println(string(bs))
}
}
os.Exit(0)
default:
os.Exit(1)
} }
if err != nil {
panic(err)
}
fmt.Println(string(bs))
return
} }