summaryrefslogtreecommitdiff
path: root/libkpod/stop.go
diff options
context:
space:
mode:
authorMatthew Heon <matthew.heon@gmail.com>2017-11-01 14:38:21 -0400
committerGitHub <noreply@github.com>2017-11-01 14:38:21 -0400
commitf5019df3f5da9030ce21e5c8ad3d3921a6585e7f (patch)
tree05412dcc190ca026dbe51a4ef72bb91ff646e7c6 /libkpod/stop.go
parent2b74391cd5281f6fdf391ff8ad50fd1490f6bf89 (diff)
parenteab0737f1189a7b88f0a37a6b894ca4345b6853f (diff)
downloadpodman-f5019df3f5da9030ce21e5c8ad3d3921a6585e7f.tar.gz
podman-f5019df3f5da9030ce21e5c8ad3d3921a6585e7f.tar.bz2
podman-f5019df3f5da9030ce21e5c8ad3d3921a6585e7f.zip
Merge pull request #1 from mheon/master
Initial checkin
Diffstat (limited to 'libkpod/stop.go')
-rw-r--r--libkpod/stop.go36
1 files changed, 36 insertions, 0 deletions
diff --git a/libkpod/stop.go b/libkpod/stop.go
new file mode 100644
index 000000000..5ab974634
--- /dev/null
+++ b/libkpod/stop.go
@@ -0,0 +1,36 @@
+package libkpod
+
+import (
+ "github.com/projectatomic/libpod/oci"
+ "github.com/pkg/errors"
+ "golang.org/x/net/context"
+)
+
+// ContainerStop stops a running container with a grace period (i.e., timeout).
+func (c *ContainerServer) ContainerStop(ctx context.Context, container string, timeout int64) (string, error) {
+ ctr, err := c.LookupContainer(container)
+ if err != nil {
+ return "", errors.Wrapf(err, "failed to find container %s", container)
+ }
+ ctrID := ctr.ID()
+
+ cStatus := c.runtime.ContainerStatus(ctr)
+ switch cStatus.Status {
+
+ case oci.ContainerStatePaused:
+ return "", errors.Errorf("cannot stop paused container %s", ctrID)
+ default:
+ if cStatus.Status != oci.ContainerStateStopped {
+ if err := c.runtime.StopContainer(ctx, ctr, timeout); err != nil {
+ return "", errors.Wrapf(err, "failed to stop container %s", ctrID)
+ }
+ if err := c.storageRuntimeServer.StopContainer(ctrID); err != nil {
+ return "", errors.Wrapf(err, "failed to unmount container %s", ctrID)
+ }
+ }
+ }
+
+ c.ContainerStateToDisk(ctr)
+
+ return ctrID, nil
+}