summaryrefslogtreecommitdiff
path: root/cmd/podman/cleanup.go
diff options
context:
space:
mode:
Diffstat (limited to 'cmd/podman/cleanup.go')
-rw-r--r--cmd/podman/cleanup.go79
1 files changed, 49 insertions, 30 deletions
diff --git a/cmd/podman/cleanup.go b/cmd/podman/cleanup.go
index bc4af9f50..d68255aa2 100644
--- a/cmd/podman/cleanup.go
+++ b/cmd/podman/cleanup.go
@@ -4,60 +4,79 @@ import (
"fmt"
"os"
+ "github.com/containers/libpod/cmd/podman/cliconfig"
"github.com/containers/libpod/cmd/podman/libpodruntime"
"github.com/pkg/errors"
- "github.com/urfave/cli"
+ "github.com/spf13/cobra"
)
var (
- cleanupFlags = []cli.Flag{
- cli.BoolFlag{
- Name: "all, a",
- Usage: "Cleans up all containers",
- },
- LatestFlag,
- }
+ cleanupCommand cliconfig.CleanupValues
cleanupDescription = `
podman container cleanup
Cleans up mount points and network stacks on one or more containers from the host. The container name or ID can be used. This command is used internally when running containers, but can also be used if container cleanup has failed when a container exits.
`
- cleanupCommand = cli.Command{
- Name: "cleanup",
- Usage: "Cleanup network and mountpoints of one or more containers",
- Description: cleanupDescription,
- Flags: sortFlags(cleanupFlags),
- Action: cleanupCmd,
- ArgsUsage: "CONTAINER-NAME [CONTAINER-NAME ...]",
- OnUsageError: usageErrorHandler,
+ _cleanupCommand = &cobra.Command{
+ Use: "cleanup",
+ Short: "Cleanup network and mountpoints of one or more containers",
+ Long: cleanupDescription,
+ RunE: func(cmd *cobra.Command, args []string) error {
+ cleanupCommand.InputArgs = args
+ cleanupCommand.GlobalFlags = MainGlobalOpts
+ return cleanupCmd(&cleanupCommand)
+ },
+ Args: func(cmd *cobra.Command, args []string) error {
+ return checkAllAndLatest(cmd, args, false)
+ },
+ Example: `podman container cleanup --latest
+ podman container cleanup ctrID1 ctrID2 ctrID3
+ podman container cleanup --all`,
}
)
-func cleanupCmd(c *cli.Context) error {
- if err := validateFlags(c, cleanupFlags); err != nil {
- return err
- }
- runtime, err := libpodruntime.GetRuntime(c)
+func init() {
+ cleanupCommand.Command = _cleanupCommand
+ cleanupCommand.SetUsageTemplate(UsageTemplate())
+ flags := cleanupCommand.Flags()
+
+ flags.BoolVarP(&cleanupCommand.All, "all", "a", false, "Cleans up all containers")
+ flags.BoolVarP(&cleanupCommand.Latest, "latest", "l", false, "Act on the latest container podman is aware of")
+ flags.BoolVar(&cleanupCommand.Remove, "rm", false, "After cleanup, remove the container entirely")
+ markFlagHiddenForRemoteClient("latest", flags)
+}
+
+func cleanupCmd(c *cliconfig.CleanupValues) error {
+ runtime, err := libpodruntime.GetRuntime(&c.PodmanCommand)
if err != nil {
return errors.Wrapf(err, "could not get runtime")
}
defer runtime.Shutdown(false)
- if err := checkAllAndLatest(c); err != nil {
- return err
- }
-
- cleanupContainers, lastError := getAllOrLatestContainers(c, runtime, -1, "all")
+ cleanupContainers, lastError := getAllOrLatestContainers(&c.PodmanCommand, runtime, -1, "all")
ctx := getContext()
for _, ctr := range cleanupContainers {
- if err = ctr.Cleanup(ctx); err != nil {
- if lastError != nil {
- fmt.Fprintln(os.Stderr, lastError)
+ hadError := false
+ if c.Remove {
+ if err := runtime.RemoveContainer(ctx, ctr, false, false); err != nil {
+ if lastError != nil {
+ fmt.Fprintln(os.Stderr, lastError)
+ }
+ lastError = errors.Wrapf(err, "failed to cleanup and remove container %v", ctr.ID())
+ hadError = true
}
- lastError = errors.Wrapf(err, "failed to cleanup container %v", ctr.ID())
} else {
+ if err := ctr.Cleanup(ctx); err != nil {
+ if lastError != nil {
+ fmt.Fprintln(os.Stderr, lastError)
+ }
+ lastError = errors.Wrapf(err, "failed to cleanup container %v", ctr.ID())
+ hadError = true
+ }
+ }
+ if !hadError {
fmt.Println(ctr.ID())
}
}