py-libp2p/libp2p/transport/transport_interface.py

31 lines
1.0 KiB
Python
Raw Normal View History

2018-10-27 04:09:39 +08:00
from abc import ABC, abstractmethod
2019-08-02 16:32:33 +08:00
from typing import TYPE_CHECKING
if TYPE_CHECKING:
from multiaddr import Multiaddr
from libp2p.peer.id import ID
from libp2p.network.connection.raw_connection_interface import IRawConnection
from .listener_interface import IListener
from .typing import THandler
2018-11-13 02:02:49 +08:00
2018-10-27 04:09:39 +08:00
class ITransport(ABC):
@abstractmethod
2019-08-02 16:32:33 +08:00
async def dial(self, maddr: "Multiaddr", self_id: "ID") -> "IRawConnection":
2018-10-27 04:09:39 +08:00
"""
dial a transport to peer listening on multiaddr
:param multiaddr: multiaddr of peer
:param self_id: peer_id of the dialer (to send to receiver)
2018-10-27 04:09:39 +08:00
:return: list of multiaddrs
"""
@abstractmethod
2019-08-02 16:32:33 +08:00
def create_listener(self, handler_function: "THandler") -> "IListener":
2018-10-27 04:09:39 +08:00
"""
create listener on transport
:param handler_function: a function called when a new conntion is received
that takes a connection as argument which implements interface-connection
:return: a listener object that implements listener_interface.py
"""