2019-06-02 16:49:45 +02:00
|
|
|
// +build go1.9
|
|
|
|
|
|
|
|
package websocket
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/kataras/neffos"
|
2019-06-15 13:07:35 +02:00
|
|
|
"github.com/kataras/neffos/gobwas"
|
|
|
|
"github.com/kataras/neffos/gorilla"
|
2019-06-02 16:49:45 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
type (
|
2019-06-15 13:07:35 +02:00
|
|
|
// Dialer is the definition type of a dialer, gorilla or gobwas or custom.
|
|
|
|
// It is the second parameter of the `Dial` function.
|
|
|
|
Dialer = neffos.Dialer
|
|
|
|
// GorillaDialerOptions is just an alias for the `gobwas/ws.Dialer` struct type.
|
|
|
|
GorillaDialerOptions = gorilla.Options
|
|
|
|
// GobwasDialerOptions is just an alias for the `gorilla/websocket.Dialer` struct type.
|
|
|
|
GobwasDialerOptions = gobwas.Options
|
|
|
|
|
2019-06-02 16:49:45 +02:00
|
|
|
// Conn describes the main websocket connection's functionality.
|
|
|
|
// Its `Connection` will return a new `NSConn` instance.
|
|
|
|
// Each connection can connect to one or more declared namespaces.
|
|
|
|
// Each `NSConn` can join to multiple rooms.
|
|
|
|
Conn = neffos.Conn
|
2019-06-15 13:07:35 +02:00
|
|
|
// NSConn describes a connection connected to a specific namespace,
|
2019-06-02 16:49:45 +02:00
|
|
|
// it emits with the `Message.Namespace` filled and it can join to multiple rooms.
|
|
|
|
// A single `Conn` can be connected to one or more namespaces,
|
|
|
|
// each connected namespace is described by this structure.
|
|
|
|
NSConn = neffos.NSConn
|
|
|
|
// Room describes a connected connection to a room,
|
|
|
|
// emits messages with the `Message.Room` filled to the specific room
|
|
|
|
// and `Message.Namespace` to the underline `NSConn`'s namespace.
|
|
|
|
Room = neffos.Room
|
|
|
|
// CloseError can be used to send and close a remote connection in the event callback's return statement.
|
|
|
|
CloseError = neffos.CloseError
|
|
|
|
|
|
|
|
// MessageHandlerFunc is the definition type of the events' callback.
|
|
|
|
// Its error can be written to the other side on specific events,
|
|
|
|
// i.e on `OnNamespaceConnect` it will abort a remote namespace connection.
|
|
|
|
// See examples for more.
|
|
|
|
MessageHandlerFunc = neffos.MessageHandlerFunc
|
2019-07-09 11:16:19 +02:00
|
|
|
// ConnHandler is the interface which namespaces and events can be retrieved through.
|
|
|
|
ConnHandler = neffos.ConnHandler
|
2019-06-02 16:49:45 +02:00
|
|
|
// Events completes the `ConnHandler` interface.
|
|
|
|
// It is a map which its key is the event name
|
|
|
|
// and its value the event's callback.
|
|
|
|
//
|
|
|
|
// Events type completes the `ConnHandler` itself therefore,
|
|
|
|
// can be used as standalone value on the `New` and `Dial` functions
|
|
|
|
// to register events on empty namespace as well.
|
|
|
|
//
|
|
|
|
// See `Namespaces`, `New` and `Dial` too.
|
|
|
|
Events = neffos.Events
|
|
|
|
// Namespaces completes the `ConnHandler` interface.
|
|
|
|
// Can be used to register one or more namespaces on the `New` and `Dial` functions.
|
|
|
|
// The key is the namespace literal and the value is the `Events`,
|
|
|
|
// a map with event names and their callbacks.
|
|
|
|
//
|
|
|
|
// See `WithTimeout`, `New` and `Dial` too.
|
|
|
|
Namespaces = neffos.Namespaces
|
|
|
|
// WithTimeout completes the `ConnHandler` interface.
|
|
|
|
// Can be used to register namespaces and events or just events on an empty namespace
|
|
|
|
// with Read and Write timeouts.
|
|
|
|
//
|
|
|
|
// See `New` and `Dial`.
|
|
|
|
WithTimeout = neffos.WithTimeout
|
2019-07-09 11:16:19 +02:00
|
|
|
// Struct completes the `ConnHandler` interface.
|
|
|
|
// It uses a structure to register a specific namespace and its events.
|
|
|
|
Struct = neffos.Struct
|
|
|
|
// StructInjector can be used to customize the value creation that can is used on serving events.
|
|
|
|
StructInjector = neffos.StructInjector
|
2019-06-02 16:49:45 +02:00
|
|
|
// The Message is the structure which describes the incoming and outcoming data.
|
|
|
|
// Emitter's "body" argument is the `Message.Body` field.
|
|
|
|
// Emitter's return non-nil error is the `Message.Err` field.
|
|
|
|
// If native message sent then the `Message.Body` is filled with the body and
|
|
|
|
// when incoming native message then the `Message.Event` is the `OnNativeMessage`,
|
|
|
|
// native messages are allowed only when an empty namespace("") and its `OnNativeMessage` callback are present.
|
|
|
|
Message = neffos.Message
|
|
|
|
)
|