api

package
v0.1.3 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Oct 18, 2021 License: GPL-3.0 Imports: 10 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func ConnectionID

func ConnectionID(conn Connection) string

ConnectionID calculates the id of the given Connection

Types

type AdapterMock

type AdapterMock struct {
	In  chan Message
	Out chan Message
	// contains filtered or unexported fields
}

AdapterMock is a mock websocket adapter

func (*AdapterMock) IsCloseError

func (am *AdapterMock) IsCloseError(err error) bool

IsCloseError returns true if the error originate as part of some close procedure

func (*AdapterMock) Receive

func (am *AdapterMock) Receive(conn Connection, v interface{}) error

Receive reads a struct from the in channel

func (*AdapterMock) RegisterHandler

func (am *AdapterMock) RegisterHandler(mux *http.ServeMux, endPoint string, handler EndPointHandler)

RegisterHandler not implemented

func (*AdapterMock) Send

func (am *AdapterMock) Send(conn Connection, v interface{}) error

Send sends the given struct to the out channel

type Connection

type Connection interface {
	Close() error
	LocalAddr() net.Addr
}

Connection is an interface to abstract the actual websocket connection implementation

type DutyRole

type DutyRole string

DutyRole is the role of the duty

const (
	// RoleAttester is an enum for attester role
	RoleAttester DutyRole = "ATTESTER"
	// RoleAggregator is an enum for aggregator role
	RoleAggregator DutyRole = "AGGREGATOR"
	// RoleProposer is an enum for proposer role
	RoleProposer DutyRole = "PROPOSER"
)

type EndPointHandler

type EndPointHandler = func(conn Connection)

EndPointHandler is an interface to abstract the actual websocket handler implementation

type Message

type Message struct {
	// Type is the type of message
	Type MessageType `json:"type"`
	// Filter
	Filter MessageFilter `json:"filter"`
	// Values holds the results, optional as it's relevant for response
	Data interface{} `json:"data,omitempty"`
}

Message represents an exporter message

type MessageFilter

type MessageFilter struct {
	// From is the starting index of the desired data
	From int64 `json:"from"`
	// To is the ending index of the desired data
	To int64 `json:"to"`
	// Role is the duty type enum, optional as it's relevant for IBFT data
	Role DutyRole `json:"role,omitempty"`
	// PublicKey is optional, used for fetching decided messages or information about specific validator/operator
	PublicKey string `json:"publicKey,omitempty"`
}

MessageFilter is a criteria for query in request messages and projection in responses

type MessageType

type MessageType string

MessageType is the type of message being sent

const (
	// TypeValidator is an enum for validator type messages
	TypeValidator MessageType = "validator"
	// TypeOperator is an enum for operator type messages
	TypeOperator MessageType = "operator"
	// TypeDecided is an enum for ibft type messages
	TypeDecided MessageType = "decided"
	// TypeError is an enum for error type messages
	TypeError MessageType = "error"
)

type NetworkMessage

type NetworkMessage struct {
	Msg  Message
	Err  error
	Conn Connection
}

NetworkMessage wraps an actual message with more information

type OperatorsMessage

type OperatorsMessage struct {
	Data []storage.OperatorInformation `json:"data,omitempty"`
}

OperatorsMessage represents message for operators response

type QueryMessageHandler added in v0.1.2

type QueryMessageHandler func(nm *NetworkMessage)

QueryMessageHandler handles the given message

type ValidatorsMessage

type ValidatorsMessage struct {
	Data []storage.ValidatorInformation `json:"data,omitempty"`
}

ValidatorsMessage represents message for validators response

type WebSocketAdapter

type WebSocketAdapter interface {
	RegisterHandler(mux *http.ServeMux, endPoint string, handler EndPointHandler)
	Send(conn Connection, v interface{}) error
	Receive(conn Connection, v interface{}) error
	IsCloseError(err error) bool
}

WebSocketAdapter is an abstraction to decouple actual library implementation

func NewAdapterMock

func NewAdapterMock(logger *zap.Logger) WebSocketAdapter

NewAdapterMock creates a new adapter for tests

type WebSocketServer

type WebSocketServer interface {
	Start(addr string) error
	OutboundSubject() pubsub.Publisher
	UseQueryHandler(handler QueryMessageHandler)
}

WebSocketServer is responsible for managing all

func NewWsServer

func NewWsServer(logger *zap.Logger, adapter WebSocketAdapter, handler QueryMessageHandler, mux *http.ServeMux) WebSocketServer

NewWsServer creates a new instance

Directories

Path Synopsis
adapters

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL