Documentation ¶
Overview ¶
Package turnpike provides a Websocket Application Messaging Protocol (WAMP) server and client
Index ¶
- Variables
- type CallResult
- type Client
- func (c *Client) Call(procURI string, args ...interface{}) chan CallResult
- func (c *Client) Connect(server, origin string) error
- func (c *Client) ConnectWithHeaders(server, origin string, headers map[string]string, TlsConfig *tls.Config) error
- func (c *Client) Disconnect() error
- func (c *Client) Prefix(prefix, URI string) error
- func (c *Client) Publish(topicURI string, event interface{}, opts ...interface{}) error
- func (c *Client) PublishExcludeMe(topicURI string, event interface{}) error
- func (c *Client) SetSessionOpenCallback(f func(string))
- func (c *Client) Subscribe(topicURI string, f EventHandler) error
- func (c *Client) Unsubscribe(topicURI string) error
- type EventHandler
- type HandlerFunc
- type PubHandler
- type RPCError
- type RPCHandler
- type Server
- func (t *Server) ConnectedClients() []string
- func (t *Server) HandleWebsocket(conn *websocket.Conn)
- func (t *Server) RegisterPubHandler(uri string, f PubHandler)
- func (t *Server) RegisterRPC(uri string, ...)
- func (t *Server) RegisterRPCFunc(uri string, f RPCHandler)
- func (t *Server) RegisterSubHandler(uri string, f SubHandler)
- func (t *Server) SendEvent(topic string, event interface{}, excludeMe bool, excludeList []string, ...)
- func (t *Server) SetSessionOpenCallback(f func(string))
- func (t *Server) SubscribedTopicUris() []string
- func (t *Server) UnregisterPubHandler(uri string)
- func (t *Server) UnregisterRPC(uri string)
- func (t *Server) UnregisterSubHandler(uri string)
- type SubHandler
- type WAMPError
Constants ¶
This section is empty.
Variables ¶
var ( // An ErrInvalidURI describes an invalid URI. ErrInvalidURI = &WAMPError{"invalid URI"} // An ErrInvalidNumArgs describes invalid number of arguments in a message. ErrInvalidNumArgs = &WAMPError{"invalid number of arguments in message"} // An ErrUnsupportedProtocol describes an unsupported WAMP protocol in a welcome message. ErrUnsupportedProtocol = &WAMPError{"unsupported protocol"} )
Functions ¶
This section is empty.
Types ¶
type CallResult ¶
type CallResult struct { // Result contains the RPC call result returned by the server. Result interface{} // Error is nil on call success otherwise it contains the RPC error. Error error }
CallResult represents either a sucess or a failure after a RPC call.
type Client ¶
type Client struct { // SessionId is a ID of the session in UUID4 format received at the start of the session. SessionId string // ProtocolVersion is the version of the WAMP protocol received at the start of the session. ProtocolVersion int // ServerIdent is the server ID (ie "turnpike, autobahn") received at the start of the session. ServerIdent string // contains filtered or unexported fields }
Client represents a WAMP client that handles RPC and pub/sub.
func (*Client) Call ¶
func (c *Client) Call(procURI string, args ...interface{}) chan CallResult
Call makes a RPC call on the server identified by procURI (in either full URI or CURIE format) with zero or more args. Returns a channel that will receive the call result (or error) on completion.
func (*Client) Connect ¶
Connect will connect to server with an optional origin. More details here: http://godoc.org/code.google.com/p/go.net/websocket#Dial
func (*Client) ConnectWithHeaders ¶
func (*Client) Disconnect ¶
func (*Client) Prefix ¶
Prefix sets a CURIE prefix at the server for later use when interacting with the server. prefix is the first part of a CURIE (ie "calc") and URI is a full identifier (ie "http://example.com/simple/calc#") that is mapped to the prefix.
func (*Client) Publish ¶
Publish publishes an event to the topicURI that gets sent to all subscribers of that topicURI by the server. opts can can be either empty, one boolean that can be used to exclude outself from receiving the event or two lists; the first a list of clients to exclude and the second a list of clients that are eligible to receive the event. Either list can be empty.
func (*Client) PublishExcludeMe ¶
PublishExcludeMe is a short hand for Publish(tobicURI, event, true) that will not send the event to ourself.
func (*Client) SetSessionOpenCallback ¶
SetSessionOpenCallback adds a callback function that is run when a new session begins. The callback function must accept a string argument that is the session ID.
func (*Client) Subscribe ¶
func (c *Client) Subscribe(topicURI string, f EventHandler) error
Subscribe adds a subscription at the server for events with topicURI lasting for the session or until Unsubscribe is called.
func (*Client) Unsubscribe ¶
Unsubscribe removes a previous subscription with topicURI at the server.
type EventHandler ¶
type EventHandler func(topicURI string, event interface{})
EventHandler is an interface for handlers to published events. The topicURI is the URI of the event and event is the event contents.
type HandlerFunc ¶
type PubHandler ¶
type PubHandler func(topicURI string, event interface{}) interface{}
PubHandler is an interface that handlers for publishes should implement to get notified on a client publish with the possibility to modify the event. The event that will be published should be returned.
type RPCError ¶
RPCError represents a call error and is the recommended way to return an error from a RPC handler.
type RPCHandler ¶
type RPCHandler interface { // RPCHandler is an interface that handlers to RPC calls should implement. // The first parameter is the call ID, the second is the proc URI. Last comes // all optional arguments to the RPC call. The return can be of any type that // can be marshaled to JSON, or a error (preferably RPCError but any error works.) // NOTE: this may be broken in v2 if multiple-return is implemented HandleRPC(clientID string, topicURI string, args ...interface{}) (interface{}, error) }
Using a handle func pattern so we can adapt the calls and do things like retry
type Server ¶
Server represents a WAMP server that handles RPC and pub/sub.
func (*Server) ConnectedClients ¶
ConnectedClients returns a slice of the ids of all connected clients
func (*Server) HandleWebsocket ¶
HandleWebsocket implements the go.net/websocket.Handler interface.
func (*Server) RegisterPubHandler ¶
func (t *Server) RegisterPubHandler(uri string, f PubHandler)
RegisterPubHandler adds a handler called when a client publishes to URI. The event can be modified in the handler and the returned event is what is published to the other clients.
func (*Server) RegisterRPC ¶
func (*Server) RegisterRPCFunc ¶
func (t *Server) RegisterRPCFunc(uri string, f RPCHandler)
RegisterRPC adds a handler for the RPC named uri.
func (*Server) RegisterSubHandler ¶
func (t *Server) RegisterSubHandler(uri string, f SubHandler)
RegisterSubHandler adds a handler called when a client subscribes to URI. The subscription can be canceled in the handler by returning false, or approved by returning true.
func (*Server) SendEvent ¶
func (t *Server) SendEvent(topic string, event interface{}, excludeMe bool, excludeList []string, eligibleList []string)
SendEvent sends an event with topic directly (not via Client.Publish())
func (*Server) SetSessionOpenCallback ¶
SetSessionOpenCallback adds a callback function that is run when a new session begins. The callback function must accept a string argument that is the session ID.
func (*Server) SubscribedTopicUris ¶
func (*Server) UnregisterPubHandler ¶
UnregisterPubHandler removes a publish handler for the URI.
func (*Server) UnregisterRPC ¶
UnregisterRPC removes a handler for the RPC named uri.
func (*Server) UnregisterSubHandler ¶
UnregisterSubHandler removes a subscription handler for the URI.
type SubHandler ¶
SubHandler is an interface that handlers for subscriptions should implement to control with subscriptions are valid. A subscription is allowed by returning true or denied by returning false.