mirror of
https://github.com/varun-r-mallya/py-libp2p.git
synced 2025-12-31 20:36:24 +00:00
Merge branch 'main' into py-multiaddr
This commit is contained in:
@ -1,3 +1,4 @@
|
|||||||
|
import functools
|
||||||
import hashlib
|
import hashlib
|
||||||
|
|
||||||
import base58
|
import base58
|
||||||
@ -36,25 +37,23 @@ if ENABLE_INLINING:
|
|||||||
|
|
||||||
class ID:
|
class ID:
|
||||||
_bytes: bytes
|
_bytes: bytes
|
||||||
_xor_id: int | None = None
|
|
||||||
_b58_str: str | None = None
|
|
||||||
|
|
||||||
def __init__(self, peer_id_bytes: bytes) -> None:
|
def __init__(self, peer_id_bytes: bytes) -> None:
|
||||||
self._bytes = peer_id_bytes
|
self._bytes = peer_id_bytes
|
||||||
|
|
||||||
@property
|
@functools.cached_property
|
||||||
def xor_id(self) -> int:
|
def xor_id(self) -> int:
|
||||||
if not self._xor_id:
|
return int(sha256_digest(self._bytes).hex(), 16)
|
||||||
self._xor_id = int(sha256_digest(self._bytes).hex(), 16)
|
|
||||||
return self._xor_id
|
@functools.cached_property
|
||||||
|
def base58(self) -> str:
|
||||||
|
return base58.b58encode(self._bytes).decode()
|
||||||
|
|
||||||
def to_bytes(self) -> bytes:
|
def to_bytes(self) -> bytes:
|
||||||
return self._bytes
|
return self._bytes
|
||||||
|
|
||||||
def to_base58(self) -> str:
|
def to_base58(self) -> str:
|
||||||
if not self._b58_str:
|
return self.base58
|
||||||
self._b58_str = base58.b58encode(self._bytes).decode()
|
|
||||||
return self._b58_str
|
|
||||||
|
|
||||||
def __repr__(self) -> str:
|
def __repr__(self) -> str:
|
||||||
return f"<libp2p.peer.id.ID ({self!s})>"
|
return f"<libp2p.peer.id.ID ({self!s})>"
|
||||||
|
|||||||
1
newsfragments/772.internal.rst
Normal file
1
newsfragments/772.internal.rst
Normal file
@ -0,0 +1 @@
|
|||||||
|
Replace the libp2p.peer.ID cache attributes with functools.cached_property functional decorator.
|
||||||
Reference in New Issue
Block a user