diff options
author | Matthew Heon <matthew.heon@gmail.com> | 2018-07-20 13:50:54 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-07-20 13:50:54 -0400 |
commit | 72c82fb79e0a903bc02db989d4c9b6d6f6979b17 (patch) | |
tree | 37f8908d4ac98c241f3bc20cdc16501f784fe21e /cmd/podman/pod_stop.go | |
parent | 1bb6e5f0d8d8f4b21b4468c554e0fcba12e3607d (diff) | |
parent | 17f257140eaecbe39f679d27df85573eb15a7d51 (diff) | |
download | podman-72c82fb79e0a903bc02db989d4c9b6d6f6979b17.tar.gz podman-72c82fb79e0a903bc02db989d4c9b6d6f6979b17.tar.bz2 podman-72c82fb79e0a903bc02db989d4c9b6d6f6979b17.zip |
Merge pull request #1117 from haircommander/pod-start-stop1
Add pod start and stop
Diffstat (limited to 'cmd/podman/pod_stop.go')
-rw-r--r-- | cmd/podman/pod_stop.go | 100 |
1 files changed, 100 insertions, 0 deletions
diff --git a/cmd/podman/pod_stop.go b/cmd/podman/pod_stop.go new file mode 100644 index 000000000..0dcbdaad6 --- /dev/null +++ b/cmd/podman/pod_stop.go @@ -0,0 +1,100 @@ +package main + +import ( + "fmt" + + "github.com/pkg/errors" + "github.com/projectatomic/libpod/cmd/podman/libpodruntime" + "github.com/projectatomic/libpod/libpod" + "github.com/sirupsen/logrus" + "github.com/urfave/cli" +) + +var ( + podStopFlags = []cli.Flag{ + cli.BoolFlag{ + Name: "all, a", + Usage: "stop all running pods", + }, + LatestFlag, + } + podStopDescription = ` + podman pod stop + + Stops one or more running pods. The pod name or ID can be used. +` + + podStopCommand = cli.Command{ + Name: "stop", + Usage: "Stop one or more pods", + Description: podStopDescription, + Flags: podStopFlags, + Action: podStopCmd, + ArgsUsage: "POD-NAME [POD-NAME ...]", + } +) + +func podStopCmd(c *cli.Context) error { + if err := checkMutuallyExclusiveFlags(c); err != nil { + return err + } + + runtime, err := libpodruntime.GetRuntime(c) + if err != nil { + return errors.Wrapf(err, "could not get runtime") + } + defer runtime.Shutdown(false) + + args := c.Args() + var pods []*libpod.Pod + var lastError error + + if c.Bool("all") { + pods, err = runtime.Pods() + if err != nil { + return errors.Wrapf(err, "unable to get running pods") + } + } + + if c.Bool("latest") { + pod, err := runtime.GetLatestPod() + if err != nil { + return errors.Wrapf(err, "unable to get latest pod") + } + pods = append(pods, pod) + } + + for _, i := range args { + pod, err := runtime.LookupPod(i) + if err != nil { + if lastError != nil { + logrus.Errorf("%q", lastError) + } + lastError = errors.Wrapf(err, "unable to find pod %s", i) + continue + } + pods = append(pods, pod) + } + + for _, pod := range pods { + // set cleanup to true to clean mounts and namespaces + ctr_errs, err := pod.Stop(true) + if err != nil { + if lastError != nil { + logrus.Errorf("%q", lastError) + } + lastError = errors.Wrapf(err, "unable to stop pod %q", pod.ID()) + continue + } else if ctr_errs != nil { + for ctr, err := range ctr_errs { + if lastError != nil { + logrus.Errorf("%q", lastError) + } + lastError = errors.Wrapf(err, "unable to stop container %q on pod %q", ctr, pod.ID()) + } + continue + } + fmt.Println(pod.ID()) + } + return lastError +} |