mirror of
https://github.com/libp2p/go-libp2p-core.git
synced 2025-01-01 00:10:07 +08:00
59 lines
1.5 KiB
Go
59 lines
1.5 KiB
Go
|
package network
|
||
|
|
||
|
import (
|
||
|
"io"
|
||
|
|
||
|
ic "github.com/libp2p/go-libp2p-core/crypto"
|
||
|
"github.com/libp2p/go-libp2p-core/peer"
|
||
|
|
||
|
ma "github.com/multiformats/go-multiaddr"
|
||
|
)
|
||
|
|
||
|
// Conn is a connection to a remote peer. It multiplexes streams.
|
||
|
// Usually there is no need to use a Conn directly, but it may
|
||
|
// be useful to get information about the peer on the other side:
|
||
|
// stream.Conn().RemotePeer()
|
||
|
type Conn interface {
|
||
|
io.Closer
|
||
|
|
||
|
ConnSecurity
|
||
|
ConnMultiaddrs
|
||
|
|
||
|
// NewStream constructs a new Stream over this conn.
|
||
|
NewStream() (Stream, error)
|
||
|
|
||
|
// GetStreams returns all open streams over this conn.
|
||
|
GetStreams() []Stream
|
||
|
|
||
|
// Stat stores metadata pertaining to this conn.
|
||
|
Stat() Stat
|
||
|
}
|
||
|
|
||
|
// ConnSecurity is the interface that one can mix into a connection interface to
|
||
|
// give it the security methods.
|
||
|
type ConnSecurity interface {
|
||
|
// LocalPeer returns our peer ID
|
||
|
LocalPeer() peer.ID
|
||
|
|
||
|
// LocalPrivateKey returns our private key
|
||
|
LocalPrivateKey() ic.PrivKey
|
||
|
|
||
|
// RemotePeer returns the peer ID of the remote peer.
|
||
|
RemotePeer() peer.ID
|
||
|
|
||
|
// RemotePublicKey returns the public key of the remote peer.
|
||
|
RemotePublicKey() ic.PubKey
|
||
|
}
|
||
|
|
||
|
// ConnMultiaddrs is an interface mixin for connection types that provide multiaddr
|
||
|
// addresses for the endpoints.
|
||
|
type ConnMultiaddrs interface {
|
||
|
// LocalMultiaddr returns the local Multiaddr associated
|
||
|
// with this connection
|
||
|
LocalMultiaddr() ma.Multiaddr
|
||
|
|
||
|
// RemoteMultiaddr returns the remote Multiaddr associated
|
||
|
// with this connection
|
||
|
RemoteMultiaddr() ma.Multiaddr
|
||
|
}
|