feat: add input(es) source support
This commit is contained in:
		| @@ -21,6 +21,8 @@ esgo2dump --input=http://127.0.0.1:9200/some_index --output=http://192.168.1.1:9 | ||||
|  | ||||
| esgo2dump --input=https://username:password@127.0.0.1:9200/some_index --output=./data.json | ||||
|  | ||||
| esgo2dump --input=http://127.0.0.1:9200/some_index --source='id;name;age;address' --output=./data.json | ||||
|  | ||||
| esgo2dump --input=http://127.0.0.1:9200/some_index --output=./data.json --query='{"match": {"name": "some_name"}}' | ||||
|  | ||||
| esgo2dump --input=http://127.0.0.1:9200/some_index --output=./data.json --query_file=my_queries.json`, | ||||
| @@ -30,6 +32,7 @@ esgo2dump --input=http://127.0.0.1:9200/some_index --output=./data.json --query_ | ||||
| 	f_output string | ||||
| 	f_limit  int | ||||
| 	f_type   string | ||||
| 	f_source string | ||||
| 	f_query  string | ||||
|  | ||||
| 	f_query_file string | ||||
| @@ -45,6 +48,7 @@ func init() { | ||||
| 	rootCommand.Flags().StringVarP(&f_input, "input", "i", "", "*required: input file or es url (example :data.json / http://127.0.0.1:9200/my_index)") | ||||
| 	rootCommand.Flags().StringVarP(&f_output, "output", "o", "output.json", "") | ||||
| 	rootCommand.Flags().StringVarP(&f_type, "type", "t", "data", "data/mapping/setting") | ||||
| 	rootCommand.Flags().StringVarP(&f_source, "source", "s", "", "query source, use ';' to separate") | ||||
| 	rootCommand.Flags().StringVarP(&f_query, "query", "q", "", `query dsl, example: {"bool":{"must":[{"term":{"name":{"value":"some_name"}}}],"must_not":[{"range":{"age":{"gte":18,"lt":60}}}]}}`) | ||||
| 	rootCommand.Flags().StringVar(&f_query_file, "query_file", "", `query json file (will execute line by line)`) | ||||
| 	rootCommand.Flags().IntVarP(&f_limit, "limit", "l", 100, "") | ||||
|   | ||||
| @@ -7,11 +7,13 @@ import ( | ||||
| 	"fmt" | ||||
| 	"net/url" | ||||
| 	"os" | ||||
| 	"strings" | ||||
|  | ||||
| 	"github.com/loveuer/esgo2dump/internal/interfaces" | ||||
| 	"github.com/loveuer/esgo2dump/internal/opt" | ||||
| 	"github.com/loveuer/esgo2dump/internal/xes" | ||||
| 	"github.com/loveuer/esgo2dump/internal/xfile" | ||||
| 	"github.com/samber/lo" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/spf13/cobra" | ||||
| ) | ||||
| @@ -76,6 +78,10 @@ func run(cmd *cobra.Command, args []string) error { | ||||
| 		return fmt.Errorf("with file input, query or query_file can't be supported") | ||||
| 	} | ||||
|  | ||||
| 	if (f_source != "") && ioi.IsFile() { | ||||
| 		return fmt.Errorf("with file input, source can't be supported") | ||||
| 	} | ||||
|  | ||||
| 	switch f_type { | ||||
| 	case "data": | ||||
| 		if err = executeData(cmd.Context(), ioi, ioo); err != nil { | ||||
| @@ -122,8 +128,15 @@ func executeData(ctx context.Context, input, output interfaces.DumpIO) error { | ||||
| 		ch      = make(chan []*interfaces.ESSource, 1) | ||||
| 		errCh   = make(chan error) | ||||
| 		queries = make([]map[string]any, 0) | ||||
| 		sources = make([]string, 0) | ||||
| 	) | ||||
|  | ||||
| 	if f_source != "" { | ||||
| 		sources = lo.Map(strings.Split(f_source, ";"), func(item string, idx int) string { | ||||
| 			return strings.TrimSpace(item) | ||||
| 		}) | ||||
| 	} | ||||
|  | ||||
| 	if f_query != "" { | ||||
| 		query := make(map[string]any) | ||||
| 		if err = json.Unmarshal([]byte(f_query), &query); err != nil { | ||||
| @@ -187,7 +200,7 @@ func executeData(ctx context.Context, input, output interfaces.DumpIO) error { | ||||
| 				case <-c.Done(): | ||||
| 					return | ||||
| 				default: | ||||
| 					if lines, err = input.ReadData(c, f_limit, query); err != nil { | ||||
| 					if lines, err = input.ReadData(c, f_limit, query, sources); err != nil { | ||||
| 						errCh <- err | ||||
| 						return | ||||
| 					} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user