From d3ad46faf520291037d6803e8547cdafe8b0aff3 Mon Sep 17 00:00:00 2001 From: Kevin Chabowski Date: Tue, 25 Mar 2014 13:31:58 +0100 Subject: Joining a room should work now --- rooms.go | 7 +++++++ websock.go | 33 +++++++++++++++++++++++++++------ 2 files changed, 34 insertions(+), 6 deletions(-) diff --git a/rooms.go b/rooms.go index e7512ee..c732bb6 100644 --- a/rooms.go +++ b/rooms.go @@ -40,6 +40,13 @@ func (r *Room) Broadcast() { } } +func (r *Room) ListBuddies() (buddies []string) { + for nick := range r.Buddies { + buddies = append(buddies, nick) + } + return +} + var rooms = make(map[string]Room) func Join(room, nick string) (*Buddy, *Room, error) { diff --git a/websock.go b/websock.go index a72bf8c..bdb7546 100644 --- a/websock.go +++ b/websock.go @@ -7,10 +7,18 @@ import ( "net/http" ) +type JoinResponse struct { + OK bool `json:"ok"` + Error string `json:"error,omitempty"` + Buddies []string `json:"buddies,omitempty"` +} + func AcceptWebSock(rw http.ResponseWriter, req *http.Request) { vars := mux.Vars(req) - room := vars["chatroom"] + roomname := vars["chatroom"] websocket.Handler(func(ws *websocket.Conn) { + send := func(v interface{}) error { return websocket.JSON.Send(ws, v) } + defer ws.Close() var nick string @@ -18,12 +26,23 @@ func AcceptWebSock(rw http.ResponseWriter, req *http.Request) { return } - if err := Join(room, nick); err != nil { - // TODO: report error to client + buddy, room, err := Join(roomname, nick) + if err != nil { + send(JoinResponse{ + OK: false, + Error: err.Error(), + }) + return + } + defer buddy.Leave() + + if send(JoinResponse{ + OK: true, + Buddies: room.ListBuddies(), + }) != nil { return } - usermsgs := make(chan string) go func() { var s string for { @@ -31,9 +50,11 @@ func AcceptWebSock(rw http.ResponseWriter, req *http.Request) { return } - if s != "" { - usermsgs <- s + if s == "" { + continue } + + // TODO: Broadcast messsage } }() }).ServeHTTP(rw, req) -- cgit v1.2.3-70-g09d2