a command line interface for elastic (work in progress)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

183 lines
5.0 KiB

package main
import (
"context"
"flag"
"fmt"
"os"
"strings"
)
func handleAliasCommand() {
if len(os.Args) < 3 {
fmt.Fprintf(os.Stderr, "%s alias: subcommand missing\n", os.Args[0])
printAliasUsage()
os.Exit(1)
}
subcmd := strings.ToLower(os.Args[2])
switch subcmd {
case "list":
listcmd := flag.NewFlagSet("alias list", flag.ExitOnError)
listcmd.SetOutput(os.Stdout)
cfgpath := listcmd.String("config", "", "path to configuration")
server := listcmd.String("server", "", "server name to use")
aname := listcmd.String("name", "", "filter list to named alias")
listcmd.Parse(os.Args[3:])
cfg := LoadConfig(*cfgpath)
es := cfg.GetClient(*server)
aliases, err := es.CatAliases().Do(context.Background())
if err != nil {
fmt.Fprintf(os.Stderr, "elastic error: %s\n", err.Error())
os.Exit(1)
}
for _, alias := range aliases {
if *aname != "" {
if alias.Alias == *aname {
fmt.Printf("%s\n", alias.Index)
}
} else {
fmt.Printf("%s %s\n", alias.Alias, alias.Index)
}
}
case "create":
createcmd := flag.NewFlagSet("alias create", flag.ExitOnError)
createcmd.SetOutput(os.Stdout)
cfgpath := createcmd.String("config", "", "path to configuration")
server := createcmd.String("server", "", "server name to use")
aname := createcmd.String("name", "", "(required) name of alias")
iname := createcmd.String("index", "", "(required) name of index")
createcmd.Parse(os.Args[3:])
if *aname == "" {
fmt.Fprintf(os.Stderr, "name parameter is required for alias create\n")
createcmd.PrintDefaults()
os.Exit(1)
}
if *iname == "" {
fmt.Fprintf(os.Stderr, "index parameter is required for alias create\n")
createcmd.PrintDefaults()
os.Exit(1)
}
cfg := LoadConfig(*cfgpath)
es := cfg.GetClient(*server)
_, err := es.Alias().Add(*iname, *aname).Do(context.Background())
if err != nil {
fmt.Fprintf(os.Stderr, "elastic error: %s\n", err.Error())
os.Exit(1)
}
case "delete":
deletecmd := flag.NewFlagSet("alias delete", flag.ExitOnError)
deletecmd.SetOutput(os.Stdout)
cfgpath := deletecmd.String("config", "", "path to configuration")
server := deletecmd.String("server", "", "server name to use")
aname := deletecmd.String("name", "", "(required) name of alias")
iname := deletecmd.String("index", "", "(required) name of index")
deletecmd.Parse(os.Args[3:])
if *aname == "" {
fmt.Fprintf(os.Stderr, "name parameter is required for alias delete\n")
deletecmd.PrintDefaults()
os.Exit(1)
}
if *iname == "" {
fmt.Fprintf(os.Stderr, "index parameter is required for alias delete\n")
deletecmd.PrintDefaults()
os.Exit(1)
}
cfg := LoadConfig(*cfgpath)
es := cfg.GetClient(*server)
_, err := es.Alias().Remove(*iname, *aname).Do(context.Background())
if err != nil {
fmt.Fprintf(os.Stderr, "elastic error: %s\n", err.Error())
os.Exit(1)
}
case "replace":
replacecmd := flag.NewFlagSet("alias replace", flag.ExitOnError)
replacecmd.SetOutput(os.Stdout)
cfgpath := replacecmd.String("config", "", "path to configuration")
server := replacecmd.String("server", "", "server name to use")
aname := replacecmd.String("name", "", "(required) name of alias")
oiname := replacecmd.String("oldindex", "", "name of the old index")
niname := replacecmd.String("newindex", "",
"(required) name of the new index")
replacecmd.Parse(os.Args[3:])
if *aname == "" {
fmt.Fprintf(os.Stderr, "name parameter is required for alias replace\n")
replacecmd.PrintDefaults()
os.Exit(1)
}
if *niname == "" {
fmt.Fprintf(os.Stderr,
"newindex parameter is required for alias replace\n")
replacecmd.PrintDefaults()
os.Exit(1)
}
cfg := LoadConfig(*cfgpath)
es := cfg.GetClient(*server)
oinames := make([]string, 0, 10)
if *oiname != "" {
oinames = append(oinames, *oiname)
} else {
aliases, err := es.CatAliases().Do(context.Background())
if err != nil {
fmt.Fprintf(os.Stderr, "elastic error: %s\n", err.Error())
os.Exit(1)
}
for _, alias := range aliases {
if alias.Alias == *aname {
oinames = append(oinames, alias.Index)
}
}
}
as := es.Alias()
for _, idx := range oinames {
as.Remove(idx, *aname)
}
as.Add(*niname, *aname)
_, err := as.Do(context.Background())
if err != nil {
fmt.Fprintf(os.Stderr, "elastic error: %s\n", err.Error())
os.Exit(1)
}
case "--help":
printAliasUsage()
os.Exit(0)
default:
fmt.Fprintf(os.Stderr, "%s: alias '%s' is not a recognized subcommand\n",
os.Args[0], os.Args[2])
printAliasUsage()
os.Exit(1)
}
}
func printAliasUsage() {
fmt.Printf("Usage: %s alias <subcommand> ... \n", os.Args[0])
fmt.Printf("See '%s alias <subcommand> --help' for information", os.Args[0])
fmt.Printf(" on a specific command\n")
fmt.Printf("valid subcommands:\n")
fmt.Printf(" list list aliases\n")
fmt.Printf(" create create alias\n")
fmt.Printf(" delete delete alias\n")
fmt.Printf(" replace replace alias (single step add/remove)\n")
}