Documentation ¶
Index ¶
- func BuildSimpleTable(bvns []string) []protocol.Route
- func RouteEnvelopes(routeAccount func(*url.URL) (string, error), envs ...*protocol.Envelope) (string, error)
- type MessageRouter
- type ResponseSubmit
- type RouteTree
- type Router
- type RouterInstance
- func (r *RouterInstance) RequestAPIv2(ctx context.Context, partitionId, method string, params, result interface{}) error
- func (r *RouterInstance) Route(envs ...*protocol.Envelope) (string, error)
- func (r *RouterInstance) RouteAccount(account *url.URL) (string, error)
- func (r *RouterInstance) Submit(ctx context.Context, partitionId string, tx *protocol.Envelope, ...) (*ResponseSubmit, error)
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func BuildSimpleTable ¶
Types ¶
type MessageRouter ¶
type MessageRouter struct {
Router
}
MessageRouter routes messages using a Router.
type ResponseSubmit ¶
type ResponseSubmit struct { Code uint32 Data []byte Log string Info string Codespace string MempoolError string }
ResponseSubmit is the response from a call to Submit.
type RouteTree ¶
type RouteTree struct {
// contains filtered or unexported fields
}
func NewRouteTree ¶
func NewRouteTree(table *protocol.RoutingTable) (*RouteTree, error)
type Router ¶
type Router interface { RouteAccount(*url.URL) (string, error) Route(...*protocol.Envelope) (string, error) RequestAPIv2(ctx context.Context, partitionId, method string, params, result interface{}) error Submit(ctx context.Context, partition string, tx *protocol.Envelope, pretend, async bool) (*ResponseSubmit, error) }
Router defines a basic interface for routing and sending transactions.
TODO Route and Send should probably be handled separately.
type RouterInstance ¶
type RouterInstance struct {
// contains filtered or unexported fields
}
RouterInstance sends transactions to remote nodes via RPC calls.
func NewRouter ¶
func NewRouter(eventBus *events.Bus, cm connections.ConnectionManager, logger log.Logger) *RouterInstance
func NewStaticRouter ¶
func NewStaticRouter(table *protocol.RoutingTable, cm connections.ConnectionManager, logger log.Logger) (*RouterInstance, error)
NewStaticRouter returns a router that uses a static routing table
func (*RouterInstance) RequestAPIv2 ¶
func (r *RouterInstance) RequestAPIv2(ctx context.Context, partitionId, method string, params, result interface{}) error
func (*RouterInstance) Route ¶
func (r *RouterInstance) Route(envs ...*protocol.Envelope) (string, error)
Route routes the account using modulo routing.
func (*RouterInstance) RouteAccount ¶
func (r *RouterInstance) RouteAccount(account *url.URL) (string, error)
func (*RouterInstance) Submit ¶
func (r *RouterInstance) Submit(ctx context.Context, partitionId string, tx *protocol.Envelope, pretend, async bool) (*ResponseSubmit, error)
Submit submits the transaction to the specified partition. If the partition matches this network's ID, the transaction is broadcasted via the local client. Otherwise the transaction is broadcasted via an RPC client.
Click to show internal directories.
Click to hide internal directories.