diff options
author | baude <bbaude@redhat.com> | 2019-02-20 15:02:18 -0600 |
---|---|---|
committer | baude <bbaude@redhat.com> | 2019-02-21 08:40:42 -0600 |
commit | e91ec38a70f4755d06972a0b65edd1f2e5366581 (patch) | |
tree | 4f5792f6662ebe43bee3331354c13585351eb81e /libpod/adapter/pods_remote.go | |
parent | 4934bf23272f185fa9f08d0ba890c5a0eb4ed14d (diff) | |
download | podman-e91ec38a70f4755d06972a0b65edd1f2e5366581.tar.gz podman-e91ec38a70f4755d06972a0b65edd1f2e5366581.tar.bz2 podman-e91ec38a70f4755d06972a0b65edd1f2e5366581.zip |
enable podman-remote pod rm
add the ability to delete a pod from the remote client.
Signed-off-by: baude <bbaude@redhat.com>
Diffstat (limited to 'libpod/adapter/pods_remote.go')
-rw-r--r-- | libpod/adapter/pods_remote.go | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/libpod/adapter/pods_remote.go b/libpod/adapter/pods_remote.go new file mode 100644 index 000000000..3fb147f48 --- /dev/null +++ b/libpod/adapter/pods_remote.go @@ -0,0 +1,44 @@ +// +build remoteclient + +package adapter + +import ( + "context" + + "github.com/containers/libpod/cmd/podman/cliconfig" + "github.com/containers/libpod/cmd/podman/varlink" + "github.com/containers/libpod/libpod" +) + +// Pod ... +type Pod struct { + remotepod +} + +type remotepod struct { + config *libpod.PodConfig + state *libpod.PodInspectState + Runtime *LocalRuntime +} + +func (r *LocalRuntime) RemovePods(ctx context.Context, cli *cliconfig.PodRmValues) ([]string, []error) { + var ( + rmErrs []error + rmPods []string + ) + podIDs, err := iopodman.GetPodsByContext().Call(r.Conn, cli.All, cli.Latest, cli.InputArgs) + if err != nil { + rmErrs = append(rmErrs, err) + return nil, rmErrs + } + + for _, p := range podIDs { + reply, err := iopodman.RemovePod().Call(r.Conn, p, cli.Force) + if err != nil { + rmErrs = append(rmErrs, err) + } else { + rmPods = append(rmPods, reply) + } + } + return rmPods, rmErrs +} |