mirror of
https://github.com/etcd-io/etcd.git
synced 2024-09-27 06:25:44 +00:00
etcdctlv3/command: add prefix flag for get
This commit is contained in:
parent
2aa635ea39
commit
683274b201
@ -27,6 +27,7 @@ var (
|
||||
getLimit int64
|
||||
getSortOrder string
|
||||
getSortTarget string
|
||||
getPrefix bool
|
||||
)
|
||||
|
||||
// NewGetCommand returns the cobra command for "get".
|
||||
@ -40,8 +41,8 @@ func NewGetCommand() *cobra.Command {
|
||||
cmd.Flags().StringVar(&getSortOrder, "order", "", "order of results; ASCEND or DESCEND")
|
||||
cmd.Flags().StringVar(&getSortTarget, "sort-by", "", "sort target; CREATE, KEY, MODIFY, VALUE, or VERSION")
|
||||
cmd.Flags().Int64Var(&getLimit, "limit", 0, "maximum number of results")
|
||||
cmd.Flags().BoolVar(&getPrefix, "prefix", false, "enable keys with matching prefix")
|
||||
// TODO: add fromkey.
|
||||
// TODO: add prefix.
|
||||
// TODO: add consistency.
|
||||
return cmd
|
||||
}
|
||||
@ -65,8 +66,12 @@ func getGetOp(cmd *cobra.Command, args []string) (string, []clientv3.OpOption) {
|
||||
opts := []clientv3.OpOption{}
|
||||
key := args[0]
|
||||
if len(args) > 1 {
|
||||
if getPrefix {
|
||||
ExitWithError(ExitBadArgs, fmt.Errorf("too many arguments for range with prefix, only accept one."))
|
||||
}
|
||||
opts = append(opts, clientv3.WithRange(args[1]))
|
||||
}
|
||||
|
||||
opts = append(opts, clientv3.WithLimit(getLimit))
|
||||
|
||||
sortByOrder := clientv3.SortNone
|
||||
@ -102,5 +107,10 @@ func getGetOp(cmd *cobra.Command, args []string) (string, []clientv3.OpOption) {
|
||||
}
|
||||
|
||||
opts = append(opts, clientv3.WithSort(sortByTarget, sortByOrder))
|
||||
|
||||
if getPrefix {
|
||||
opts = append(opts, clientv3.WithPrefix())
|
||||
}
|
||||
|
||||
return key, opts
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user