Use types for {Private,Public}Key and address other missing type hints
This commit is contained in:
parent
e7d2681fc0
commit
2e3ffb9d53
|
@ -1,7 +1,7 @@
|
||||||
import asyncio
|
import asyncio
|
||||||
from typing import Mapping, Sequence
|
from typing import Mapping, Sequence
|
||||||
|
|
||||||
from libp2p.crypto.keys import KeyPair
|
from libp2p.crypto.keys import KeyPair, PrivateKey
|
||||||
from libp2p.crypto.rsa import create_new_key_pair
|
from libp2p.crypto.rsa import create_new_key_pair
|
||||||
from libp2p.host.basic_host import BasicHost
|
from libp2p.host.basic_host import BasicHost
|
||||||
from libp2p.kademlia.network import KademliaServer
|
from libp2p.kademlia.network import KademliaServer
|
||||||
|
@ -38,7 +38,7 @@ def generate_new_rsa_identity() -> KeyPair:
|
||||||
return create_new_key_pair()
|
return create_new_key_pair()
|
||||||
|
|
||||||
|
|
||||||
def generate_peer_id_from_rsa_identity(key_pair=None) -> ID:
|
def generate_peer_id_from_rsa_identity(key_pair: KeyPair = None) -> ID:
|
||||||
if not key_pair:
|
if not key_pair:
|
||||||
key_pair = generate_new_rsa_identity()
|
key_pair = generate_new_rsa_identity()
|
||||||
public_key = key_pair.public_key
|
public_key = key_pair.public_key
|
||||||
|
@ -69,7 +69,7 @@ def initialize_default_kademlia_router(
|
||||||
|
|
||||||
|
|
||||||
def initialize_default_swarm(
|
def initialize_default_swarm(
|
||||||
private_key: bytes,
|
private_key: PrivateKey,
|
||||||
id_opt: ID = None,
|
id_opt: ID = None,
|
||||||
transport_opt: Sequence[str] = None,
|
transport_opt: Sequence[str] = None,
|
||||||
muxer_opt: Sequence[str] = None,
|
muxer_opt: Sequence[str] = None,
|
||||||
|
@ -98,11 +98,9 @@ def initialize_default_swarm(
|
||||||
# TODO TransportUpgrader is not doing anything really
|
# TODO TransportUpgrader is not doing anything really
|
||||||
# TODO parse muxer and sec to pass into TransportUpgrader
|
# TODO parse muxer and sec to pass into TransportUpgrader
|
||||||
muxer = muxer_opt or ["mplex/6.7.0"]
|
muxer = muxer_opt or ["mplex/6.7.0"]
|
||||||
private_key_bytes = private_key.export_key("DER")
|
|
||||||
public_key_bytes = private_key.publickey().export_key("DER")
|
|
||||||
security_transports_by_protocol = sec_opt or {
|
security_transports_by_protocol = sec_opt or {
|
||||||
TProtocol("insecure/1.0.0"): InsecureTransport(
|
TProtocol("insecure/1.0.0"): InsecureTransport(
|
||||||
private_key_bytes, public_key_bytes
|
private_key, private_key.get_public_key()
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
upgrader = TransportUpgrader(security_transports_by_protocol, muxer)
|
upgrader = TransportUpgrader(security_transports_by_protocol, muxer)
|
||||||
|
@ -115,7 +113,7 @@ def initialize_default_swarm(
|
||||||
|
|
||||||
|
|
||||||
async def new_node(
|
async def new_node(
|
||||||
private_key=None,
|
private_key: PrivateKey = None,
|
||||||
swarm_opt: INetwork = None,
|
swarm_opt: INetwork = None,
|
||||||
id_opt: ID = None,
|
id_opt: ID = None,
|
||||||
transport_opt: Sequence[str] = None,
|
transport_opt: Sequence[str] = None,
|
||||||
|
|
|
@ -1,3 +1,6 @@
|
||||||
|
from typing import Optional
|
||||||
|
|
||||||
|
from libp2p.crypto.keys import PrivateKey, PublicKey
|
||||||
from libp2p.network.connection.raw_connection_interface import IRawConnection
|
from libp2p.network.connection.raw_connection_interface import IRawConnection
|
||||||
from libp2p.peer.id import ID
|
from libp2p.peer.id import ID
|
||||||
from libp2p.security.base_transport import BaseSecureTransport
|
from libp2p.security.base_transport import BaseSecureTransport
|
||||||
|
@ -17,25 +20,16 @@ class BaseSession(ISecureConn, IRawConnection):
|
||||||
self.local_private_key = transport.local_private_key
|
self.local_private_key = transport.local_private_key
|
||||||
self.conn = conn
|
self.conn = conn
|
||||||
self.remote_peer_id = peer_id
|
self.remote_peer_id = peer_id
|
||||||
self.remote_permanent_pubkey = b""
|
self.remote_permanent_pubkey = None
|
||||||
|
|
||||||
# TODO clean up how this is passed around?
|
self.initiator = self.conn.initiator
|
||||||
@property
|
self.writer = self.conn.writer
|
||||||
def initiator(self) -> bool:
|
self.reader = self.conn.reader
|
||||||
return self.conn.initiator
|
|
||||||
|
|
||||||
# TODO clean up how this is passed around?
|
# TODO clean up how this is passed around?
|
||||||
def next_stream_id(self) -> int:
|
def next_stream_id(self) -> int:
|
||||||
return self.conn.next_stream_id()
|
return self.conn.next_stream_id()
|
||||||
|
|
||||||
@property
|
|
||||||
def writer(self):
|
|
||||||
return self.conn.writer
|
|
||||||
|
|
||||||
@property
|
|
||||||
def reader(self):
|
|
||||||
return self.conn.reader
|
|
||||||
|
|
||||||
async def write(self, data: bytes) -> None:
|
async def write(self, data: bytes) -> None:
|
||||||
await self.conn.write(data)
|
await self.conn.write(data)
|
||||||
|
|
||||||
|
@ -48,11 +42,11 @@ class BaseSession(ISecureConn, IRawConnection):
|
||||||
def get_local_peer(self) -> ID:
|
def get_local_peer(self) -> ID:
|
||||||
return self.local_peer
|
return self.local_peer
|
||||||
|
|
||||||
def get_local_private_key(self) -> bytes:
|
def get_local_private_key(self) -> PrivateKey:
|
||||||
return self.local_private_key
|
return self.local_private_key
|
||||||
|
|
||||||
def get_remote_peer(self) -> ID:
|
def get_remote_peer(self) -> ID:
|
||||||
return self.remote_peer_id
|
return self.remote_peer_id
|
||||||
|
|
||||||
def get_remote_public_key(self) -> bytes:
|
def get_remote_public_key(self) -> Optional[PublicKey]:
|
||||||
return self.remote_permanent_pubkey
|
return self.remote_permanent_pubkey
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
from libp2p.crypto.keys import PrivateKey, PublicKey
|
||||||
from libp2p.peer.id import ID
|
from libp2p.peer.id import ID
|
||||||
from libp2p.security.secure_transport_interface import ISecureTransport
|
from libp2p.security.secure_transport_interface import ISecureTransport
|
||||||
|
|
||||||
|
@ -8,6 +9,8 @@ class BaseSecureTransport(ISecureTransport):
|
||||||
is only meant to be used in clases that derive from it.
|
is only meant to be used in clases that derive from it.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, local_private_key: bytes, local_public_key: bytes) -> None:
|
def __init__(
|
||||||
|
self, local_private_key: PrivateKey, local_public_key: PublicKey
|
||||||
|
) -> None:
|
||||||
self.local_private_key = local_private_key
|
self.local_private_key = local_private_key
|
||||||
self.local_peer = ID.from_pubkey(local_public_key)
|
self.local_peer = ID.from_pubkey(local_public_key)
|
||||||
|
|
|
@ -1,7 +1,8 @@
|
||||||
from abc import ABC, abstractmethod
|
from abc import ABC, abstractmethod
|
||||||
|
|
||||||
from libp2p.peer.id import ID
|
from libp2p.crypto.keys import PrivateKey, PublicKey
|
||||||
from libp2p.network.connection.raw_connection_interface import IRawConnection
|
from libp2p.network.connection.raw_connection_interface import IRawConnection
|
||||||
|
from libp2p.peer.id import ID
|
||||||
|
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
@ -18,7 +19,7 @@ class AbstractSecureConn(ABC):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
@abstractmethod
|
@abstractmethod
|
||||||
def get_local_private_key(self) -> bytes:
|
def get_local_private_key(self) -> PrivateKey:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
@abstractmethod
|
@abstractmethod
|
||||||
|
@ -26,7 +27,7 @@ class AbstractSecureConn(ABC):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
@abstractmethod
|
@abstractmethod
|
||||||
def get_remote_public_key(self) -> bytes:
|
def get_remote_public_key(self) -> PublicKey:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
from abc import ABC
|
from abc import ABC
|
||||||
from typing import Dict
|
from typing import Dict, Mapping
|
||||||
|
|
||||||
from libp2p.network.connection.raw_connection_interface import IRawConnection
|
from libp2p.network.connection.raw_connection_interface import IRawConnection
|
||||||
from libp2p.peer.id import ID
|
from libp2p.peer.id import ID
|
||||||
|
@ -23,7 +23,9 @@ class SecurityMultistream(ABC):
|
||||||
multiselect: Multiselect
|
multiselect: Multiselect
|
||||||
multiselect_client: MultiselectClient
|
multiselect_client: MultiselectClient
|
||||||
|
|
||||||
def __init__(self, secure_transports_by_protocol) -> None:
|
def __init__(
|
||||||
|
self, secure_transports_by_protocol: Mapping[TProtocol, ISecureTransport]
|
||||||
|
) -> None:
|
||||||
self.transports = {}
|
self.transports = {}
|
||||||
self.multiselect = Multiselect()
|
self.multiselect = Multiselect()
|
||||||
self.multiselect_client = MultiselectClient()
|
self.multiselect_client = MultiselectClient()
|
||||||
|
|
Loading…
Reference in New Issue
Block a user