Documentation ¶
Index ¶
- type DHT
- func (dht *DHT) Bootstrap() error
- func (dht *DHT) CreateSocket() error
- func (dht *DHT) Disconnect() error
- func (dht *DHT) Get(key string) (data []byte, found bool, err error)
- func (dht *DHT) GetNetworkAddr() string
- func (dht *DHT) GetSelfID() string
- func (dht *DHT) Listen() error
- func (dht *DHT) NumNodes() int
- func (dht *DHT) Store(data []byte) (id string, err error)
- type MemoryStore
- func (ms *MemoryStore) Delete(key []byte)
- func (ms *MemoryStore) ExpireKeys()
- func (ms *MemoryStore) GetAllKeysForReplication() [][]byte
- func (ms *MemoryStore) GetKey(data []byte) []byte
- func (ms *MemoryStore) Init()
- func (ms *MemoryStore) Retrieve(key []byte) (data []byte, found bool)
- func (ms *MemoryStore) Store(key []byte, data []byte, replication time.Time, expiration time.Time, ...) error
- type NetworkNode
- type Options
- type Store
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type DHT ¶
type DHT struct {
// contains filtered or unexported fields
}
DHT represents the state of the local node in the distributed hash table
func (*DHT) Bootstrap ¶
Bootstrap attempts to bootstrap the network using the BootstrapNodes provided to the Options struct. This will trigger an iterativeFindNode to the provided BootstrapNodes.
func (*DHT) CreateSocket ¶
CreateSocket attempts to open a UDP socket on the port provided to options
func (*DHT) Disconnect ¶
Disconnect will trigger a disconnect from the network. All underlying sockets will be closed.
func (*DHT) Get ¶
Get retrieves data from the networking using key. Key is the base58 encoded identifier of the data.
func (*DHT) GetNetworkAddr ¶
GetNetworkAddr returns the publicly accessible IP and Port of the local node
type MemoryStore ¶
type MemoryStore struct {
// contains filtered or unexported fields
}
MemoryStore is a simple in-memory key/value store used for unit testing, and the CLI example
func (*MemoryStore) Delete ¶
func (ms *MemoryStore) Delete(key []byte)
Delete deletes a key/value pair from the MemoryStore
func (*MemoryStore) ExpireKeys ¶
func (ms *MemoryStore) ExpireKeys()
ExpireKeys should expire all key/values due for expiration.
func (*MemoryStore) GetAllKeysForReplication ¶
func (ms *MemoryStore) GetAllKeysForReplication() [][]byte
GetAllKeysForReplication should return the keys of all data to be replicated across the network. Typically all data should be replicated every tReplicate seconds.
func (*MemoryStore) GetKey ¶
func (ms *MemoryStore) GetKey(data []byte) []byte
GetKey returns the key for data
type NetworkNode ¶
type NetworkNode struct { // ID is a 20 byte unique identifier ID []byte // IP is the IPv4 address of the node IP net.IP // Port is the port of the node Port int }
NetworkNode is the over-the-wire representation of a node
func NewNetworkNode ¶
func NewNetworkNode(ip string, port string) *NetworkNode
NewNetworkNode creates a new NetworkNode for bootstrapping
type Options ¶
type Options struct { ID []byte // The local IPv4 or IPv6 address IP string // The local port to listen for connections on Port string // Whether or not to use the STUN protocol to determine public IP and Port // May be necessary if the node is behind a NAT UseStun bool // Specifies the the host of the STUN server. If left empty will use the // default specified in go-stun. StunAddr string // A logger interface Logger log.Logger // The nodes being used to bootstrap the network. Without a bootstrap // node there is no way to connect to the network. NetworkNodes can be // initialized via dht.NewNetworkNode() BootstrapNodes []*NetworkNode // The time after which a key/value pair expires; // this is a time-to-live (TTL) from the original publication date TExpire time.Duration // Seconds after which an otherwise unaccessed bucket must be refreshed TRefresh time.Duration // The interval between Kademlia replication events, when a node is // required to publish its entire database TReplicate time.Duration // The time after which the original publisher must // republish a key/value pair. Currently not implemented. TRepublish time.Duration // The maximum time to wait for a response from a node before discarding // it from the bucket TPingMax time.Duration // The maximum time to wait for a response to any message TMsgTimeout time.Duration }
Options contains configuration options for the local node
type Store ¶
type Store interface { // Store should store a key/value pair for the local node with the // given replication and expiration times. Store(key []byte, data []byte, replication time.Time, expiration time.Time, publisher bool) error // Retrieve should return the local key/value if it exists. Retrieve(key []byte) (data []byte, found bool) // Delete should delete a key/value pair from the Store Delete(key []byte) // Init initializes the Store Init() // GetAllKeysForReplication should return the keys of all data to be // replicated across the network. Typically all data should be // replicated every tReplicate seconds. GetAllKeysForReplication() [][]byte // ExpireKeys should expire all key/values due for expiration. ExpireKeys() // GetKey returns the key for data GetKey(data []byte) []byte }
Store is the interface for implementing the storage mechanism for the DHT.