diff --git a/daemon/daemon.go b/daemon/daemon.go index b111331415..d4a3ddb521 100644 --- a/daemon/daemon.go +++ b/daemon/daemon.go @@ -126,6 +126,9 @@ func (daemon *Daemon) Install(eng *engine.Engine) error { if err := eng.Register("create", daemon.ContainerCreate); err != nil { return err } + if err := eng.Register("stop", daemon.ContainerStop); err != nil { + return err + } return nil } diff --git a/daemon/stop.go b/daemon/stop.go new file mode 100644 index 0000000000..5ce2e1726e --- /dev/null +++ b/daemon/stop.go @@ -0,0 +1,30 @@ +package daemon + +import ( + "github.com/docker/docker/engine" +) + +func (daemon *Daemon) ContainerStop(job *engine.Job) engine.Status { + if len(job.Args) != 1 { + return job.Errorf("Usage: %s CONTAINER\n", job.Name) + } + var ( + name = job.Args[0] + t = 10 + ) + if job.EnvExists("t") { + t = job.GetenvInt("t") + } + if container := daemon.Get(name); container != nil { + if !container.State.IsRunning() { + return job.Errorf("Container already stopped") + } + if err := container.Stop(int(t)); err != nil { + return job.Errorf("Cannot stop container %s: %s\n", name, err) + } + job.Eng.Job("log", "stop", container.ID, daemon.Repositories().ImageName(container.Image)).Run() + } else { + return job.Errorf("No such container: %s\n", name) + } + return engine.StatusOK +} diff --git a/server/container.go b/server/container.go index 64b942e208..13409a4bb5 100644 --- a/server/container.go +++ b/server/container.go @@ -467,31 +467,6 @@ func (srv *Server) ContainerStart(job *engine.Job) engine.Status { return engine.StatusOK } -func (srv *Server) ContainerStop(job *engine.Job) engine.Status { - if len(job.Args) != 1 { - return job.Errorf("Usage: %s CONTAINER\n", job.Name) - } - var ( - name = job.Args[0] - t = 10 - ) - if job.EnvExists("t") { - t = job.GetenvInt("t") - } - if container := srv.daemon.Get(name); container != nil { - if !container.State.IsRunning() { - return job.Errorf("Container already stopped") - } - if err := container.Stop(int(t)); err != nil { - return job.Errorf("Cannot stop container %s: %s\n", name, err) - } - srv.LogEvent("stop", container.ID, srv.daemon.Repositories().ImageName(container.Image)) - } else { - return job.Errorf("No such container: %s\n", name) - } - return engine.StatusOK -} - func (srv *Server) ContainerWait(job *engine.Job) engine.Status { if len(job.Args) != 1 { return job.Errorf("Usage: %s", job.Name) diff --git a/server/init.go b/server/init.go index 9ad5e41359..c543f3ee91 100644 --- a/server/init.go +++ b/server/init.go @@ -86,7 +86,6 @@ func InitServer(job *engine.Job) engine.Status { job.Eng.Hack_SetGlobalVar("httpapi.daemon", srv.daemon) for name, handler := range map[string]engine.Handler{ - "stop": srv.ContainerStop, "restart": srv.ContainerRestart, "start": srv.ContainerStart, "wait": srv.ContainerWait,