Documentation ¶
Index ¶
- Variables
- type DiscoverOptions
- type Node
- type Options
- type Peer
- func (p *Peer) Addr() netip.AddrPort
- func (p *Peer) Close() error
- func (p *Peer) Conn() net.Conn
- func (p *Peer) MetaData() *data.MetaData
- func (p *Peer) Receive(last *data.LastMessage)
- func (p *Peer) Release()
- func (p *Peer) Signer() crypto.Signer
- func (p *Peer) String() string
- func (p *Peer) Updates() data.Channel
- type Storage
Constants ¶
This section is empty.
Variables ¶
var (
ErrAlreadyConnected = errors.New("already connected")
)
Functions ¶
This section is empty.
Types ¶
type DiscoverOptions ¶ added in v1.1.1
type Node ¶
type Node struct {
// contains filtered or unexported fields
}
func New ¶
func New( clipboard clipboard.Manager, peers *Storage, localClipboard data.Channel, opt *Options, ) *Node
New creates a new instance of Node with the specified settings.
func (*Node) Broadcast ¶
Broadcast sends a message to all connected nodes except those specified in the 'ignore' list. It first checks if the message is a duplicate of the last sent message by comparing their IDs and hashes. If the message is a duplicate, it is not sent. For each connection in the storage, it writes the message to the connection's writer. The method logs the sent messages and their hashes for debugging purposes. The 'msg' parameter is the message to be broadcast. The 'ignore' parameter is a variadic list of AddrPort to exclude from the broadcast.
func (*Node) ConnectTo ¶
ConnectTo establishes a TCP connection to a remote clipboard at the specified address. It adds the connection to the node's storage and starts handling the connection using 'handleConnection'. The 'addr' parameter should be in the format "host:port" to specify the remote clipboard's address. If the connection is successfully established, it returns nil; otherwise, it returns an error.
func (*Node) MonitorBuffer ¶
func (n *Node) MonitorBuffer()
MonitorBuffer starts monitoring the clipboard and subsequently sending data to other nodes
func (*Node) Start ¶
Start starts the node by listening for incoming connections on the specified public port. It also starts a clipboard monitor to periodically scan and update the local clipboard. When a new connection is accepted, it invokes the 'handleConnection' method to handle the connection. The 'scanDelay' parameter determines the interval at which the clipboard is scanned and updated. The method returns an error if it fails to start listening.
type Peer ¶
type Peer struct {
// contains filtered or unexported fields
}
func AcquirePeer ¶
func (*Peer) Receive ¶
func (p *Peer) Receive(last *data.LastMessage)