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.

48 lines
1.0 KiB

4 years ago
4 years ago
4 years ago
4 years ago
  1. package main
  2. import (
  3. "fmt"
  4. "os"
  5. "strings"
  6. )
  7. func main() {
  8. if len(os.Args) < 2 {
  9. fmt.Fprintf(os.Stderr, "%s: required argument missing\n", os.Args[0])
  10. printDefaultUsage()
  11. os.Exit(1)
  12. }
  13. cmd := strings.ToLower(os.Args[1])
  14. switch cmd {
  15. case "index", "idx", "i":
  16. handleIndexCommand()
  17. case "alias", "a":
  18. handleAliasCommand()
  19. case "search", "sea", "s":
  20. handleSearchCommand()
  21. case "--help":
  22. printDefaultUsage()
  23. os.Exit(0)
  24. default:
  25. fmt.Fprintf(os.Stderr, "%s: '%s' is not a recognized command\n",
  26. os.Args[0], os.Args[1])
  27. printDefaultUsage()
  28. os.Exit(1)
  29. }
  30. os.Exit(0)
  31. }
  32. func printDefaultUsage() {
  33. fmt.Printf("Usage: %s <command> ...\n", os.Args[0])
  34. fmt.Printf("See '%s <command> --help' for information", os.Args[0])
  35. fmt.Printf(" on a specific command\n")
  36. fmt.Printf("valid commands:\n")
  37. fmt.Printf(" index create, delete, refresh, or list indexes\n")
  38. fmt.Printf(" alias create, delete, replace, or list aliases\n")
  39. fmt.Printf(" search search an index or alias\n")
  40. }