Documentation ¶
Index ¶
- Constants
- Variables
- type Acceptor
- type Callable
- type Callback
- type Client
- type Conn
- type Dialer
- type MessageType
- type Packet
- type PacketReader
- type PacketType
- type PacketWriter
- type Parameters
- type Payload
- type Server
- func (s *Server) Close() (err error)
- func (s Server) Get(id string) (ß *Socket, b bool)
- func (s Server) NewSession(conn Conn, readTimeout, writeTimeout time.Duration) *Socket
- func (e Server) On(event event, callable Callable)
- func (s Server) Remove(id string)
- func (s *Server) ServeHTTP(w http.ResponseWriter, r *http.Request)
- type Socket
- func (s *Socket) CheckPaused()
- func (s *Socket) Close() (err error)
- func (s *Socket) Emit(event event, msgType MessageType, args interface{}) (err error)
- func (s *Socket) Read() (p *Packet, err error)
- func (s *Socket) Send(args interface{}) (err error)
- func (s *Socket) ServeHTTP(w http.ResponseWriter, r *http.Request)
- func (s *Socket) Sid() string
- type Transport
Examples ¶
Constants ¶
const ( // EventOpen is fired upon successful connection. EventOpen event = "open" // EventMessage is fired when data is received from the server. EventMessage event = "message" // EventClose is fired upon disconnection. In compliance with the WebSocket API spec, this event may be fired even if the open event does not occur (i.e. due to connection error or close()). EventClose event = "close" // EventError is fired when an error occurs. EventError event = "error" // EventUpgrade is fired upon upgrade success, after the new transport is set EventUpgrade event = "upgrade" // EventPing is fired upon flushing a ping packet (ie: actual packet write out) EventPing event = "ping" // EventPong is fired upon receiving a pong packet. EventPong event = "pong" )
const (
// Version is engine.io-protocol version
Version = "3"
)
Variables ¶
var ( // ErrPollingConnClosed implies connection closed; fatal. ErrPollingConnClosed = errors.New("polling connection closed") // ErrPollingConnReadTimeout implies connection read timeout; fatal. ErrPollingConnReadTimeout = errors.New("polling connection read timeout") // ErrPollingConnWriteTimeout implies connection write timeout; fatal. ErrPollingConnWriteTimeout = errors.New("polling connection write timeout") // ErrPollingConnPaused implies connection paused; temperary. ErrPollingConnPaused = errors.New("polling connection paused") // ErrPollingRequestCanceled implies request canceled; temperary. ErrPollingRequestCanceled = errors.New("polling request canceled") )
var ( // ErrInvalidPayload indicates received data is invalid or unrecognized when decoding payload ErrInvalidPayload = errors.New("invalid payload") )
var ( // ErrPauseNotSupported indicates that a connection does not support PAUSE (e.g. websocket) ErrPauseNotSupported = errors.New("transport pause unsupported") )
Functions ¶
This section is empty.
Types ¶
type Acceptor ¶
Acceptor accepts a connecting requests and creates a connection instance (server side)
var PollingAcceptor Acceptor = &pollingAcceptor{}
PollingAcceptor is an Acceptor instance for polling
type Callable ¶
type Callable interface {
Call(so *Socket, typ MessageType, data []byte)
}
Callable is event handle to be called when event occurs
type Callback ¶
type Callback func(so *Socket, typ MessageType, data []byte)
Callback is a Callable func, default event handler
type Client ¶
type Client struct { *Socket // contains filtered or unexported fields }
Client is engine.io client
func Dial ¶
Dial connects to a engine.io server represented by `rawurl` and create Client instance on success.
Example ¶
c, err := Dial("ws://localhost:8080/engine.io/", nil, WebsocketTransport) if err != nil { log.Printf("dial err=%s", err) return } defer c.Close() log.Printf("id=%s\n", c.Sid())
Output:
type Conn ¶
type Conn interface { PacketReader PacketWriter io.Closer FlushOut() []*Packet FlushIn() []*Packet SetReadDeadline(t time.Time) error SetWriteDeadline(t time.Time) error Pause() error Resume() error LocalAddr() net.Addr RemoteAddr() net.Addr }
Conn is abstraction of bidirectional engine.io connection
type MessageType ¶
type MessageType byte
MessageType indicates type of an engine.io Message
const ( // MessageTypeString indicates Message encoded as string MessageTypeString MessageType = iota // MessageTypeBinary indicates Message encoded as binary MessageTypeBinary )
func (MessageType) String ¶
func (m MessageType) String() string
String returns string representation of a MessageType
type Packet ¶
type Packet struct {
// contains filtered or unexported fields
}
Packet is abstraction of message, exchaged between engine.io server and client
type PacketReader ¶
PacketReader reads data from remote and outputs a Packet when appropriate
type PacketType ¶
type PacketType byte
PacketType indicates type of an engine.io Packet
const ( // PacketTypeOpen is sent from the server when a new transport is opened (recheck) PacketTypeOpen PacketType = iota // PacketTypeClose requests the close of this transport but does not shutdown the connection itself. PacketTypeClose // PacketTypePing is sent by the client. Server should answer with a pong packet containing the same data PacketTypePing // PacketTypePong is sent by the server to respond to ping packets. PacketTypePong // PacketTypeMessage denotes actual message, client and server should call their callbacks with the data. PacketTypeMessage // PacketTypeUpgrade is sent by the client requesting the server to flush its cache on the old transport and switch to the new transport. PacketTypeUpgrade // PacketTypeNoop denotes a noop packet. Used primarily to force a poll cycle when an incoming websocket connection is received. PacketTypeNoop )
func (PacketType) String ¶
func (p PacketType) String() string
String returns string representation of a PacketType
type PacketWriter ¶
PacketWriter accepts a Packet and sends to remote
type Parameters ¶
type Parameters struct { SID string `json:"sid"` Upgrades []string `json:"upgrades"` PingInterval int `json:"pingInterval"` PingTimeout int `json:"pingTimeout"` }
Parameters describes engine.io connection attributes, sending from server to client upon handshaking.
type Payload ¶
type Payload struct {
// contains filtered or unexported fields
}
Payload is a series of Packets
type Server ¶
type Server struct {
// contains filtered or unexported fields
}
Server is engine.io server implementation
Example ¶
server, _ := NewServer(time.Second*5, time.Second*5, func(so *Socket) { log.Println("connect", so.RemoteAddr()) }) server.On(EventMessage, Callback(func(so *Socket, typ MessageType, data []byte) { switch typ { case MessageTypeString: log.Printf("txt: %s\n", data) case MessageTypeBinary: log.Printf("bin: %x\n", data) default: log.Printf("???: %x\n", data) } })) server.On(EventPing, Callback(func(so *Socket, _ MessageType, _ []byte) { log.Printf("socket ping\n") })) server.On(EventClose, Callback(func(so *Socket, _ MessageType, _ []byte) { log.Printf("socket close\n") })) server.On(EventUpgrade, Callback(func(so *Socket, _ MessageType, _ []byte) { log.Printf("socket upgrade\n") })) defer server.Close() log.Fatalln(http.ListenAndServe("localhost:8081", server))
Output:
func (Server) NewSession ¶
type Socket ¶
Socket is engine.io connection encapsulation
func (*Socket) CheckPaused ¶
func (s *Socket) CheckPaused()
CheckPaused blocks when socket is paused
func (*Socket) Emit ¶
func (s *Socket) Emit(event event, msgType MessageType, args interface{}) (err error)
Emit sends event data to remote peer