mirror of
https://github.com/lightningnetwork/lnd.git
synced 2025-01-19 14:45:23 +01:00
e41c65785f
Move merge of our features into the feature manager, rather than updating our node announcement then retrospectively setting the feature manger's set to the new vector. This allows us to use the feature vector as our single source of truth for announcements.
33 lines
1.1 KiB
Go
33 lines
1.1 KiB
Go
//go:build peersrpc
|
|
// +build peersrpc
|
|
|
|
package peersrpc
|
|
|
|
import (
|
|
"net"
|
|
|
|
"github.com/lightningnetwork/lnd/lnwire"
|
|
"github.com/lightningnetwork/lnd/netann"
|
|
)
|
|
|
|
// Config is the primary configuration struct for the peers RPC subserver.
|
|
// It contains all the items required for the server to carry out its duties.
|
|
// The fields with struct tags are meant to be parsed as normal configuration
|
|
// options, while if able to be populated, the latter fields MUST also be
|
|
// specified.
|
|
type Config struct {
|
|
// GetNodeAnnouncement is used to send our retrieve the current
|
|
// node announcement information.
|
|
GetNodeAnnouncement func() lnwire.NodeAnnouncement
|
|
|
|
// ParseAddr parses an address from its string format to a net.Addr.
|
|
ParseAddr func(addr string) (net.Addr, error)
|
|
|
|
// UpdateNodeAnnouncement updates and broadcasts our node announcement,
|
|
// setting the feature vector provided and applying the
|
|
// NodeAnnModifiers. If no feature updates are required, a nil feature
|
|
// vector should be provided.
|
|
UpdateNodeAnnouncement func(features *lnwire.RawFeatureVector,
|
|
mods ...netann.NodeAnnModifier) error
|
|
}
|