2019-07-02 12:40:25 +00:00
|
|
|
package lp2p
|
2019-07-01 09:09:48 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
"github.com/libp2p/go-libp2p"
|
2019-07-04 15:50:48 +00:00
|
|
|
"github.com/libp2p/go-libp2p-core/host"
|
2019-07-01 09:09:48 +00:00
|
|
|
p2pbhost "github.com/libp2p/go-libp2p/p2p/host/basic"
|
|
|
|
mafilter "github.com/libp2p/go-maddr-filter"
|
|
|
|
ma "github.com/multiformats/go-multiaddr"
|
|
|
|
mamask "github.com/whyrusleeping/multiaddr-filter"
|
|
|
|
)
|
|
|
|
|
|
|
|
func AddrFilters(filters []string) func() (opts Libp2pOpts, err error) {
|
|
|
|
return func() (opts Libp2pOpts, err error) {
|
|
|
|
for _, s := range filters {
|
|
|
|
f, err := mamask.NewMask(s)
|
|
|
|
if err != nil {
|
|
|
|
return opts, fmt.Errorf("incorrectly formatted address filter in config: %s", s)
|
|
|
|
}
|
2020-05-27 20:53:20 +00:00
|
|
|
opts.Opts = append(opts.Opts, libp2p.FilterAddresses(f)) //golint:staticcheck
|
2019-07-01 09:09:48 +00:00
|
|
|
}
|
|
|
|
return opts, nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func makeAddrsFactory(announce []string, noAnnounce []string) (p2pbhost.AddrsFactory, error) {
|
|
|
|
var annAddrs []ma.Multiaddr
|
|
|
|
for _, addr := range announce {
|
|
|
|
maddr, err := ma.NewMultiaddr(addr)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
annAddrs = append(annAddrs, maddr)
|
|
|
|
}
|
|
|
|
|
|
|
|
filters := mafilter.NewFilters()
|
|
|
|
noAnnAddrs := map[string]bool{}
|
|
|
|
for _, addr := range noAnnounce {
|
|
|
|
f, err := mamask.NewMask(addr)
|
|
|
|
if err == nil {
|
|
|
|
filters.AddFilter(*f, mafilter.ActionDeny)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
maddr, err := ma.NewMultiaddr(addr)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
noAnnAddrs[string(maddr.Bytes())] = true
|
|
|
|
}
|
|
|
|
|
|
|
|
return func(allAddrs []ma.Multiaddr) []ma.Multiaddr {
|
|
|
|
var addrs []ma.Multiaddr
|
|
|
|
if len(annAddrs) > 0 {
|
|
|
|
addrs = annAddrs
|
|
|
|
} else {
|
|
|
|
addrs = allAddrs
|
|
|
|
}
|
|
|
|
|
|
|
|
var out []ma.Multiaddr
|
|
|
|
for _, maddr := range addrs {
|
|
|
|
// check for exact matches
|
|
|
|
ok := noAnnAddrs[string(maddr.Bytes())]
|
|
|
|
// check for /ipcidr matches
|
|
|
|
if !ok && !filters.AddrBlocked(maddr) {
|
|
|
|
out = append(out, maddr)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return out
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func AddrsFactory(announce []string, noAnnounce []string) func() (opts Libp2pOpts, err error) {
|
|
|
|
return func() (opts Libp2pOpts, err error) {
|
|
|
|
addrsFactory, err := makeAddrsFactory(announce, noAnnounce)
|
|
|
|
if err != nil {
|
|
|
|
return opts, err
|
|
|
|
}
|
|
|
|
opts.Opts = append(opts.Opts, libp2p.AddrsFactory(addrsFactory))
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func listenAddresses(addresses []string) ([]ma.Multiaddr, error) {
|
|
|
|
var listen []ma.Multiaddr
|
|
|
|
for _, addr := range addresses {
|
|
|
|
maddr, err := ma.NewMultiaddr(addr)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("failure to parse config.Addresses.Swarm: %s", addresses)
|
|
|
|
}
|
|
|
|
listen = append(listen, maddr)
|
|
|
|
}
|
|
|
|
|
|
|
|
return listen, nil
|
|
|
|
}
|
|
|
|
|
2019-07-04 15:50:48 +00:00
|
|
|
func StartListening(addresses []string) func(host host.Host) error {
|
|
|
|
return func(host host.Host) error {
|
|
|
|
listenAddrs, err := listenAddresses(addresses)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2019-07-01 09:09:48 +00:00
|
|
|
|
2019-07-04 15:50:48 +00:00
|
|
|
// Actually start listening:
|
|
|
|
if err := host.Network().Listen(listenAddrs...); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2019-07-01 09:09:48 +00:00
|
|
|
|
2019-07-04 15:50:48 +00:00
|
|
|
// list out our addresses
|
|
|
|
addrs, err := host.Network().InterfaceListenAddresses()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
log.Infof("Swarm listening at: %s", addrs)
|
|
|
|
return nil
|
2019-07-01 09:09:48 +00:00
|
|
|
}
|
|
|
|
}
|