1
0
Fork 0
burlesque/server/server.go

115 lines
2.2 KiB
Go
Raw Normal View History

2014-09-24 09:49:27 +00:00
package server
2014-07-10 12:19:39 +00:00
import (
2014-09-11 19:13:53 +00:00
"encoding/json"
2014-07-29 06:57:07 +00:00
"fmt"
2014-07-10 12:19:39 +00:00
"io/ioutil"
"net/http"
"strings"
2014-09-11 10:27:55 +00:00
"github.com/KosyanMedia/burlesque/hub"
2014-07-10 12:19:39 +00:00
)
2014-09-24 09:49:27 +00:00
type (
Server struct {
port int
hub *hub.Hub
}
)
func New(port int, h *hub.Hub) *Server {
s := Server{
port: port,
hub: h,
}
http.HandleFunc("/status", s.statusHandler)
http.HandleFunc("/debug", s.debugHandler)
http.HandleFunc("/publish", s.pubHandler)
http.HandleFunc("/subscribe", s.subHandler)
return &s
}
2014-09-11 10:27:55 +00:00
2014-09-24 09:49:27 +00:00
func (s *Server) Start() {
port := fmt.Sprintf(":%d", s.port)
2014-09-11 19:00:19 +00:00
if err := http.ListenAndServe(port, nil); err != nil {
2014-09-11 10:30:15 +00:00
panic(err)
2014-07-29 06:56:46 +00:00
}
}
2014-09-24 09:49:27 +00:00
func (s *Server) statusHandler(w http.ResponseWriter, r *http.Request) {
info := s.hub.Info()
2014-09-11 19:13:53 +00:00
jsn, _ := json.Marshal(info)
w.Write(jsn)
2014-07-10 12:19:39 +00:00
}
2014-09-24 09:49:27 +00:00
func (s *Server) debugHandler(w http.ResponseWriter, r *http.Request) {
2014-09-11 10:27:55 +00:00
// info := make(map[string]interface{})
// info["version"] = version
// info["goroutines"] = runtime.NumGoroutine()
// s, err := storage.Status()
// if err != nil {
// alert(err, "Failed to get Kyoto Cabinet status")
// }
// s = s[:len(s)-1] // Removing trailing new line
// ks := make(map[string]interface{})
// tokens := strings.Split(s, "\n")
// for _, t := range tokens {
// tt := strings.Split(t, "\t")
// num, err := strconv.Atoi(tt[1])
// if err != nil {
// ks[tt[0]] = tt[1]
// } else {
// ks[tt[0]] = num
// }
// }
// info["kyoto_cabinet"] = ks
// jsn, _ := json.Marshal(info)
// w.Write(jsn)
2014-07-10 12:19:39 +00:00
}
2014-09-24 09:49:27 +00:00
func (s *Server) pubHandler(w http.ResponseWriter, r *http.Request) {
2014-07-10 12:19:39 +00:00
defer r.Body.Close()
msg, _ := ioutil.ReadAll(r.Body)
if len(msg) == 0 {
2014-09-11 10:27:55 +00:00
msg = []byte(r.FormValue("msg"))
2014-07-10 12:19:39 +00:00
}
2014-09-11 10:27:55 +00:00
queue := r.FormValue("queue")
2014-07-10 12:19:39 +00:00
2014-09-24 09:49:27 +00:00
if ok := s.hub.Pub(queue, msg); ok {
2014-07-16 17:47:08 +00:00
w.Write([]byte("OK"))
} else {
http.Error(w, "FAIL", 500)
}
2014-07-10 12:19:39 +00:00
}
2014-09-24 09:49:27 +00:00
func (s *Server) subHandler(w http.ResponseWriter, r *http.Request) {
2014-09-11 10:27:55 +00:00
result := make(chan hub.Result)
queues := strings.Split(r.FormValue("queues"), ",")
2014-09-11 19:00:19 +00:00
2014-09-11 10:27:55 +00:00
sub := hub.NewSubscription(queues, result)
2014-09-11 19:00:19 +00:00
defer sub.Close()
2014-07-10 12:19:39 +00:00
2014-09-11 10:27:55 +00:00
finished := make(chan struct{})
2014-09-11 19:00:19 +00:00
defer close(finished)
disconnected := w.(http.CloseNotifier).CloseNotify()
2014-07-10 12:19:39 +00:00
go func() {
select {
case <-disconnected:
2014-09-11 10:27:55 +00:00
sub.Close()
2014-07-10 12:19:39 +00:00
case <-finished:
}
}()
2014-09-24 09:49:27 +00:00
go s.hub.Sub(sub)
2014-09-11 10:27:55 +00:00
res := <-result
2014-07-10 12:19:39 +00:00
2014-09-11 10:27:55 +00:00
w.Header().Set("Queue", res.Queue)
w.Write(res.Message)
2014-07-10 12:19:39 +00:00
}