diff options
author | OpenShift Merge Robot <openshift-merge-robot@users.noreply.github.com> | 2021-01-23 11:05:09 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-01-23 11:05:09 +0100 |
commit | 1305f7c47a4c324c3afd873a244fe2315249a25d (patch) | |
tree | 765fe7f70fafbd075bd110ce399225d45fc04597 /cmd/podman | |
parent | 474ba4c3acfc48fecb88814ba48f38e4da15ecae (diff) | |
parent | 6e6a38b4168ed7a528614f6499783243a8668395 (diff) | |
download | podman-1305f7c47a4c324c3afd873a244fe2315249a25d.tar.gz podman-1305f7c47a4c324c3afd873a244fe2315249a25d.tar.bz2 podman-1305f7c47a4c324c3afd873a244fe2315249a25d.zip |
Merge pull request #9067 from Luap99/podman-manifest-exists
podman manifest exists
Diffstat (limited to 'cmd/podman')
-rw-r--r-- | cmd/podman/manifest/exists.go | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/cmd/podman/manifest/exists.go b/cmd/podman/manifest/exists.go new file mode 100644 index 000000000..14e01edab --- /dev/null +++ b/cmd/podman/manifest/exists.go @@ -0,0 +1,39 @@ +package manifest + +import ( + "github.com/containers/podman/v2/cmd/podman/common" + "github.com/containers/podman/v2/cmd/podman/registry" + "github.com/containers/podman/v2/pkg/domain/entities" + "github.com/spf13/cobra" +) + +var ( + existsCmd = &cobra.Command{ + Use: "exists MANIFEST", + Short: "Check if a manifest list exists in local storage", + Long: `If the manifest list exists in local storage, podman manifest exists exits with 0, otherwise the exit code will be 1.`, + Args: cobra.ExactArgs(1), + RunE: exists, + ValidArgsFunction: common.AutocompleteImages, + Example: "podman manifest exists mylist", + } +) + +func init() { + registry.Commands = append(registry.Commands, registry.CliCommand{ + Mode: []entities.EngineMode{entities.ABIMode, entities.TunnelMode}, + Command: existsCmd, + Parent: manifestCmd, + }) +} + +func exists(cmd *cobra.Command, args []string) error { + found, err := registry.ImageEngine().ManifestExists(registry.GetContext(), args[0]) + if err != nil { + return err + } + if !found.Value { + registry.SetExitCode(1) + } + return nil +} |