initial code commit
This commit is contained in:
72
scraper/main.py
Normal file
72
scraper/main.py
Normal file
@@ -0,0 +1,72 @@
|
||||
import asyncio
|
||||
import os
|
||||
import websockets
|
||||
import json
|
||||
from datetime import datetime
|
||||
|
||||
async def relay_websockets(input_websocket, output_websocket, kinds):
|
||||
while True:
|
||||
try:
|
||||
# Wait for an event on input websocket
|
||||
event = json.loads(await input_websocket.recv())
|
||||
try:
|
||||
if(event[0] == "EVENT"):
|
||||
# TODO: Broadcast to output websocket
|
||||
print("Got event: ", event)
|
||||
# Output websocket broadcast will be implemented here
|
||||
|
||||
elif(event[0] == "EOSE"):
|
||||
print("End of stream")
|
||||
|
||||
except Exception as error:
|
||||
print(f"Failed to relay event: {error}")
|
||||
if("sent 1011" in str(error)):
|
||||
print("Got Code 1011 -> Closing websockets...")
|
||||
input_websocket.close()
|
||||
output_websocket.close()
|
||||
continue
|
||||
|
||||
except websockets.ConnectionClosed:
|
||||
# If either websocket is closed, attempt to reconnect
|
||||
print("Connection closed, attempting to reconnect...")
|
||||
await asyncio.sleep(1)
|
||||
try:
|
||||
async with websockets.connect(os.environ.get("INPUT_RELAY")) as new_input_websocket, \
|
||||
websockets.connect(os.environ.get("OUTPUT_RELAY")) as new_output_websocket:
|
||||
message = '["REQ", "1337", {"kinds": '+kinds+', "limit": 10}]'
|
||||
await new_input_websocket.send(message)
|
||||
await relay_websockets(new_input_websocket, new_output_websocket, kinds)
|
||||
|
||||
except Exception as error:
|
||||
# If the reconnection attempt fails, repeat the loop and try again
|
||||
print(f"Failed to reconnect: {error}")
|
||||
continue
|
||||
|
||||
async def main():
|
||||
print("Scraper started...")
|
||||
# Read the websocket URLs from environment variables
|
||||
input_url = os.environ.get("INPUT_RELAY")
|
||||
output_url = os.environ.get("OUTPUT_RELAY")
|
||||
kinds = os.environ.get("KINDS")
|
||||
|
||||
# If either relay URL is missing, raise an error
|
||||
if not input_url:
|
||||
raise ValueError("Please set the INPUT_RELAY environment variable")
|
||||
if not output_url:
|
||||
raise ValueError("Please set the OUTPUT_RELAY environment variable")
|
||||
|
||||
try:
|
||||
async with websockets.connect(input_url) as input_websocket, \
|
||||
websockets.connect(output_url) as output_websocket:
|
||||
message = '["REQ", "1337", {"kinds": '+kinds+'}]'
|
||||
await input_websocket.send(message)
|
||||
await relay_websockets(input_websocket, output_websocket, kinds)
|
||||
|
||||
except Exception as error:
|
||||
# If the initial connection attempt fails, attempt to reconnect immediately
|
||||
print(f"Failed to connect: {error}")
|
||||
await asyncio.sleep(1)
|
||||
await main()
|
||||
|
||||
# Start the script
|
||||
asyncio.run(main())
|
||||
Reference in New Issue
Block a user