From cc4ee912794aa7da93ee046ec32135c5d3e5ad69 Mon Sep 17 00:00:00 2001 From: Neil Alexander Date: Mon, 21 May 2018 14:29:27 +0100 Subject: [PATCH] Allow JSON output using -json argument --- yggdrasilctl.go | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/yggdrasilctl.go b/yggdrasilctl.go index 48ea19b9..77c98fbc 100644 --- a/yggdrasilctl.go +++ b/yggdrasilctl.go @@ -13,11 +13,12 @@ type admin_info map[string]interface{} func main() { server := flag.String("endpoint", "localhost:9001", "Admin socket endpoint") + injson := flag.Bool("json", false, "Output in JSON format") flag.Parse() args := flag.Args() if len(args) == 0 { - fmt.Println("usage:", os.Args[0], "[-endpoint=localhost:9001] command [key=value] [...]") + fmt.Println("usage:", os.Args[0], "[-endpoint=localhost:9001] [-json] command [key=value] [...]") fmt.Println("example:", os.Args[0], "getPeers") fmt.Println("example:", os.Args[0], "setTunTap name=auto mtu=1500 tap_mode=false") fmt.Println("example:", os.Args[0], "-endpoint=localhost:9001 getDHT") @@ -78,6 +79,13 @@ func main() { req := recv["request"].(map[string]interface{}) res := recv["response"].(map[string]interface{}) + if *injson { + if json, err := json.MarshalIndent(res, "", " "); err == nil { + fmt.Println(string(json)) + } + os.Exit(0) + } + switch req["request"] { case "dot": fmt.Println(res["dot"])