mirror of
https://github.com/status-im/status-go.git
synced 2025-01-21 20:20:29 +00:00
eeca435064
Update vendor Integrate rendezvous into status node Add a test with failover using rendezvous Use multiple servers in client Use discovery V5 by default and test that node can be started with rendezvous discovet Fix linter Update rendezvous client to one with instrumented stream Address feedback Fix test with updated topic limits Apply several suggestions Change log to debug for request errors because we continue execution Remove web3js after rebase Update rendezvous package
128 lines
3.6 KiB
Go
128 lines
3.6 KiB
Go
package stream
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
"fmt"
|
|
"net"
|
|
|
|
ss "github.com/libp2p/go-conn-security"
|
|
pnet "github.com/libp2p/go-libp2p-interface-pnet"
|
|
peer "github.com/libp2p/go-libp2p-peer"
|
|
transport "github.com/libp2p/go-libp2p-transport"
|
|
filter "github.com/libp2p/go-maddr-filter"
|
|
smux "github.com/libp2p/go-stream-muxer"
|
|
manet "github.com/multiformats/go-multiaddr-net"
|
|
)
|
|
|
|
// ErrNilPeer is returned when attempting to upgrade an outbound connection
|
|
// without specifying a peer ID.
|
|
var ErrNilPeer = errors.New("nil peer")
|
|
|
|
// AcceptQueueLength is the number of connections to fully setup before not accepting any new connections
|
|
var AcceptQueueLength = 16
|
|
|
|
// Upgrader is a multistream upgrader that can upgrade an underlying connection
|
|
// to a full transport connection (secure and multiplexed).
|
|
type Upgrader struct {
|
|
Protector pnet.Protector
|
|
Secure ss.Transport
|
|
Muxer smux.Transport
|
|
Filters *filter.Filters
|
|
}
|
|
|
|
// UpgradeListener upgrades the passed multiaddr-net listener into a full libp2p-transport listener.
|
|
func (u *Upgrader) UpgradeListener(t transport.Transport, list manet.Listener) transport.Listener {
|
|
ctx, cancel := context.WithCancel(context.Background())
|
|
l := &listener{
|
|
Listener: list,
|
|
upgrader: u,
|
|
transport: t,
|
|
threshold: newThreshold(AcceptQueueLength),
|
|
incoming: make(chan transport.Conn),
|
|
cancel: cancel,
|
|
ctx: ctx,
|
|
}
|
|
go l.handleIncoming()
|
|
return l
|
|
}
|
|
|
|
// UpgradeOutbound upgrades the given outbound multiaddr-net connection into a
|
|
// full libp2p-transport connection.
|
|
func (u *Upgrader) UpgradeOutbound(ctx context.Context, t transport.Transport, maconn manet.Conn, p peer.ID) (transport.Conn, error) {
|
|
if p == "" {
|
|
return nil, ErrNilPeer
|
|
}
|
|
return u.upgrade(ctx, t, maconn, p)
|
|
}
|
|
|
|
// UpgradeInbound upgrades the given inbound multiaddr-net connection into a
|
|
// full libp2p-transport connection.
|
|
func (u *Upgrader) UpgradeInbound(ctx context.Context, t transport.Transport, maconn manet.Conn) (transport.Conn, error) {
|
|
return u.upgrade(ctx, t, maconn, "")
|
|
}
|
|
|
|
func (u *Upgrader) upgrade(ctx context.Context, t transport.Transport, maconn manet.Conn, p peer.ID) (transport.Conn, error) {
|
|
if u.Filters != nil && u.Filters.AddrBlocked(maconn.RemoteMultiaddr()) {
|
|
log.Debugf("blocked connection from %s", maconn.RemoteMultiaddr())
|
|
maconn.Close()
|
|
return nil, fmt.Errorf("blocked connection from %s", maconn.RemoteMultiaddr())
|
|
}
|
|
|
|
var conn net.Conn = maconn
|
|
if u.Protector != nil {
|
|
pconn, err := u.Protector.Protect(conn)
|
|
if err != nil {
|
|
conn.Close()
|
|
return nil, err
|
|
}
|
|
conn = pconn
|
|
} else if pnet.ForcePrivateNetwork {
|
|
log.Error("tried to dial with no Private Network Protector but usage" +
|
|
" of Private Networks is forced by the enviroment")
|
|
return nil, pnet.ErrNotInPrivateNetwork
|
|
}
|
|
sconn, err := u.setupSecurity(ctx, conn, p)
|
|
if err != nil {
|
|
conn.Close()
|
|
return nil, err
|
|
}
|
|
smconn, err := u.setupMuxer(ctx, sconn, p)
|
|
if err != nil {
|
|
conn.Close()
|
|
return nil, err
|
|
}
|
|
return &transportConn{
|
|
Conn: smconn,
|
|
ConnMultiaddrs: maconn,
|
|
ConnSecurity: sconn,
|
|
transport: t,
|
|
}, nil
|
|
}
|
|
|
|
func (u *Upgrader) setupSecurity(ctx context.Context, conn net.Conn, p peer.ID) (ss.Conn, error) {
|
|
if p == "" {
|
|
return u.Secure.SecureInbound(ctx, conn)
|
|
}
|
|
return u.Secure.SecureOutbound(ctx, conn, p)
|
|
}
|
|
|
|
func (u *Upgrader) setupMuxer(ctx context.Context, conn net.Conn, p peer.ID) (smux.Conn, error) {
|
|
// TODO: The muxer should take a context.
|
|
done := make(chan struct{})
|
|
|
|
var smconn smux.Conn
|
|
var err error
|
|
go func() {
|
|
defer close(done)
|
|
smconn, err = u.Muxer.NewConn(conn, p == "")
|
|
}()
|
|
|
|
select {
|
|
case <-done:
|
|
return smconn, err
|
|
case <-ctx.Done():
|
|
return nil, ctx.Err()
|
|
}
|
|
}
|