|
|
package melody
import ( "github.com/gorilla/websocket" "net/http" )
type handleMessageFunc func(*Session, []byte) type handleErrorFunc func(*Session, error) type handleSessionFunc func(*Session) type filterFunc func(*Session) bool
type Melody struct { Config *Config upgrader *websocket.Upgrader messageHandler handleMessageFunc errorHandler handleErrorFunc connectHandler handleSessionFunc disconnectHandler handleSessionFunc hub *hub }
// Returns a new melody instance.
func New() *Melody { upgrader := &websocket.Upgrader{ ReadBufferSize: 1024, WriteBufferSize: 1024, }
hub := newHub()
go hub.run()
return &Melody{ Config: newConfig(), upgrader: upgrader, messageHandler: func(*Session, []byte) {}, errorHandler: func(*Session, error) {}, connectHandler: func(*Session) {}, disconnectHandler: func(*Session) {}, hub: hub, } }
// Fires fn when a session connects.
func (m *Melody) HandleConnect(fn func(*Session)) { m.connectHandler = fn }
// Fires fn when a session disconnects.
func (m *Melody) HandleDisconnect(fn func(*Session)) { m.disconnectHandler = fn }
// Callback when a message comes in.
func (m *Melody) HandleMessage(fn func(*Session, []byte)) { m.messageHandler = fn }
// Fires when a session has an error.
func (m *Melody) HandleError(fn handleErrorFunc) { m.errorHandler = fn }
// Handles a http request and upgrades it to a websocket.
func (m *Melody) HandleRequest(w http.ResponseWriter, r *http.Request) error { conn, err := m.upgrader.Upgrade(w, r, nil)
if err != nil { return err }
session := newSession(m.Config, conn)
m.hub.register <- session
go m.connectHandler(session)
go session.writePump(m.errorHandler)
session.readPump(m.messageHandler, m.errorHandler)
m.hub.unregister <- session
go m.disconnectHandler(session)
return nil }
// Broadcasts a message to all sessions.
func (m *Melody) Broadcast(msg []byte) { message := &envelope{t: websocket.TextMessage, msg: msg} m.hub.broadcast <- message }
// Broadcasts a message to all sessions that fn returns true for.
func (m *Melody) BroadcastFilter(fn func(*Session) bool, msg []byte) { message := &envelope{t: websocket.TextMessage, msg: msg, filter: fn} m.hub.broadcast <- message }
|