1
0
Fork 0
burlesque/server.go

94 lines
1.8 KiB
Go

package main
import (
"encoding/json"
"io/ioutil"
"net/http"
"runtime"
"strings"
)
func StatusHandler(w http.ResponseWriter, r *http.Request) {
info := make(map[string]map[string]uint)
for _, q := range queues {
info[q.Name] = map[string]uint{
"messages": q.Counter.Distance(),
"subscriptions": 0,
}
}
for _, r := range pool {
for _, q := range r.Queues {
info[q]["subscriptions"]++
}
}
infoJson, _ := json.Marshal(info)
w.Write(infoJson)
}
func DebugHandler(w http.ResponseWriter, r *http.Request) {
info := make(map[string]int)
info["goroutines"] = runtime.NumGoroutine()
infoJson, _ := json.Marshal(info)
w.Write(infoJson)
}
func PublishHandler(w http.ResponseWriter, r *http.Request) {
defer r.Body.Close()
msg, _ := ioutil.ReadAll(r.Body)
if len(msg) == 0 {
msg = Message(r.FormValue("msg"))
}
queueName := r.FormValue("queue")
go Register(queueName, msg)
log.Println("Published message of", len(msg), "bytes to queue", queueName)
w.Write([]byte("OK"))
}
func SubscriptionHandler(w http.ResponseWriter, r *http.Request) {
rch := make(chan *Response)
req := &Request{
Queues: strings.Split(r.FormValue("queues"), ","),
Callback: func(r *Response) {
rch <- r
},
}
go Process(req)
disconnected := w.(http.CloseNotifier).CloseNotify()
finished := make(chan bool)
go func() {
select {
case <-disconnected:
rch <- nil
case <-finished:
break
}
Purge(req)
}()
res := <-rch
if res == nil {
return
}
w.Header().Set("Queue", res.Queue)
w.Write(res.Message)
log.Println("Recieved message of", len(res.Message), "bytes from queue", res.Queue)
finished <- true
}
func SetupServer() {
http.HandleFunc("/status", StatusHandler)
http.HandleFunc("/debug", DebugHandler)
http.HandleFunc("/publish", PublishHandler)
http.HandleFunc("/subscribe", SubscriptionHandler)
}