diff options
author | OpenShift Merge Robot <openshift-merge-robot@users.noreply.github.com> | 2021-05-20 04:37:19 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-05-20 04:37:19 -0400 |
commit | cb937f4aa89abc3758bcc761839d3044d194b936 (patch) | |
tree | 747dba2f210f1d2586550617452300eac04e835c /cmd/podman/manifest/rm.go | |
parent | 8bc39f4a90a658e92305369cc2628e2a65874506 (diff) | |
parent | 2b89b241461c6baba777894f09a75df17dd05741 (diff) | |
download | podman-cb937f4aa89abc3758bcc761839d3044d194b936.tar.gz podman-cb937f4aa89abc3758bcc761839d3044d194b936.tar.bz2 podman-cb937f4aa89abc3758bcc761839d3044d194b936.zip |
Merge pull request #10235 from rhatdan/manifest
Add support for podman manifest rm command
Diffstat (limited to 'cmd/podman/manifest/rm.go')
-rw-r--r-- | cmd/podman/manifest/rm.go | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/cmd/podman/manifest/rm.go b/cmd/podman/manifest/rm.go new file mode 100644 index 000000000..58c0de886 --- /dev/null +++ b/cmd/podman/manifest/rm.go @@ -0,0 +1,51 @@ +package manifest + +import ( + "context" + "fmt" + + "github.com/containers/podman/v3/cmd/podman/common" + "github.com/containers/podman/v3/cmd/podman/registry" + "github.com/containers/podman/v3/pkg/domain/entities" + "github.com/containers/podman/v3/pkg/errorhandling" + "github.com/spf13/cobra" +) + +var ( + rmCmd = &cobra.Command{ + Use: "rm LIST", + Short: "Remove manifest list or image index from local storage", + Long: "Remove manifest list or image index from local storage.", + RunE: rm, + ValidArgsFunction: common.AutocompleteImages, + Example: `podman manifest rm mylist:v1.11`, + Args: cobra.ExactArgs(1), + DisableFlagsInUseLine: true, + } +) + +func init() { + registry.Commands = append(registry.Commands, registry.CliCommand{ + Mode: []entities.EngineMode{entities.ABIMode, entities.TunnelMode}, + Command: rmCmd, + Parent: manifestCmd, + }) +} + +func rm(cmd *cobra.Command, args []string) error { + report, rmErrors := registry.ImageEngine().ManifestRm(context.Background(), args) + if report != nil { + for _, u := range report.Untagged { + fmt.Println("Untagged: " + u) + } + for _, d := range report.Deleted { + // Make sure an image was deleted (and not just untagged); else print it + if len(d) > 0 { + fmt.Println("Deleted: " + d) + } + } + registry.SetExitCode(report.ExitCode) + } + + return errorhandling.JoinErrors(rmErrors) +} |