2014-07-31 16:40:15 -04:00
|
|
|
package daemon
|
|
|
|
|
|
|
|
import (
|
2015-03-25 03:44:12 -04:00
|
|
|
"fmt"
|
|
|
|
|
2014-07-31 16:40:15 -04:00
|
|
|
"github.com/docker/docker/engine"
|
|
|
|
)
|
|
|
|
|
2015-03-25 03:44:12 -04:00
|
|
|
func (daemon *Daemon) ContainerStop(job *engine.Job) error {
|
2014-07-31 16:40:15 -04:00
|
|
|
if len(job.Args) != 1 {
|
2015-03-25 03:44:12 -04:00
|
|
|
return fmt.Errorf("Usage: %s CONTAINER\n", job.Name)
|
2014-07-31 16:40:15 -04:00
|
|
|
}
|
|
|
|
var (
|
|
|
|
name = job.Args[0]
|
|
|
|
t = 10
|
|
|
|
)
|
|
|
|
if job.EnvExists("t") {
|
|
|
|
t = job.GetenvInt("t")
|
|
|
|
}
|
2014-12-16 18:06:35 -05:00
|
|
|
container, err := daemon.Get(name)
|
|
|
|
if err != nil {
|
2015-03-25 03:44:12 -04:00
|
|
|
return err
|
2014-07-31 16:40:15 -04:00
|
|
|
}
|
2014-12-16 18:06:35 -05:00
|
|
|
if !container.IsRunning() {
|
2015-03-25 03:44:12 -04:00
|
|
|
return fmt.Errorf("Container already stopped")
|
2014-12-16 18:06:35 -05:00
|
|
|
}
|
|
|
|
if err := container.Stop(int(t)); err != nil {
|
2015-03-25 03:44:12 -04:00
|
|
|
return fmt.Errorf("Cannot stop container %s: %s\n", name, err)
|
2014-12-16 18:06:35 -05:00
|
|
|
}
|
|
|
|
container.LogEvent("stop")
|
2015-03-25 03:44:12 -04:00
|
|
|
return nil
|
2014-07-31 16:40:15 -04:00
|
|
|
}
|