First try on using standard websocket and removing socket.io from the

middle
This commit is contained in:
Jonathan Leibiusky (@xetorthio)
2017-10-19 13:49:14 +02:00
parent 82b95ee112
commit b1406f4ea8
4 changed files with 177 additions and 31 deletions

View File

@@ -9,7 +9,6 @@ import (
"golang.org/x/crypto/acme/autocert"
"github.com/googollee/go-socket.io"
gh "github.com/gorilla/handlers"
"github.com/gorilla/mux"
"github.com/play-with-docker/play-with-docker/config"
@@ -21,7 +20,6 @@ import (
var core pwd.PWDApi
var e event.EventApi
var ws *socketio.Server
type HandlerExtender func(h *mux.Router)
@@ -31,15 +29,6 @@ func Bootstrap(c pwd.PWDApi, ev event.EventApi) {
}
func Register(extend HandlerExtender) {
server, err := socketio.NewServer(nil)
if err != nil {
log.Fatal(err)
}
server.On("connection", WS)
server.On("error", WSError)
RegisterEvents(server)
r := mux.NewRouter()
corsRouter := mux.NewRouter()
@@ -71,7 +60,7 @@ func Register(extend HandlerExtender) {
http.ServeFile(rw, r, "www/sdk.js")
})
corsRouter.Handle("/sessions/{sessionId}/ws/", server)
corsRouter.HandleFunc("/sessions/{sessionId}/ws/", WSH)
r.Handle("/metrics", promhttp.Handler())
// Generic routes
@@ -129,12 +118,3 @@ func Register(extend HandlerExtender) {
}
}
func RegisterEvents(s *socketio.Server) {
ws = s
e.OnAny(broadcastEvent)
}
func broadcastEvent(eventType event.EventType, sessionId string, args ...interface{}) {
ws.BroadcastTo(sessionId, eventType.String(), args...)
}