mirror of https://github.com/docker/docs.git
Merge pull request #43 from bfirsh/add-start-to-apiserver
This commit is contained in:
commit
a5b1106ffd
|
@ -58,7 +58,28 @@ func getContainersJSON(out beam.Sender, version version.Version, w http.Response
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
return writeJSON(w, 200, names)
|
return writeJSON(w, http.StatusOK, names)
|
||||||
|
}
|
||||||
|
|
||||||
|
func postContainersStart(out beam.Sender, version version.Version, w http.ResponseWriter, r *http.Request, vars map[string]string) error {
|
||||||
|
if vars == nil {
|
||||||
|
return fmt.Errorf("Missing parameter")
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: r.Body
|
||||||
|
|
||||||
|
name := vars["name"]
|
||||||
|
_, containerOut, err := beam.Obj(out).Attach(name)
|
||||||
|
container := beam.Obj(containerOut)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if err := container.Start(); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
w.WriteHeader(http.StatusNoContent)
|
||||||
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func createRouter(out beam.Sender) (*mux.Router, error) {
|
func createRouter(out beam.Sender) (*mux.Router, error) {
|
||||||
|
@ -68,7 +89,9 @@ func createRouter(out beam.Sender) (*mux.Router, error) {
|
||||||
"/_ping": ping,
|
"/_ping": ping,
|
||||||
"/containers/json": getContainersJSON,
|
"/containers/json": getContainersJSON,
|
||||||
},
|
},
|
||||||
"POST": {},
|
"POST": {
|
||||||
|
"/containers/{name:.*}/start": postContainersStart,
|
||||||
|
},
|
||||||
"DELETE": {},
|
"DELETE": {},
|
||||||
"OPTIONS": {},
|
"OPTIONS": {},
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,7 +11,6 @@ func Debug() beam.Sender {
|
||||||
backend := beam.NewServer()
|
backend := beam.NewServer()
|
||||||
backend.OnSpawn(beam.Handler(func(ctx *beam.Message) error {
|
backend.OnSpawn(beam.Handler(func(ctx *beam.Message) error {
|
||||||
instance := beam.Task(func(in beam.Receiver, out beam.Sender) {
|
instance := beam.Task(func(in beam.Receiver, out beam.Sender) {
|
||||||
fmt.Printf("debug backend!")
|
|
||||||
for {
|
for {
|
||||||
msg, err := in.Receive(beam.Ret)
|
msg, err := in.Receive(beam.Ret)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|
|
@ -46,11 +46,16 @@ type forwarder struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (f *forwarder) attach(ctx *beam.Message) error {
|
func (f *forwarder) attach(ctx *beam.Message) error {
|
||||||
|
if ctx.Args[0] == "" {
|
||||||
ctx.Ret.Send(&beam.Message{Verb: beam.Ack, Ret: f.Server})
|
ctx.Ret.Send(&beam.Message{Verb: beam.Ack, Ret: f.Server})
|
||||||
for {
|
for {
|
||||||
time.Sleep(1 * time.Second)
|
time.Sleep(1 * time.Second)
|
||||||
(&beam.Object{ctx.Ret}).Log("forward: heartbeat")
|
(&beam.Object{ctx.Ret}).Log("forward: heartbeat")
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
c := f.newContainer(ctx.Args[0])
|
||||||
|
ctx.Ret.Send(&beam.Message{Verb: beam.Ack, Ret: c})
|
||||||
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue