Documentation ¶
Index ¶
- Variables
- func IsNil(face interface{}) bool
- func NewChaCha20CryptoRandKey() []byte
- func SelfyNewKey(createKeyPairNamed, odir string) error
- type Args
- func (z *Args) DecodeMsg(dc *msgp.Reader) (err error)
- func (z Args) EncodeMsg(en *msgp.Writer) (err error)
- func (z Args) MarshalMsg(b []byte) (o []byte, err error)
- func (z Args) Msgsize() (s int)
- func (z *Args) UnmarshalMsg(bts []byte) (o []byte, err error)
- func (z *Args) UnmarshalMsgWithCfg(bts []byte, cfg *msgp.RuntimeConfig) (o []byte, err error)
- type Arith
- func (t *Arith) Add(args Args, reply *Reply) error
- func (z *Arith) DecodeMsg(dc *msgp.Reader) (err error)
- func (t *Arith) Div(args Args, reply *Reply) error
- func (z Arith) EncodeMsg(en *msgp.Writer) (err error)
- func (t *Arith) Error(args *Args, reply *Reply) error
- func (z Arith) MarshalMsg(b []byte) (o []byte, err error)
- func (z Arith) Msgsize() (s int)
- func (t *Arith) Mul(args *Args, reply *Reply) error
- func (t *Arith) Scan(args string, reply *Reply) (err error)
- func (t *Arith) SleepMilli(args *Args, reply *Reply) error
- func (t *Arith) String(args *Args, reply *string) error
- func (z *Arith) UnmarshalMsg(bts []byte) (o []byte, err error)
- func (z *Arith) UnmarshalMsgWithCfg(bts []byte, cfg *msgp.RuntimeConfig) (o []byte, err error)
- type BenchmarkMessage
- func (z *BenchmarkMessage) DecodeMsg(dc *msgp.Reader) (err error)
- func (z *BenchmarkMessage) EncodeMsg(en *msgp.Writer) (err error)
- func (z *BenchmarkMessage) MarshalMsg(b []byte) (o []byte, err error)
- func (z *BenchmarkMessage) Msgsize() (s int)
- func (z *BenchmarkMessage) UnmarshalMsg(bts []byte) (o []byte, err error)
- func (z *BenchmarkMessage) UnmarshalMsgWithCfg(bts []byte, cfg *msgp.RuntimeConfig) (o []byte, err error)
- type BuiltinTypes
- func (BuiltinTypes) Array(args *Args, reply *[2]int) error
- func (z *BuiltinTypes) DecodeMsg(dc *msgp.Reader) (err error)
- func (z BuiltinTypes) EncodeMsg(en *msgp.Writer) (err error)
- func (BuiltinTypes) Map(args *Args, reply *map[int]int) error
- func (z BuiltinTypes) MarshalMsg(b []byte) (o []byte, err error)
- func (z BuiltinTypes) Msgsize() (s int)
- func (BuiltinTypes) Slice(args *Args, reply *[]int) error
- func (z *BuiltinTypes) UnmarshalMsg(bts []byte) (o []byte, err error)
- func (z *BuiltinTypes) UnmarshalMsgWithCfg(bts []byte, cfg *msgp.RuntimeConfig) (o []byte, err error)
- func (BuiltinTypes) WantsContext(ctx context.Context, args *Args, reply *[2]int) error
- type Call
- type CallType
- func (z *CallType) DecodeMsg(dc *msgp.Reader) (err error)
- func (z CallType) EncodeMsg(en *msgp.Writer) (err error)
- func (z CallType) MarshalMsg(b []byte) (o []byte, err error)
- func (z CallType) Msgsize() (s int)
- func (z *CallType) UnmarshalMsg(bts []byte) (o []byte, err error)
- func (z *CallType) UnmarshalMsgWithCfg(bts []byte, cfg *msgp.RuntimeConfig) (o []byte, err error)
- type Client
- func (c *Client) Call(serviceMethod string, args, reply Green, octx context.Context) error
- func (c *Client) Close() error
- func (c *Client) Err() error
- func (c *Client) GetOneRead(seqno uint64, ch chan *Message)
- func (c *Client) GetReadIncomingCh() (ch chan *Message)
- func (c *Client) GetReads(ch chan *Message)
- func (c *Client) Go(serviceMethod string, args Green, reply Green, done chan *Call, ...) *Call
- func (c *Client) IsDown() (down bool)
- func (c *Client) LocalAddr() string
- func (c *Client) Name() string
- func (c *Client) OneWaySend(msg *Message, cancelJobCh <-chan struct{}) (err error)
- func (c *Client) SendAndGetReply(req *Message, cancelJobCh <-chan struct{}) (reply *Message, err error)
- func (c *Client) SendAndGetReplyWithTimeout(timeout time.Duration, req *Message) (reply *Message, err error)
- func (c *Client) Start() error
- func (c *Client) UngetReads(ch chan *Message)
- type ClientCodec
- type Config
- type Embed
- func (z *Embed) DecodeMsg(dc *msgp.Reader) (err error)
- func (z Embed) EncodeMsg(en *msgp.Writer) (err error)
- func (z Embed) MarshalMsg(b []byte) (o []byte, err error)
- func (z Embed) Msgsize() (s int)
- func (z *Embed) UnmarshalMsg(bts []byte) (o []byte, err error)
- func (z *Embed) UnmarshalMsgWithCfg(bts []byte, cfg *msgp.RuntimeConfig) (o []byte, err error)
- type Green
- type HDR
- func (hdr *HDR) AsGreenpack(scratch []byte) (o []byte, err error)
- func (m *HDR) Bytes() []byte
- func (m *HDR) Compact() string
- func (z *HDR) DecodeMsg(dc *msgp.Reader) (err error)
- func (z *HDR) EncodeMsg(en *msgp.Writer) (err error)
- func (a *HDR) Equal(b *HDR) bool
- func (m *HDR) JSON() []byte
- func (z *HDR) MarshalMsg(b []byte) (o []byte, err error)
- func (z *HDR) Msgsize() (s int)
- func (m *HDR) Pretty() string
- func (m *HDR) String() string
- func (z *HDR) UnmarshalMsg(bts []byte) (o []byte, err error)
- func (z *HDR) UnmarshalMsgWithCfg(bts []byte, cfg *msgp.RuntimeConfig) (o []byte, err error)
- type Hello
- func (z *Hello) DecodeMsg(dc *msgp.Reader) (err error)
- func (z Hello) EncodeMsg(en *msgp.Writer) (err error)
- func (z Hello) MarshalMsg(b []byte) (o []byte, err error)
- func (z Hello) Msgsize() (s int)
- func (z *Hello) UnmarshalMsg(bts []byte) (o []byte, err error)
- func (z *Hello) UnmarshalMsgWithCfg(bts []byte, cfg *msgp.RuntimeConfig) (o []byte, err error)
- type InvalidRequest
- func (z *InvalidRequest) DecodeMsg(dc *msgp.Reader) (err error)
- func (z InvalidRequest) EncodeMsg(en *msgp.Writer) (err error)
- func (z InvalidRequest) MarshalMsg(b []byte) (o []byte, err error)
- func (z InvalidRequest) Msgsize() (s int)
- func (z *InvalidRequest) UnmarshalMsg(bts []byte) (o []byte, err error)
- func (z *InvalidRequest) UnmarshalMsgWithCfg(bts []byte, cfg *msgp.RuntimeConfig) (o []byte, err error)
- type Message
- func (m *Message) AsGreenpack(scratch []byte) (o []byte, err error)
- func (z *Message) DecodeMsg(dc *msgp.Reader) (err error)
- func (z *Message) EncodeMsg(en *msgp.Writer) (err error)
- func (z *Message) MarshalMsg(b []byte) (o []byte, err error)
- func (z *Message) Msgsize() (s int)
- func (msg *Message) String() string
- func (z *Message) UnmarshalMsg(bts []byte) (o []byte, err error)
- func (z *Message) UnmarshalMsgWithCfg(bts []byte, cfg *msgp.RuntimeConfig) (o []byte, err error)
- type NetConnWrapper
- type OneWayFunc
- type Reply
- func (z *Reply) DecodeMsg(dc *msgp.Reader) (err error)
- func (z Reply) EncodeMsg(en *msgp.Writer) (err error)
- func (z Reply) MarshalMsg(b []byte) (o []byte, err error)
- func (z Reply) Msgsize() (s int)
- func (z *Reply) UnmarshalMsg(bts []byte) (o []byte, err error)
- func (z *Reply) UnmarshalMsgWithCfg(bts []byte, cfg *msgp.RuntimeConfig) (o []byte, err error)
- type Request
- func (z *Request) DecodeMsg(dc *msgp.Reader) (err error)
- func (z Request) EncodeMsg(en *msgp.Writer) (err error)
- func (z Request) MarshalMsg(b []byte) (o []byte, err error)
- func (z Request) Msgsize() (s int)
- func (z *Request) UnmarshalMsg(bts []byte) (o []byte, err error)
- func (z *Request) UnmarshalMsgWithCfg(bts []byte, cfg *msgp.RuntimeConfig) (o []byte, err error)
- type Response
- func (z *Response) DecodeMsg(dc *msgp.Reader) (err error)
- func (z Response) EncodeMsg(en *msgp.Writer) (err error)
- func (z Response) MarshalMsg(b []byte) (o []byte, err error)
- func (z Response) Msgsize() (s int)
- func (z *Response) UnmarshalMsg(bts []byte) (o []byte, err error)
- func (z *Response) UnmarshalMsgWithCfg(bts []byte, cfg *msgp.RuntimeConfig) (o []byte, err error)
- type Server
- func (s *Server) Close() error
- func (s *Server) Register(rcvr msgp.Encodable) error
- func (s *Server) Register1Func(callme1 OneWayFunc)
- func (s *Server) Register2Func(callme2 TwoWayFunc)
- func (s *Server) RegisterName(name string, rcvr msgp.Encodable) error
- func (s *Server) SendMessage(callID, subject, destAddr string, data []byte, seqno uint64, ...) error
- func (s *Server) Start() (serverAddr net.Addr, err error)
- type ServerClient
- type ServerCodec
- type ServerError
- type Simple
- func (z *Simple) DecodeMsg(dc *msgp.Reader) (err error)
- func (z Simple) EncodeMsg(en *msgp.Writer) (err error)
- func (t *Simple) Exported(args Args, reply *Reply) error
- func (z Simple) MarshalMsg(b []byte) (o []byte, err error)
- func (z Simple) Msgsize() (s int)
- func (z *Simple) UnmarshalMsg(bts []byte) (o []byte, err error)
- func (z *Simple) UnmarshalMsgWithCfg(bts []byte, cfg *msgp.RuntimeConfig) (o []byte, err error)
- type TwoWayFunc
Constants ¶
This section is empty.
Variables ¶
var ErrDone = fmt.Errorf("done channel closed")
var ErrHandshakeQUIC = fmt.Errorf("quic handshake failure")
var ErrNetConnectionNotFound = fmt.Errorf("error: net.Conn not found")
var ErrNetRpcShutdown = errors.New("connection is shut down")
ErrNetRpcShutdown is from net/rpc, and still distinct from ErrShutdown to help locate when and where the error was generated. It indicates the system, or at least the network connection or stream, is closed or shutting down.
var ErrNotFound = fmt.Errorf("known_tls_hosts file not found")
var ErrShutdown = fmt.Errorf("shutting down")
var ErrTimeout = fmt.Errorf("time-out waiting for call to complete")
var ErrTooLong = fmt.Errorf("message message too long: over 2GB; encrypted client vs an un-encrypted server?")
Functions ¶
func IsNil ¶ added in v1.1.32
func IsNil(face interface{}) bool
IsNil uses reflect to to return true iff the face contains a nil pointer, map, array, slice, or channel.
func NewChaCha20CryptoRandKey ¶ added in v1.0.114
func NewChaCha20CryptoRandKey() []byte
func SelfyNewKey ¶ added in v1.0.3
SelfyNewKey is only for testing, not production. It is used by the tests to check that certs are signed by the expected CA.
SelfyNewKey will generate a self-signed certificate authority, a new ed25519 key pair, sign the public key to create a cert, and write these four new files to disk. The directories odir/my-keep-private-dir and odir/certs will be created, based on the odir argument. For a given createKeyPairNamed name, we will create odir/certs/name.crt and odir/certs/name.key files. The odir/certs/name.key and my-keep-private-dir/ca.key files contain private keys and should be kept confidential. The `selfy` command in this package can be used to produce the same keys but with password protection, which is recommended.
Types ¶
type Args ¶ added in v1.1.0
func (*Args) DecodeMsg ¶ added in v1.1.0
DecodeMsg implements msgp.Decodable We treat empty fields as if we read a Nil from the wire.
func (Args) MarshalMsg ¶ added in v1.1.0
MarshalMsg implements msgp.Marshaler
func (Args) Msgsize ¶ added in v1.1.0
Msgsize returns an upper bound estimate of the number of bytes occupied by the serialized message
func (*Args) UnmarshalMsg ¶ added in v1.1.0
UnmarshalMsg implements msgp.Unmarshaler
func (*Args) UnmarshalMsgWithCfg ¶ added in v1.1.0
type Arith ¶ added in v1.1.0
type Arith int
func (*Arith) DecodeMsg ¶ added in v1.1.0
DecodeMsg implements msgp.Decodable We treat empty fields as if we read a Nil from the wire.
func (Arith) MarshalMsg ¶ added in v1.1.0
MarshalMsg implements msgp.Marshaler
func (Arith) Msgsize ¶ added in v1.1.0
Msgsize returns an upper bound estimate of the number of bytes occupied by the serialized message
func (*Arith) SleepMilli ¶ added in v1.1.0
func (*Arith) UnmarshalMsg ¶ added in v1.1.0
UnmarshalMsg implements msgp.Unmarshaler
func (*Arith) UnmarshalMsgWithCfg ¶ added in v1.1.0
type BenchmarkMessage ¶ added in v1.1.30
type BenchmarkMessage struct { Field1 string `zid:"0"` Field9 string `zid:"1"` Field18 string `zid:"2"` Field80 bool `zid:"3"` Field81 bool `zid:"4"` Field2 int32 `zid:"5"` Field3 int32 `zid:"6"` Field280 int32 `zid:"7"` Field6 int32 `zid:"8"` Field22 int64 `zid:"9"` Field4 string `zid:"10"` Field5 []uint64 `zid:"11"` Field59 bool `zid:"12"` Field7 string `zid:"13"` Field16 int32 `zid:"14"` Field130 int32 `zid:"15"` Field12 bool `zid:"16"` Field17 bool `zid:"17"` Field13 bool `zid:"18"` Field14 bool `zid:"19"` Field104 int32 `zid:"20"` Field100 int32 `zid:"21"` Field101 int32 `zid:"22"` Field102 string `zid:"23"` Field103 string `zid:"24"` Field29 int32 `zid:"25"` Field30 bool `zid:"26"` Field60 int32 `zid:"27"` Field271 int32 `zid:"28"` Field272 int32 `zid:"29"` Field150 int32 `zid:"30"` Field23 int32 `zid:"31"` Field24 bool `zid:"32"` Field25 int32 `zid:"33"` Field78 bool `zid:"34"` Field67 int32 `zid:"35"` Field68 int32 `zid:"36"` Field128 int32 `zid:"37"` Field129 string `zid:"38"` Field131 int32 `zid:"39"` }
func (*BenchmarkMessage) DecodeMsg ¶ added in v1.1.30
func (z *BenchmarkMessage) DecodeMsg(dc *msgp.Reader) (err error)
DecodeMsg implements msgp.Decodable We treat empty fields as if we read a Nil from the wire.
func (*BenchmarkMessage) EncodeMsg ¶ added in v1.1.30
func (z *BenchmarkMessage) EncodeMsg(en *msgp.Writer) (err error)
EncodeMsg implements msgp.Encodable
func (*BenchmarkMessage) MarshalMsg ¶ added in v1.1.30
func (z *BenchmarkMessage) MarshalMsg(b []byte) (o []byte, err error)
MarshalMsg implements msgp.Marshaler
func (*BenchmarkMessage) Msgsize ¶ added in v1.1.30
func (z *BenchmarkMessage) Msgsize() (s int)
Msgsize returns an upper bound estimate of the number of bytes occupied by the serialized message
func (*BenchmarkMessage) UnmarshalMsg ¶ added in v1.1.30
func (z *BenchmarkMessage) UnmarshalMsg(bts []byte) (o []byte, err error)
UnmarshalMsg implements msgp.Unmarshaler
func (*BenchmarkMessage) UnmarshalMsgWithCfg ¶ added in v1.1.30
func (z *BenchmarkMessage) UnmarshalMsgWithCfg(bts []byte, cfg *msgp.RuntimeConfig) (o []byte, err error)
type BuiltinTypes ¶ added in v1.1.0
type BuiltinTypes struct {
Placeholder int `zid:"0"` // greenpack refuses to serialize an empty struct.
}
func (BuiltinTypes) Array ¶ added in v1.1.0
func (BuiltinTypes) Array(args *Args, reply *[2]int) error
func (*BuiltinTypes) DecodeMsg ¶ added in v1.1.0
func (z *BuiltinTypes) DecodeMsg(dc *msgp.Reader) (err error)
DecodeMsg implements msgp.Decodable We treat empty fields as if we read a Nil from the wire.
func (BuiltinTypes) EncodeMsg ¶ added in v1.1.0
func (z BuiltinTypes) EncodeMsg(en *msgp.Writer) (err error)
EncodeMsg implements msgp.Encodable
func (BuiltinTypes) Map ¶ added in v1.1.0
func (BuiltinTypes) Map(args *Args, reply *map[int]int) error
func (BuiltinTypes) MarshalMsg ¶ added in v1.1.0
func (z BuiltinTypes) MarshalMsg(b []byte) (o []byte, err error)
MarshalMsg implements msgp.Marshaler
func (BuiltinTypes) Msgsize ¶ added in v1.1.0
func (z BuiltinTypes) Msgsize() (s int)
Msgsize returns an upper bound estimate of the number of bytes occupied by the serialized message
func (BuiltinTypes) Slice ¶ added in v1.1.0
func (BuiltinTypes) Slice(args *Args, reply *[]int) error
func (*BuiltinTypes) UnmarshalMsg ¶ added in v1.1.0
func (z *BuiltinTypes) UnmarshalMsg(bts []byte) (o []byte, err error)
UnmarshalMsg implements msgp.Unmarshaler
func (*BuiltinTypes) UnmarshalMsgWithCfg ¶ added in v1.1.0
func (z *BuiltinTypes) UnmarshalMsgWithCfg(bts []byte, cfg *msgp.RuntimeConfig) (o []byte, err error)
func (BuiltinTypes) WantsContext ¶ added in v1.1.0
mimic Array's reply
type Call ¶ added in v1.0.42
type Call struct { ServiceMethod string // The name of the service and method to call. Args Green // The argument to the function (*struct). Reply Green // The reply from the function (*struct). Error error // After completion, the error status. Done chan *Call // Receives *Call when Go is complete. }
Call represents an active net/rpc RPC.
type CallType ¶ added in v1.1.29
type CallType int
func (*CallType) DecodeMsg ¶ added in v1.1.29
DecodeMsg implements msgp.Decodable We treat empty fields as if we read a Nil from the wire.
func (CallType) MarshalMsg ¶ added in v1.1.29
MarshalMsg implements msgp.Marshaler
func (CallType) Msgsize ¶ added in v1.1.29
Msgsize returns an upper bound estimate of the number of bytes occupied by the serialized message
func (*CallType) UnmarshalMsg ¶ added in v1.1.29
UnmarshalMsg implements msgp.Unmarshaler
func (*CallType) UnmarshalMsgWithCfg ¶ added in v1.1.29
type Client ¶
type Client struct {
// contains filtered or unexported fields
}
A Client starts requests, and (might) wait for responses.
func NewClient ¶
NewClient creates a new client. Call Start() to begin a connection. The name setting allows users to track multiple instances of Clients, and the Client.Name() method will retreive it.
func (*Client) Call ¶ added in v1.0.42
Call implements the net/rpc Client.Call() API; its docs:
Call invokes the named function, waits for it to complete, and returns its error status.
Added: octx is an optional context for cancelling the job. It can be nil.
func (*Client) GetOneRead ¶
GetOneRead responds on ch with the first incoming message whose Seqno matches seqno, then auto unregisters itself after that single send on ch.
func (*Client) GetReadIncomingCh ¶
GetReadIncomingCh creates and returns a buffered channel that reads incoming messages that are server-pushed (not associated with a round-trip rpc call request/response pair).
func (*Client) GetReads ¶
GetReads registers to get any received messages on ch. It is similar to GetReadIncomingCh but for when ch already exists and you do not want a new one.
func (*Client) Go ¶ added in v1.0.42
func (c *Client) Go(serviceMethod string, args Green, reply Green, done chan *Call, octx context.Context) *Call
Go implements the net/rpc Client.Go() API; its docs:
Go invokes the function asynchronously. It returns the Call structure representing the invocation. The done channel will signal when the call is complete by returning the same Call object. If done is nil, Go will allocate a new channel. If non-nil, done must be buffered or Go will deliberately crash.
octx is an optional context, for early cancelling of a job. It can be nil.
func (*Client) OneWaySend ¶
OneWaySend sends a message without expecting or waiting for a response. The cancelJobCh is optional, and can be nil.
func (*Client) SendAndGetReply ¶
func (c *Client) SendAndGetReply(req *Message, cancelJobCh <-chan struct{}) (reply *Message, err error)
SendAndGetReply starts a round-trip RPC call. We will wait for a response before retuning. The requestStopCh is optional; it can be nil. A context.Done() like channel can be supplied there to cancel the job and stop waiting before a reply comes back.
UPDATE: a DEFAULT timeout is in force now. Because server failure or blink (down then up) can leave us stalled forever, we put in a default timeout of 10 seconds, if not otherwise specified. If you expect your call to take more than a few seconds, you should set the timeout directly with SendAndGetReplyWithTimeout() or pass in a cancelJobCh here to manage it. Otherwise, to handle the common case when we expect very fast replies, if cancelJobCh is nil, we will cancel the job if it has not finished after 10 seconds.
func (*Client) SendAndGetReplyWithTimeout ¶
func (c *Client) SendAndGetReplyWithTimeout(timeout time.Duration, req *Message) (reply *Message, err error)
SendAndGetReplyWithTimeout expires the call after timeout.
func (*Client) Start ¶ added in v1.1.15
Start dials the server. That is, Start attemps to connect to config.ClientDialToHostPort. The err will come back with any problems encountered.
func (*Client) UngetReads ¶
UngetReads reverses what GetReads does: un-register and have ch be deaf from now on. Idempotent: if ch is already gone, no foul is reported.
type ClientCodec ¶ added in v1.0.42
type ClientCodec interface { WriteRequest(*Request, msgp.Encodable) error ReadResponseHeader(*Response) error ReadResponseBody(msgp.Decodable) error Close() error }
ClientCodec is part of the net/rpc API. Its docs:
A ClientCodec implements writing of RPC requests and reading of RPC responses for the client side of an RPC session. The client calls [ClientCodec.WriteRequest] to write a request to the connection and calls [ClientCodec.ReadResponseHeader] and [ClientCodec.ReadResponseBody] in pairs to read responses. The client calls [ClientCodec.Close] when finished with the connection. ReadResponseBody may be called with a nil argument to force the body of the response to be read and then discarded. See NewClient's comment for information about concurrent access.
type Config ¶
type Config struct { // ServerAddr host:port where the server should listen. ServerAddr string // optional. Can be used to suggest that the // client use a specific host:port. NB: For QUIC, by default, the client and // server will share the same port if they are in the same process. // In that case this setting will definitely be ignored. ClientHostPort string // Who the client should contact ClientDialToHostPort string // TCP false means TLS-1.3 secured. true here means do TCP only; with no encryption. TCPonly_no_TLS bool // UseQUIC cannot be true if TCPonly_no_TLS is true. UseQUIC bool // If true, then we do not share same UDP port between a QUIC // client and server (in the same process). Used // for testing client shutdown paths too. NoSharePortQUIC bool // path to certs/ like certificate // directory on the live filesystem. CertPath string // SkipVerifyKeys true allows any incoming // key to be signed by // any CA; it does not have to be ours. Obviously // this discards almost all access control; it // should rarely be used unless communication // with the any random agent/hacker/public person // is desired. SkipVerifyKeys bool ClientKeyPairName string // default "client" means use certs/client.crt and certs/client.key ServerKeyPairName string // default "node" means use certs/node.crt and certs/node.key // key. It must be 32 bytes (or more). Ideally // it should be generated from crypto/rand. // The `selfy -gensym outpath` command will // write 32 randomly bytes to output. PreSharedKeyPath string // These are timeouts for connection and transport tuning. // The defaults of 0 mean wait forever. ConnectTimeout time.Duration ReadTimeout time.Duration WriteTimeout time.Duration ServerSendKeepAlive time.Duration ClientSendKeepAlive time.Duration // contains filtered or unexported fields }
Config is the same struct type for both NewClient and NewServer setup.
Config says who to contact (for a client), or where to listen (for a server and/or client); and sets how strong a security posture we adopt.
Copying a Config is fine, but it should be a simple shallow copy to preserve the shared *sharedTransport struct. See/use the Config.Clone() method if in doubt.
nitty gritty details/dev note: the `shared` pointer here is the basis of port (and file handle) reuse where a single process can maintain a server and multiple clients in a "star" pattern. This only works with QUIC of course, and is one of the main reasons to use QUIC.
The shared pointer is reference counted and the underlying net.UDPConn is only closed when the last instance in use is Close()-ed.
type Embed ¶ added in v1.1.0
type Embed struct {
Simple `zid:"0"`
}
func (*Embed) DecodeMsg ¶ added in v1.1.0
DecodeMsg implements msgp.Decodable We treat empty fields as if we read a Nil from the wire.
func (Embed) MarshalMsg ¶ added in v1.1.0
MarshalMsg implements msgp.Marshaler
func (Embed) Msgsize ¶ added in v1.1.0
Msgsize returns an upper bound estimate of the number of bytes occupied by the serialized message
func (*Embed) UnmarshalMsg ¶ added in v1.1.0
UnmarshalMsg implements msgp.Unmarshaler
func (*Embed) UnmarshalMsgWithCfg ¶ added in v1.1.0
type HDR ¶ added in v1.0.42
type HDR struct { // Nc is supplied to reveal the LocalAddr() or RemoteAddr() end points. // Do not read from, or write to, this connection; // that will cause the RPC connection to fail. Nc net.Conn `msg:"-"` Created time.Time `zid:"0"` // HDR creation time stamp. From string `zid:"1"` // originator host:port address. To string `zid:"2"` // destination host:port address. Subject string `zid:"3"` // in net/rpc, the "Service.Method" ServiceName Seqno uint64 `zid:"4"` // user (client) set sequence number for each call (same on response). Typ CallType `zid:"5"` // see constants below. CallID string `zid:"6"` // 20 bytes pseudo random base-64 coded string (same on response). Serial int64 `zid:"7"` // system serial number }
HDR provides header information and details about the transport. It is the first thing in every Message. It is public so that clients can understand the context of their calls. Traditional `net/rpc` API users can use the `ctx context.Context` first argument form of callback methods and get an *HDR with ctx.Value("HDR") as in the README.md introduction. Reproduced here:
func (s *Service) GetsContext(ctx context.Context, args *Args, reply *Reply) error { if hdr := ctx.Value("HDR"); hdr != nil { h, ok := hdr.(*rpc25519.HDR) if ok { fmt.Printf("GetsContext called with HDR = '%v'; "+ "HDR.Nc.RemoteAddr() gives '%v'; HDR.Nc.LocalAddr() gives '%v'\n", h.String(), h.Nc.RemoteAddr(), h.Nc.LocalAddr()) } } else { fmt.Println("HDR not found") } }
func HDRFromBytes ¶ added in v1.0.42
func HDRFromGreenpack ¶ added in v1.0.42
HDRFromGreenpack will unmarshal the header into the returned struct. The [greenpack format](https://github.com/glycerine/greenpack) is expected.
func (*HDR) AsGreenpack ¶ added in v1.0.42
AsGreenpack will marshall hdr into the o output bytes. The scratch bytes can be nil or reused and returned to avoid allocation. The [greenpack format](https://github.com/glycerine/greenpack) is used.
func (*HDR) DecodeMsg ¶ added in v1.0.42
DecodeMsg implements msgp.Decodable We treat empty fields as if we read a Nil from the wire.
func (*HDR) Equal ¶ added in v1.0.42
Equal compares two *HDR structs field by field for structural equality
func (*HDR) MarshalMsg ¶ added in v1.0.42
MarshalMsg implements msgp.Marshaler
func (*HDR) Msgsize ¶ added in v1.0.42
Msgsize returns an upper bound estimate of the number of bytes occupied by the serialized message
func (*HDR) UnmarshalMsg ¶ added in v1.0.42
UnmarshalMsg implements msgp.Unmarshaler
func (*HDR) UnmarshalMsgWithCfg ¶ added in v1.0.42
type Hello ¶ added in v1.1.30
type Hello struct {
Placeholder int `zid:"0"` // must have public field or greenpack will ignore it.
}
func (*Hello) DecodeMsg ¶ added in v1.1.30
DecodeMsg implements msgp.Decodable We treat empty fields as if we read a Nil from the wire.
func (Hello) MarshalMsg ¶ added in v1.1.30
MarshalMsg implements msgp.Marshaler
func (Hello) Msgsize ¶ added in v1.1.30
Msgsize returns an upper bound estimate of the number of bytes occupied by the serialized message
func (*Hello) UnmarshalMsg ¶ added in v1.1.30
UnmarshalMsg implements msgp.Unmarshaler
func (*Hello) UnmarshalMsgWithCfg ¶ added in v1.1.30
type InvalidRequest ¶ added in v1.1.0
type InvalidRequest struct {
Placeholder int `zid:"0"`
}
InvalidRequest used instead of struct{} since greenpack needs one member element.
func (*InvalidRequest) DecodeMsg ¶ added in v1.1.0
func (z *InvalidRequest) DecodeMsg(dc *msgp.Reader) (err error)
DecodeMsg implements msgp.Decodable We treat empty fields as if we read a Nil from the wire.
func (InvalidRequest) EncodeMsg ¶ added in v1.1.0
func (z InvalidRequest) EncodeMsg(en *msgp.Writer) (err error)
EncodeMsg implements msgp.Encodable
func (InvalidRequest) MarshalMsg ¶ added in v1.1.0
func (z InvalidRequest) MarshalMsg(b []byte) (o []byte, err error)
MarshalMsg implements msgp.Marshaler
func (InvalidRequest) Msgsize ¶ added in v1.1.0
func (z InvalidRequest) Msgsize() (s int)
Msgsize returns an upper bound estimate of the number of bytes occupied by the serialized message
func (*InvalidRequest) UnmarshalMsg ¶ added in v1.1.0
func (z *InvalidRequest) UnmarshalMsg(bts []byte) (o []byte, err error)
UnmarshalMsg implements msgp.Unmarshaler
func (*InvalidRequest) UnmarshalMsgWithCfg ¶ added in v1.1.0
func (z *InvalidRequest) UnmarshalMsgWithCfg(bts []byte, cfg *msgp.RuntimeConfig) (o []byte, err error)
type Message ¶
type Message struct { // HDR contains header information. HDR HDR `zid:"0"` // JobSerz is the "body" of the message. // The user provides and interprets this. JobSerz []byte `zid:"1"` // JobErrs returns error information from the server-registered // user-defined callback functions. JobErrs string `zid:"2"` // Err is not serialized on the wire by the server. // It communicates only local (client/server side) information. Callback // functions should convey errors in JobErrs or in-band within // JobSerz. Err error `msg:"-"` // DoneCh will receive this Message itself when the call completes. // It must be buffered, with at least capacity 1. // NewMessage() automatically allocates DoneCh correctly and // should be used when creating a new Message. DoneCh chan *Message `msg:"-"` }
Message transports JobSerz []byte slices for the user, who can de-serialize them they wish. The HDR header field provides transport details.
func MessageFromGreenpack ¶ added in v1.0.28
MessageFromGreenpack unmarshals the by slice into a Message and returns it. The [greenpack format](https://github.com/glycerine/greenpack) is expected.
func NewMessage ¶
func NewMessage() *Message
NewMessage allocates a new Message with a DoneCh properly created (buffered 1).
func NewMessageFromBytes ¶
NewMessageFromBytes calls NewMessage() and sets by as the JobSerz field.
func (*Message) AsGreenpack ¶ added in v1.0.29
AsGreenpack marshalls m into o. The scratch workspace can be nil or reused to avoid allocation. The [greenpack format](https://github.com/glycerine/greenpack) is used.
func (*Message) DecodeMsg ¶ added in v1.0.26
DecodeMsg implements msgp.Decodable We treat empty fields as if we read a Nil from the wire.
func (*Message) MarshalMsg ¶ added in v1.0.26
MarshalMsg implements msgp.Marshaler
func (*Message) Msgsize ¶ added in v1.0.26
Msgsize returns an upper bound estimate of the number of bytes occupied by the serialized message
func (*Message) UnmarshalMsg ¶ added in v1.0.26
UnmarshalMsg implements msgp.Unmarshaler
func (*Message) UnmarshalMsgWithCfg ¶ added in v1.0.26
type NetConnWrapper ¶ added in v1.0.5
type NetConnWrapper struct { quic.Stream quic.Connection }
NetConnWrapper is exported so that clients like `goq` and others that want to inspect that context of their calls can do so.
type OneWayFunc ¶ added in v1.0.39
type OneWayFunc func(req *Message)
OneWayFunc is the simpler sibling to the above. A OneWayFunc will not return anything to the sender.
As above req.JobSerz [] byte contains the job payload.
type Reply ¶ added in v1.1.0
type Reply struct {
C int `zid:"0"`
}
func (*Reply) DecodeMsg ¶ added in v1.1.0
DecodeMsg implements msgp.Decodable We treat empty fields as if we read a Nil from the wire.
func (Reply) MarshalMsg ¶ added in v1.1.0
MarshalMsg implements msgp.Marshaler
func (Reply) Msgsize ¶ added in v1.1.0
Msgsize returns an upper bound estimate of the number of bytes occupied by the serialized message
func (*Reply) UnmarshalMsg ¶ added in v1.1.0
UnmarshalMsg implements msgp.Unmarshaler
func (*Reply) UnmarshalMsgWithCfg ¶ added in v1.1.0
type Request ¶ added in v1.0.42
type Request struct { ServiceMethod string `zid:"0"` // format: "Service.Method" Seq uint64 `zid:"1"` // sequence number chosen by client // contains filtered or unexported fields }
Request is part of the net/rpc API. Its docs:
Request is a header written before every RPC call. It is used internally but documented here as an aid to debugging, such as when analyzing network traffic.
func (*Request) DecodeMsg ¶ added in v1.0.42
DecodeMsg implements msgp.Decodable We treat empty fields as if we read a Nil from the wire.
func (Request) MarshalMsg ¶ added in v1.0.42
MarshalMsg implements msgp.Marshaler
func (Request) Msgsize ¶ added in v1.0.42
Msgsize returns an upper bound estimate of the number of bytes occupied by the serialized message
func (*Request) UnmarshalMsg ¶ added in v1.0.42
UnmarshalMsg implements msgp.Unmarshaler
func (*Request) UnmarshalMsgWithCfg ¶ added in v1.0.42
type Response ¶ added in v1.0.42
type Response struct { ServiceMethod string `zid:"0"` // echoes that of the Request Seq uint64 `zid:"1"` // echoes that of the request Error string `zid:"2"` // error, if any. // contains filtered or unexported fields }
Response is part of the net/rpc API. Its docs:
Response is a header written before every RPC return. It is used internally but documented here as an aid to debugging, such as when analyzing network traffic.
func (*Response) DecodeMsg ¶ added in v1.0.42
DecodeMsg implements msgp.Decodable We treat empty fields as if we read a Nil from the wire.
func (Response) MarshalMsg ¶ added in v1.0.42
MarshalMsg implements msgp.Marshaler
func (Response) Msgsize ¶ added in v1.0.42
Msgsize returns an upper bound estimate of the number of bytes occupied by the serialized message
func (*Response) UnmarshalMsg ¶ added in v1.0.42
UnmarshalMsg implements msgp.Unmarshaler
func (*Response) UnmarshalMsgWithCfg ¶ added in v1.0.42
type Server ¶
type Server struct { // RemoteConnectedCh sends the remote host:port address // when the server gets a new client, // See srv_test.go Test004_server_push for example, // where it is used to avoid a race/panic. RemoteConnectedCh chan *ServerClient // contains filtered or unexported fields }
Servers read and respond to requests. Two APIs are available.
Using the rpc25519.Message based API:
Register1Func() and Register2Func() register callbacks.
Using the net/rpc API:
Server.Register() registers structs with callback methods on them.
The net/rpc API is implemented as a layer on top of the rpc25519.Message based API. Both can be used concurrently if desired.
func NewServer ¶
NewServer will keep its own copy of config. If config is nil, the server will make its own upon Start().
func (*Server) Register ¶ added in v1.0.42
Register implements the net/rpc Server.Register() API. Its docs:
Register publishes in the server the set of methods of the receiver value that satisfy the following conditions:
- exported method of exported type
- two arguments, both of exported type
- the second argument is a pointer
- one return value, of type error
It returns an error if the receiver is not an exported type or has no suitable methods. It also logs the error using package log. The client accesses each method using a string of the form "Type.Method", where Type is the receiver's concrete type.
rpc25519 addendum:
Callback methods in the `net/rpc` style traditionally look like this first `NoContext` example below. We now allow a context.Context as an additional first parameter. The ctx will have an "HDR" value set on it giving a pointer to the `rpc25519.HDR` header from the incoming Message.
func (s *Service) NoContext(args *Args, reply *Reply) error
* new:
func (s *Service) GetsContext(ctx context.Context, args *Args, reply *Reply) error { if hdr := ctx.Value("HDR"); hdr != nil { h, ok := hdr.(*rpc25519.HDR) if ok { fmt.Printf("GetsContext called with HDR = '%v'; "+ "HDR.Nc.RemoteAddr() gives '%v'; HDR.Nc.LocalAddr() gives '%v'\n", h.String(), h.Nc.RemoteAddr(), h.Nc.LocalAddr()) } } else { fmt.Println("HDR not found") } }
func (*Server) Register1Func ¶ added in v1.0.39
func (s *Server) Register1Func(callme1 OneWayFunc)
Register1Func tells the server about a func or method that will not reply. See the OneWayFunc definition.
func (*Server) Register2Func ¶ added in v1.0.39
func (s *Server) Register2Func(callme2 TwoWayFunc)
Register2Func tells the server about a func or method that will have a returned Message value. See the TwoWayFunc definition.
func (*Server) RegisterName ¶ added in v1.0.42
RegisterName is like [Register] but uses the provided name for the type instead of the receiver's concrete type.
func (*Server) SendMessage ¶
func (s *Server) SendMessage(callID, subject, destAddr string, data []byte, seqno uint64, errWriteDur *time.Duration) error
SendMessage can be used on the server to push data to one of the connected clients; that found at destAdddr.
A NewMessage() Message will be created and JobSerz will contain the data. The HDR fields Subject, CallID, and Seqno will also be set from the arguments. If callID argument is the empty string, we will use a crypto/rand randomly generated one.
If the destAddr is not already connected to the server, the ErrNetConnectionNotFound error will be returned.
errWriteDur is how long we pause waiting for the writing goroutine to send the message or give us a fast error reply. Early discovery of client disconnect can allow us to try other (worker) clients, rather than wait for pings or other slow error paths.
The errWriteDur can be set to a few seconds if this would save the caller a minute of two of waiting to discover the send is unlikely to suceed; or to time.Duration(0) if they want no pause after writing Message to the connection. The default is 30 msec. It is a guess and aims at balance: allowing enough time to get an error back from quic-go if we are going to discover "Application error 0x0 (remote)" right away, and not wanting to stall the caller too much.
type ServerClient ¶ added in v1.0.135
type ServerClient struct { Remote string GoneCh chan struct{} }
type ServerCodec ¶ added in v1.0.42
type ServerCodec interface { ReadRequestHeader(*Request) error ReadRequestBody(msgp.Decodable) error WriteResponse(*Response, msgp.Encodable) error // Close can be called multiple times and must be idempotent. Close() error }
ServerCodec is part of the net/rpc API. Its docs:
A ServerCodec implements reading of RPC requests and writing of RPC responses for the server side of an RPC session. The server calls [ServerCodec.ReadRequestHeader] and [ServerCodec.ReadRequestBody] in pairs to read requests from the connection, and it calls [ServerCodec.WriteResponse] to write a response back. The server calls [ServerCodec.Close] when finished with the connection. ReadRequestBody may be called with a nil argument to force the body of the request to be read and discarded. See NewClient's comment for information about concurrent access.
type ServerError ¶ added in v1.0.42
type ServerError string
ServerError represents an error that has been returned from the remote side of the RPC connection.
func (ServerError) Error ¶ added in v1.0.42
func (e ServerError) Error() string
type Simple ¶ added in v1.1.0
type Simple int
func (*Simple) DecodeMsg ¶ added in v1.1.0
DecodeMsg implements msgp.Decodable We treat empty fields as if we read a Nil from the wire.
func (Simple) MarshalMsg ¶ added in v1.1.0
MarshalMsg implements msgp.Marshaler
func (Simple) Msgsize ¶ added in v1.1.0
Msgsize returns an upper bound estimate of the number of bytes occupied by the serialized message
func (*Simple) UnmarshalMsg ¶ added in v1.1.0
UnmarshalMsg implements msgp.Unmarshaler
func (*Simple) UnmarshalMsgWithCfg ¶ added in v1.1.0
type TwoWayFunc ¶ added in v1.0.39
TwoWayFunc is the user's own function that they register with the server for remote procedure calls.
The user's Func may not want to return anything. In that case they should register a OneWayFunc instead.
req.JobSerz []byte contains the job payload.
Implementers of TwoWayFunc should assign their return []byte to reply.JobSerz. reply.Jobserz can also be left nil, of course.
Any errors can be returned on reply.JobErrs; this is optional. Note that JobErrs is a string value rather than an error.
The system will overwrite the reply.HDR field when sending the reply, so the user should not bother trying to alter it. The one exception to this rule is the reply.HDR.Subject string, which can be set by the user to return user-defined information. The reply will still be matched to the request on the HDR.Seqno, so a change of HDR.Subject will not change which goroutine receives the reply.