Documentation ¶
Index ¶
- Variables
- func DialAuthHTTP(network, address, user, password, codecName string, ...) (conn *rpc.Client, err error)
- func DialHTTP(network, address, codecName string, cFactory ClientCodecFactory, ...) (*rpc.Client, error)
- func GetRpcPath(codecName string, auth bool) string
- func ServeAuthRPC(codecName string, cFactory ServerCodecFactory)
- func ServeCustomRPC(handler *http.ServeMux, server *rpc.Server, useAuth bool, codecName string, ...)
- func ServeRPC(codecName string, cFactory ServerCodecFactory)
- type BufferedConnection
- type ClientCodecFactory
- type ServerCodecFactory
Constants ¶
This section is empty.
Variables ¶
var AuthenticatedServer = rpc.NewServer()
AuthenticatedServer is an rpc.Server instance that serves authenticated calls.
Functions ¶
func DialAuthHTTP ¶
func DialAuthHTTP(network, address, user, password, codecName string, cFactory ClientCodecFactory, connectTimeout time.Duration, config *tls.Config) (conn *rpc.Client, err error)
DialAuthHTTP connects to an authenticated go HTTP RPC server using the specified codec and credentials. use 0 as connectTimeout for no timeout use nil as config to not use TLS
func DialHTTP ¶
func DialHTTP(network, address, codecName string, cFactory ClientCodecFactory, connectTimeout time.Duration, config *tls.Config) (*rpc.Client, error)
DialHTTP connects to a go HTTP RPC server using the specified codec. use 0 as connectTimeout for no timeout use nil as config to not use TLS
func GetRpcPath ¶
GetRpcPath returns the toplevel path used for serving RPCs over HTTP
func ServeAuthRPC ¶
func ServeAuthRPC(codecName string, cFactory ServerCodecFactory)
ServeAuthRPC handles authenticated rpc requests using the hijack scheme of rpc
func ServeCustomRPC ¶
func ServeCustomRPC(handler *http.ServeMux, server *rpc.Server, useAuth bool, codecName string, cFactory ServerCodecFactory)
ServeCustomRPC serves the given rpc requests with the provided ServeMux, authenticated or not
func ServeRPC ¶
func ServeRPC(codecName string, cFactory ServerCodecFactory)
ServeRPC handles rpc requests using the hijack scheme of rpc
Types ¶
type BufferedConnection ¶
type BufferedConnection struct { *bufio.Reader io.WriteCloser // contains filtered or unexported fields }
func NewBufferedConnection ¶
func NewBufferedConnection(conn io.ReadWriteCloser) *BufferedConnection
func (*BufferedConnection) Close ¶
func (bc *BufferedConnection) Close() error
FIXME(sougou/szopa): Find a better way to track connection count.
type ClientCodecFactory ¶
type ClientCodecFactory func(conn io.ReadWriteCloser) rpc.ClientCodec
type ServerCodecFactory ¶
type ServerCodecFactory func(conn io.ReadWriteCloser) rpc.ServerCodec