2018-10-21 04:55:37 +08:00
|
|
|
from abc import ABC, abstractmethod
|
2019-08-01 06:00:12 +08:00
|
|
|
from typing import Any, List, Sequence
|
2019-07-27 16:27:01 +08:00
|
|
|
|
|
|
|
from multiaddr import Multiaddr
|
2018-10-21 04:55:37 +08:00
|
|
|
|
2019-11-26 12:27:59 +08:00
|
|
|
from libp2p.crypto.keys import PrivateKey, PublicKey
|
|
|
|
|
2019-07-30 15:31:02 +08:00
|
|
|
from .peermetadata_interface import IPeerMetadata
|
|
|
|
|
2019-01-10 02:38:56 +08:00
|
|
|
|
2018-10-21 04:55:37 +08:00
|
|
|
class IPeerData(ABC):
|
2018-11-03 04:16:46 +08:00
|
|
|
@abstractmethod
|
2019-07-27 16:27:01 +08:00
|
|
|
def get_protocols(self) -> List[str]:
|
2018-11-03 04:16:46 +08:00
|
|
|
"""
|
|
|
|
:return: all protocols associated with given peer
|
|
|
|
"""
|
2018-10-21 04:55:37 +08:00
|
|
|
|
2018-11-03 04:16:46 +08:00
|
|
|
@abstractmethod
|
2019-07-27 16:27:01 +08:00
|
|
|
def add_protocols(self, protocols: Sequence[str]) -> None:
|
2018-11-03 04:16:46 +08:00
|
|
|
"""
|
|
|
|
:param protocols: protocols to add
|
|
|
|
"""
|
2018-10-21 04:55:37 +08:00
|
|
|
|
2018-11-03 04:16:46 +08:00
|
|
|
@abstractmethod
|
2019-07-27 16:27:01 +08:00
|
|
|
def set_protocols(self, protocols: Sequence[str]) -> None:
|
2018-11-03 04:16:46 +08:00
|
|
|
"""
|
2019-11-26 12:27:59 +08:00
|
|
|
:param protocols: protocols to set
|
2018-11-03 04:16:46 +08:00
|
|
|
"""
|
|
|
|
|
|
|
|
@abstractmethod
|
2019-07-27 16:27:01 +08:00
|
|
|
def add_addrs(self, addrs: Sequence[Multiaddr]) -> None:
|
2018-11-03 04:16:46 +08:00
|
|
|
"""
|
|
|
|
:param addrs: multiaddresses to add
|
|
|
|
"""
|
2018-10-21 04:55:37 +08:00
|
|
|
|
2018-11-03 04:16:46 +08:00
|
|
|
@abstractmethod
|
2019-07-27 16:27:01 +08:00
|
|
|
def get_addrs(self) -> List[Multiaddr]:
|
2018-11-03 04:16:46 +08:00
|
|
|
"""
|
|
|
|
:return: all multiaddresses
|
|
|
|
"""
|
2018-10-21 04:55:37 +08:00
|
|
|
|
2018-11-03 04:16:46 +08:00
|
|
|
@abstractmethod
|
2019-07-27 16:27:01 +08:00
|
|
|
def clear_addrs(self) -> None:
|
2019-10-24 14:41:10 +08:00
|
|
|
"""Clear all addresses."""
|
2018-10-21 04:55:37 +08:00
|
|
|
|
2018-11-03 04:16:46 +08:00
|
|
|
@abstractmethod
|
2019-07-30 15:31:02 +08:00
|
|
|
def put_metadata(self, key: str, val: Any) -> None:
|
2018-11-03 04:16:46 +08:00
|
|
|
"""
|
|
|
|
:param key: key in KV pair
|
|
|
|
:param val: val to associate with key
|
|
|
|
"""
|
2018-10-21 04:55:37 +08:00
|
|
|
|
2018-11-03 04:16:46 +08:00
|
|
|
@abstractmethod
|
2019-07-30 15:31:02 +08:00
|
|
|
def get_metadata(self, key: str) -> IPeerMetadata:
|
2018-11-03 04:16:46 +08:00
|
|
|
"""
|
|
|
|
:param key: key in KV pair
|
|
|
|
:return: val for key
|
2019-11-26 12:27:59 +08:00
|
|
|
:raise PeerDataError: key not found
|
|
|
|
"""
|
|
|
|
|
|
|
|
@abstractmethod
|
|
|
|
def add_pubkey(self, pubkey: PublicKey) -> None:
|
|
|
|
"""
|
|
|
|
:param pubkey:
|
|
|
|
"""
|
|
|
|
|
|
|
|
@abstractmethod
|
|
|
|
def get_pubkey(self) -> PublicKey:
|
|
|
|
"""
|
|
|
|
:return: public key of the peer
|
|
|
|
:raise PeerDataError: if public key not found
|
|
|
|
"""
|
|
|
|
|
|
|
|
@abstractmethod
|
|
|
|
def add_privkey(self, privkey: PrivateKey) -> None:
|
|
|
|
"""
|
|
|
|
:param privkey:
|
|
|
|
"""
|
|
|
|
|
|
|
|
@abstractmethod
|
|
|
|
def get_privkey(self) -> PrivateKey:
|
|
|
|
"""
|
|
|
|
:return: private key of the peer
|
|
|
|
:raise PeerDataError: if private key not found
|
2018-11-03 04:16:46 +08:00
|
|
|
"""
|