2019-06-02 16:49:45 +02:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"log"
|
|
|
|
|
|
|
|
"github.com/kataras/iris"
|
|
|
|
"github.com/kataras/iris/websocket"
|
|
|
|
)
|
|
|
|
|
|
|
|
const namespace = "default"
|
|
|
|
|
|
|
|
// if namespace is empty then simply websocket.Events{...} can be used instead.
|
|
|
|
var serverEvents = websocket.Namespaces{
|
|
|
|
namespace: websocket.Events{
|
2019-06-02 17:27:51 +02:00
|
|
|
websocket.OnNamespaceConnected: func(nsConn *websocket.NSConn, msg websocket.Message) error {
|
|
|
|
log.Printf("[%s] connected to namespace [%s] with IP [%s]",
|
|
|
|
nsConn, msg.Namespace,
|
|
|
|
// with `GetContext` you can retrieve the Iris' `Context`, alternatively
|
|
|
|
// you can use the `nsConn.Conn.Socket().Request()` to get the raw `*http.Request`.
|
|
|
|
websocket.GetContext(nsConn.Conn).RemoteAddr())
|
2019-06-02 16:49:45 +02:00
|
|
|
return nil
|
|
|
|
},
|
2019-06-02 17:27:51 +02:00
|
|
|
websocket.OnNamespaceDisconnect: func(nsConn *websocket.NSConn, msg websocket.Message) error {
|
|
|
|
log.Printf("[%s] disconnected from namespace [%s]", nsConn, msg.Namespace)
|
2019-06-02 16:49:45 +02:00
|
|
|
return nil
|
|
|
|
},
|
2019-06-02 17:27:51 +02:00
|
|
|
"chat": func(nsConn *websocket.NSConn, msg websocket.Message) error {
|
|
|
|
// room.String() returns -> NSConn.String() returns -> Conn.String() returns -> Conn.ID()
|
|
|
|
log.Printf("[%s] sent: %s", nsConn, string(msg.Body))
|
2019-06-02 16:49:45 +02:00
|
|
|
|
|
|
|
// Write message back to the client message owner with:
|
2019-06-02 17:27:51 +02:00
|
|
|
// nsConn.Emit("chat", msg)
|
2019-06-02 16:49:45 +02:00
|
|
|
// Write message to all except this client with:
|
2019-06-02 17:27:51 +02:00
|
|
|
nsConn.Conn.Server().Broadcast(nsConn, msg)
|
2019-06-02 16:49:45 +02:00
|
|
|
return nil
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
app := iris.New()
|
|
|
|
websocketServer := websocket.New(
|
2019-06-13 11:15:01 +02:00
|
|
|
websocket.DefaultGorillaUpgrader, /* DefaultGobwasUpgrader can be used too. */
|
2019-06-02 16:49:45 +02:00
|
|
|
serverEvents)
|
|
|
|
|
|
|
|
// serves the endpoint of ws://localhost:8080/echo
|
|
|
|
app.Get("/echo", websocket.Handler(websocketServer))
|
|
|
|
|
|
|
|
// serves the browser-based websocket client.
|
|
|
|
app.Get("/", func(ctx iris.Context) {
|
|
|
|
ctx.ServeFile("./browser/index.html", false)
|
|
|
|
})
|
|
|
|
|
|
|
|
// serves the npm browser websocket client usage example.
|
|
|
|
app.StaticWeb("/browserify", "./browserify")
|
|
|
|
|
2019-06-13 11:15:01 +02:00
|
|
|
app.Run(iris.Addr(":8080"), iris.WithoutServerError(iris.ErrServerClosed))
|
2019-06-02 16:49:45 +02:00
|
|
|
}
|