summaryrefslogtreecommitdiff
path: root/cmd/podman/manifest/rm.go
diff options
context:
space:
mode:
authorOpenShift Merge Robot <openshift-merge-robot@users.noreply.github.com>2021-05-20 04:37:19 -0400
committerGitHub <noreply@github.com>2021-05-20 04:37:19 -0400
commitcb937f4aa89abc3758bcc761839d3044d194b936 (patch)
tree747dba2f210f1d2586550617452300eac04e835c /cmd/podman/manifest/rm.go
parent8bc39f4a90a658e92305369cc2628e2a65874506 (diff)
parent2b89b241461c6baba777894f09a75df17dd05741 (diff)
downloadpodman-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.go51
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)
+}