diff options
author | OpenShift Merge Robot <openshift-merge-robot@users.noreply.github.com> | 2021-11-08 16:50:59 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-11-08 16:50:59 +0100 |
commit | 22ef488d246effddbb3f390dd3fd048dc0f5fe82 (patch) | |
tree | 40bd3e05c649ecae4bcf02ab17c43415294efd12 /cmd/podman/system | |
parent | c9ba1fb7d4565365ee4ad4f852cce13f2072574e (diff) | |
parent | 338eb9d75e217dc0c38d51c33967e49e5c0daae4 (diff) | |
download | podman-22ef488d246effddbb3f390dd3fd048dc0f5fe82.tar.gz podman-22ef488d246effddbb3f390dd3fd048dc0f5fe82.tar.bz2 podman-22ef488d246effddbb3f390dd3fd048dc0f5fe82.zip |
Merge pull request #12213 from flouthoc/system-connection-rm-all
system: Adds support for removing all named destination via `--all`
Diffstat (limited to 'cmd/podman/system')
-rw-r--r-- | cmd/podman/system/connection/remove.go | 27 |
1 files changed, 24 insertions, 3 deletions
diff --git a/cmd/podman/system/connection/remove.go b/cmd/podman/system/connection/remove.go index 73bae4994..ffbea76c5 100644 --- a/cmd/podman/system/connection/remove.go +++ b/cmd/podman/system/connection/remove.go @@ -5,14 +5,14 @@ import ( "github.com/containers/podman/v3/cmd/podman/common" "github.com/containers/podman/v3/cmd/podman/registry" "github.com/containers/podman/v3/cmd/podman/system" + "github.com/pkg/errors" "github.com/spf13/cobra" ) var ( // Skip creating engines since this command will obtain connection information to said engines rmCmd = &cobra.Command{ - Use: "remove NAME", - Args: cobra.ExactArgs(1), + Use: "remove [options] NAME", Aliases: []string{"rm"}, Long: `Delete named destination from podman configuration`, Short: "Delete named destination", @@ -21,6 +21,10 @@ var ( Example: `podman system connection remove devl podman system connection rm devl`, } + + rmOpts = struct { + All bool + }{} ) func init() { @@ -28,14 +32,31 @@ func init() { Command: rmCmd, Parent: system.ConnectionCmd, }) + + flags := rmCmd.Flags() + flags.BoolVarP(&rmOpts.All, "all", "a", false, "Remove all connections") } -func rm(_ *cobra.Command, args []string) error { +func rm(cmd *cobra.Command, args []string) error { cfg, err := config.ReadCustomConfig() if err != nil { return err } + if rmOpts.All { + if cfg.Engine.ServiceDestinations != nil { + for k := range cfg.Engine.ServiceDestinations { + delete(cfg.Engine.ServiceDestinations, k) + } + } + cfg.Engine.ActiveService = "" + return cfg.Write() + } + + if len(args) != 1 { + return errors.New("accepts 1 arg(s), received 0") + } + if cfg.Engine.ServiceDestinations != nil { delete(cfg.Engine.ServiceDestinations, args[0]) } |