mirror of
https://github.com/aljazceru/python-nostr.git
synced 2025-12-18 23:04:20 +01:00
Initial AUTH support
This commit is contained in:
@@ -24,11 +24,18 @@ class EndOfStoredEventsMessage:
|
||||
self.url = url
|
||||
|
||||
|
||||
class AuthMessage:
|
||||
def __init__(self, challenge: str, url: str) -> None:
|
||||
self.challenge = challenge
|
||||
self.url = url
|
||||
|
||||
|
||||
class MessagePool:
|
||||
def __init__(self) -> None:
|
||||
self.events: Queue[EventMessage] = Queue()
|
||||
self.notices: Queue[NoticeMessage] = Queue()
|
||||
self.eose_notices: Queue[EndOfStoredEventsMessage] = Queue()
|
||||
self.auths: Queue[AuthMessage] = Queue()
|
||||
self._unique_events: set = set()
|
||||
self.lock: Lock = Lock()
|
||||
|
||||
@@ -44,6 +51,9 @@ class MessagePool:
|
||||
def get_eose_notice(self):
|
||||
return self.eose_notices.get()
|
||||
|
||||
def get_auth(self):
|
||||
return self.auth.get()
|
||||
|
||||
def has_events(self):
|
||||
return self.events.qsize() > 0
|
||||
|
||||
@@ -53,6 +63,9 @@ class MessagePool:
|
||||
def has_eose_notices(self):
|
||||
return self.eose_notices.qsize() > 0
|
||||
|
||||
def has_auths(self):
|
||||
return self.auths.qsize() > 0
|
||||
|
||||
def _process_message(self, message: str, url: str):
|
||||
message_json = json.loads(message)
|
||||
message_type = message_json[0]
|
||||
@@ -75,3 +88,5 @@ class MessagePool:
|
||||
self.notices.put(NoticeMessage(message_json[1], url))
|
||||
elif message_type == RelayMessageType.END_OF_STORED_EVENTS:
|
||||
self.eose_notices.put(EndOfStoredEventsMessage(message_json[1], url))
|
||||
elif message_type == RelayMessageType.AUTH:
|
||||
self.auths.put(AuthMessage(message_json[1], url))
|
||||
|
||||
@@ -2,14 +2,16 @@ class ClientMessageType:
|
||||
EVENT = "EVENT"
|
||||
REQUEST = "REQ"
|
||||
CLOSE = "CLOSE"
|
||||
AUTH = "AUTH"
|
||||
|
||||
class RelayMessageType:
|
||||
EVENT = "EVENT"
|
||||
NOTICE = "NOTICE"
|
||||
END_OF_STORED_EVENTS = "EOSE"
|
||||
AUTH = "AUTH"
|
||||
|
||||
@staticmethod
|
||||
def is_valid(type: str) -> bool:
|
||||
if type == RelayMessageType.EVENT or type == RelayMessageType.NOTICE or type == RelayMessageType.END_OF_STORED_EVENTS:
|
||||
return True
|
||||
return False
|
||||
return False
|
||||
|
||||
@@ -100,7 +100,7 @@ class Relay:
|
||||
|
||||
def close_subscription(self, id: str) -> None:
|
||||
with self.lock:
|
||||
self.subscriptions.pop(id)
|
||||
self.subscriptions.pop(id, None)
|
||||
|
||||
def update_subscription(self, id: str, filters: Filters) -> None:
|
||||
with self.lock:
|
||||
|
||||
@@ -52,12 +52,13 @@ class RelayManager:
|
||||
for relay in self.relays.values():
|
||||
relay.close()
|
||||
|
||||
def publish_message(self, message: str):
|
||||
def publish_message(self, message: str, url:str=None):
|
||||
for relay in self.relays.values():
|
||||
if relay.policy.should_write:
|
||||
relay.publish(message)
|
||||
if url is None or relay.url == url:
|
||||
relay.publish(message)
|
||||
|
||||
def publish_event(self, event: Event):
|
||||
def verify_event(self, event: Event):
|
||||
"""Verifies that the Event is publishable before submitting it to relays"""
|
||||
if event.signature is None:
|
||||
raise RelayException(f"Could not publish {event.id}: must be signed")
|
||||
@@ -66,4 +67,12 @@ class RelayManager:
|
||||
raise RelayException(
|
||||
f"Could not publish {event.id}: failed to verify signature {event.signature}"
|
||||
)
|
||||
|
||||
def publish_event(self, event: Event):
|
||||
self.verify_event(event)
|
||||
self.publish_message(event.to_message())
|
||||
|
||||
def publish_auth(self, event: Event, url: str):
|
||||
self.verify_event(event)
|
||||
self.publish_message(event.to_message(), url)
|
||||
|
||||
|
||||
Reference in New Issue
Block a user