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.

61 lines
1.5 KiB

  1. package main
  2. import (
  3. "context"
  4. "flag"
  5. "fmt"
  6. "os"
  7. elastic "github.com/olivere/elastic/v7"
  8. )
  9. func handleSearchCommand() {
  10. cmd := flag.NewFlagSet("search", flag.ExitOnError)
  11. cmd.SetOutput(os.Stdout)
  12. cmd.Usage = func() {
  13. fmt.Printf("Usage: %s search <index> <search term(s)>\n", os.Args[0])
  14. cmd.PrintDefaults()
  15. }
  16. cfgpath := cmd.String("config", "", "path to configuration")
  17. server := cmd.String("server", "", "server name to use")
  18. size := cmd.Int("size", 10, "maximum number of results returned")
  19. from := cmd.Int("from", 0, "count to start search results from")
  20. defop := cmd.String("defop", "AND", "default search operator")
  21. cmd.Parse(os.Args[2:])
  22. if *defop != "AND" && *defop != "OR" {
  23. fmt.Fprintf(os.Stderr, "default operator must be AND or OR\n")
  24. cmd.Usage()
  25. os.Exit(1)
  26. }
  27. if len(cmd.Args()) < 2 {
  28. fmt.Fprintf(os.Stderr, "index name and query required for search\n")
  29. cmd.Usage()
  30. os.Exit(1)
  31. }
  32. cfg := LoadConfig(*cfgpath)
  33. es := cfg.GetClient(*server)
  34. res, err := es.Search().
  35. Index(cmd.Arg(0)).
  36. Size(*size).
  37. From(*from).
  38. NoStoredFields().
  39. FetchSourceContext(
  40. elastic.NewFetchSourceContext(true).Include("*"),
  41. ).
  42. Query(elastic.NewQueryStringQuery(cmd.Arg(1)).DefaultOperator(*defop)).
  43. Do(context.Background())
  44. if err != nil {
  45. fmt.Fprintf(os.Stderr, "elastic error: %s\n", err.Error())
  46. os.Exit(1)
  47. }
  48. for _, r := range res.Hits.Hits {
  49. fmt.Fprintf(os.Stdout, "%s: %s\n", r.Id, string(r.Source))
  50. }
  51. fmt.Fprintf(os.Stdout, "Total: %d\n", res.Hits.TotalHits.Value)
  52. }