mirror of
https://github.com/containers/podman.git
synced 2025-10-18 03:33:32 +08:00
Unify the method of parsing filters in cmd
This commit unifies the method of filters parsing in cmd. It removes also the function redundancy. [NO NEW TESTS NEEDED] Signed-off-by: Jakub Guzik <jguzik@redhat.com>
This commit is contained in:
@ -9,11 +9,11 @@ import (
|
||||
|
||||
"github.com/containers/common/pkg/completion"
|
||||
"github.com/containers/podman/v3/cmd/podman/common"
|
||||
"github.com/containers/podman/v3/cmd/podman/parse"
|
||||
"github.com/containers/podman/v3/cmd/podman/registry"
|
||||
"github.com/containers/podman/v3/cmd/podman/utils"
|
||||
"github.com/containers/podman/v3/cmd/podman/validate"
|
||||
"github.com/containers/podman/v3/pkg/domain/entities"
|
||||
"github.com/containers/podman/v3/pkg/specgenutil"
|
||||
"github.com/spf13/cobra"
|
||||
)
|
||||
|
||||
@ -64,7 +64,7 @@ func prune(cmd *cobra.Command, args []string) error {
|
||||
}
|
||||
}
|
||||
|
||||
pruneOptions.Filters, err = specgenutil.ParseFilters(filter)
|
||||
pruneOptions.Filters, err = parse.FilterArgumentsIntoFilters(filter)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
@ -8,11 +8,11 @@ import (
|
||||
|
||||
"github.com/containers/common/pkg/completion"
|
||||
"github.com/containers/podman/v3/cmd/podman/common"
|
||||
"github.com/containers/podman/v3/cmd/podman/parse"
|
||||
"github.com/containers/podman/v3/cmd/podman/registry"
|
||||
"github.com/containers/podman/v3/cmd/podman/utils"
|
||||
"github.com/containers/podman/v3/cmd/podman/validate"
|
||||
"github.com/containers/podman/v3/pkg/domain/entities"
|
||||
"github.com/containers/podman/v3/pkg/specgenutil"
|
||||
"github.com/spf13/cobra"
|
||||
)
|
||||
|
||||
@ -66,7 +66,7 @@ func prune(cmd *cobra.Command, args []string) error {
|
||||
return nil
|
||||
}
|
||||
}
|
||||
filterMap, err := specgenutil.ParseFilters(filter)
|
||||
filterMap, err := parse.FilterArgumentsIntoFilters(filter)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
@ -10,10 +10,10 @@ import (
|
||||
"github.com/containers/common/pkg/completion"
|
||||
"github.com/containers/common/pkg/report"
|
||||
"github.com/containers/podman/v3/cmd/podman/common"
|
||||
"github.com/containers/podman/v3/cmd/podman/parse"
|
||||
"github.com/containers/podman/v3/cmd/podman/registry"
|
||||
"github.com/containers/podman/v3/cmd/podman/validate"
|
||||
"github.com/containers/podman/v3/pkg/domain/entities"
|
||||
"github.com/pkg/errors"
|
||||
"github.com/spf13/cobra"
|
||||
"github.com/spf13/pflag"
|
||||
)
|
||||
@ -61,14 +61,12 @@ func init() {
|
||||
}
|
||||
|
||||
func networkList(cmd *cobra.Command, args []string) error {
|
||||
networkListOptions.Filters = make(map[string][]string)
|
||||
for _, f := range filters {
|
||||
split := strings.SplitN(f, "=", 2)
|
||||
if len(split) == 1 {
|
||||
return errors.Errorf("invalid filter %q", f)
|
||||
}
|
||||
networkListOptions.Filters[split[0]] = append(networkListOptions.Filters[split[0]], split[1])
|
||||
var err error
|
||||
networkListOptions.Filters, err = parse.FilterArgumentsIntoFilters(filters)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
responses, err := registry.ContainerEngine().NetworkList(registry.Context(), networkListOptions)
|
||||
if err != nil {
|
||||
return err
|
||||
|
@ -7,11 +7,11 @@ import (
|
||||
"strings"
|
||||
|
||||
"github.com/containers/podman/v3/cmd/podman/common"
|
||||
"github.com/containers/podman/v3/cmd/podman/parse"
|
||||
"github.com/containers/podman/v3/cmd/podman/registry"
|
||||
"github.com/containers/podman/v3/cmd/podman/utils"
|
||||
"github.com/containers/podman/v3/cmd/podman/validate"
|
||||
"github.com/containers/podman/v3/pkg/domain/entities"
|
||||
"github.com/containers/podman/v3/pkg/specgenutil"
|
||||
"github.com/spf13/cobra"
|
||||
"github.com/spf13/pflag"
|
||||
)
|
||||
@ -68,7 +68,7 @@ func networkPrune(cmd *cobra.Command, _ []string) error {
|
||||
return nil
|
||||
}
|
||||
}
|
||||
networkPruneOptions.Filters, err = specgenutil.ParseFilters(filter)
|
||||
networkPruneOptions.Filters, err = parse.FilterArgumentsIntoFilters(filter)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
@ -38,21 +38,6 @@ func ReadPodIDFiles(files []string) ([]string, error) {
|
||||
return ids, nil
|
||||
}
|
||||
|
||||
// ParseFilters transforms one filter format to another and validates input
|
||||
func ParseFilters(filter []string) (map[string][]string, error) {
|
||||
// TODO Remove once filter refactor is finished and url.Values done.
|
||||
filters := map[string][]string{}
|
||||
for _, f := range filter {
|
||||
t := strings.SplitN(f, "=", 2)
|
||||
filters = make(map[string][]string)
|
||||
if len(t) < 2 {
|
||||
return map[string][]string{}, errors.Errorf("filter input must be in the form of filter=value: %s is invalid", f)
|
||||
}
|
||||
filters[t[0]] = append(filters[t[0]], t[1])
|
||||
}
|
||||
return filters, nil
|
||||
}
|
||||
|
||||
// CreateExpose parses user-provided exposed port definitions and converts them
|
||||
// into SpecGen format.
|
||||
// TODO: The SpecGen format should really handle ranges more sanely - we could
|
||||
|
Reference in New Issue
Block a user