Documentation ¶
Index ¶
- func GetMaxRequestSize(net Cmix, e2eGrp *cyclic.Group) int
- func TransmitRequest(recipient contact.Contact, tag string, payload []byte, responseCB Response, ...) ([]id.Round, receptionID.EphemeralIdentity, error)
- type Cmix
- type ListenCmix
- type Listener
- type Receiver
- type Request
- func (r *Request) GetMaxParts() uint8
- func (r *Request) GetMaxResponseLength() int
- func (r *Request) GetMaxResponsePartSize() int
- func (r *Request) GetPartner() *id.ID
- func (r *Request) GetPayload() []byte
- func (r *Request) GetTag() string
- func (r *Request) GoString() string
- func (r *Request) Respond(payload []byte, cMixParams cmix.CMIXParams, timeout time.Duration) ([]id.Round, error)
- type RequestCmix
- type RequestParams
- type Response
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func GetMaxRequestSize ¶
GetMaxRequestSize returns the maximum size of a request payload.
func TransmitRequest ¶
func TransmitRequest(recipient contact.Contact, tag string, payload []byte, responseCB Response, params RequestParams, net Cmix, rng csprng.Source, e2eGrp *cyclic.Group) ([]id.Round, receptionID.EphemeralIdentity, error)
TransmitRequest sends a request to the recipient with the given tag containing the given payload. The request is identified as coming from a new user ID and the recipient of the request responds to that address. As a result, this request does not reveal the identity of the sender.
The current implementation allows for up to maxNumRequestParts cMix request payloads. GetMaxRequestSize can be used to get the max size.
The network follower must be running and healthy to transmit.
Types ¶
type Cmix ¶
type Cmix interface { IsHealthy() bool GetAddressSpace() uint8 GetMaxMessageLength() int DeleteClientFingerprints(identity *id.ID) AddFingerprint(identity *id.ID, fingerprint format.Fingerprint, mp message.Processor) error AddIdentity(id *id.ID, validUntil time.Time, persistent bool, fallthroughProcessor message.Processor) Send(recipient *id.ID, fingerprint format.Fingerprint, service cmix.Service, payload, mac []byte, cmixParams cmix.CMIXParams) ( rounds.Round, ephemeral.Id, error) AddService(clientID *id.ID, newService message.Service, response message.Processor) DeleteService(clientID *id.ID, toDelete message.Service, processor message.Processor) GetInstance() *network.Instance CheckInProgressMessages() }
Cmix is a sub-interface of the cmix.Client. It contains the methods relevant to what is used in this package.
type ListenCmix ¶
type ListenCmix interface { RequestCmix AddFingerprint(identity *id.ID, fingerprint format.Fingerprint, mp cMixMsg.Processor) error AddService( clientID *id.ID, newService cMixMsg.Service, response cMixMsg.Processor) DeleteService( clientID *id.ID, toDelete cMixMsg.Service, processor cMixMsg.Processor) CheckInProgressMessages() }
ListenCmix interface matches a subset of cmix.Client methods used for Listen.
type Listener ¶
type Listener interface {
// Stop unregisters the listener
Stop()
}
func Listen ¶
func Listen(tag string, myID *id.ID, privKey *cyclic.Int, net ListenCmix, e2eGrp *cyclic.Group, cb Receiver) Listener
Listen allows a server to listen for single use requests. It will register a service relative to the tag and myID as the identifier. Only a single listener can be active for a tag-myID pair, and an error will be returned if that is violated. When requests are received, they will be called on the Receiver interface.
type Receiver ¶
type Receiver interface {
Callback(*Request, receptionID.EphemeralIdentity, []rounds.Round)
}
Receiver contains the callback interface for any handler which will process the reception of a single request. Used in Listen.
type Request ¶
type Request struct {
// contains filtered or unexported fields
}
Request contains the information contained in a single-use request message.
func BuildTestRequest ¶
BuildTestRequest can be used for mocking a Request. Should only be used for tests.
func (*Request) GetMaxParts ¶
GetMaxParts returns the maximum number of messages allowed to send in the reply.
func (*Request) GetMaxResponseLength ¶
GetMaxResponseLength returns the maximum size of the entire response message.
func (*Request) GetMaxResponsePartSize ¶
GetMaxResponsePartSize returns maximum payload size for an individual part of the response message.
func (*Request) GetPartner ¶
GetPartner returns a copy of the sender ID.
func (*Request) GetPayload ¶
GetPayload returns the payload that came in the request
func (*Request) GoString ¶
GoString returns string showing the values of all the fields of Request. Adheres to the fmt.GoStringer interface.
func (*Request) Respond ¶
func (r *Request) Respond(payload []byte, cMixParams cmix.CMIXParams, timeout time.Duration) ([]id.Round, error)
Respond is used to respond to the request. It sends a payload up to Request.GetMaxResponseLength. It will chunk the message into multiple cMix messages if it is too long for a single message. It will fail if a single cMix message cannot be sent.
type RequestCmix ¶
type RequestCmix interface { GetMaxMessageLength() int Send(recipient *id.ID, fingerprint format.Fingerprint, service cmix.Service, payload, mac []byte, cmixParams cmix.CMIXParams) (rounds.Round, ephemeral.Id, error) GetInstance() *network.Instance }
RequestCmix interface matches a subset of the cmix.Client methods used by the Request for easier testing.
type RequestParams ¶
type RequestParams struct { // Timeout is the duration to wait before timing out while sending a request Timeout time.Duration // MaxResponseMessages is the maximum number of messages allowed in the // response to the request MaxResponseMessages uint8 // CmixParams is the parameters used in sending a cMix message CmixParams cmix.CMIXParams }
RequestParams contains configurable parameters for sending a single-use request message.
func GetDefaultRequestParams ¶
func GetDefaultRequestParams() RequestParams
GetDefaultRequestParams returns a RequestParams with the default configuration.
func GetParameters ¶
func GetParameters(params string) (RequestParams, error)
GetParameters returns the default network parameters, or override with given parameters, if set.
func (RequestParams) MarshalJSON ¶
func (rp RequestParams) MarshalJSON() ([]byte, error)
MarshalJSON adheres to the json.Marshaler interface.
func (*RequestParams) UnmarshalJSON ¶
func (rp *RequestParams) UnmarshalJSON(data []byte) error
UnmarshalJSON adheres to the json.Unmarshaler interface.
type Response ¶
type Response interface { Callback(payload []byte, receptionID receptionID.EphemeralIdentity, rounds []rounds.Round, err error) }
Response contains the callback interface for any handler which will process the response of a single request. Used in TransmitRequest.