Compare commits

...

5 Commits

Author SHA1 Message Date
Michael Pilosov
38cd99fa73 RADICAL SIMPLIFICATION. working client. 2023-03-19 23:32:09 -06:00
Michael Pilosov
945f485243 REFACTOR/CLEANUP start_client 2023-03-19 23:14:48 -06:00
Michael Pilosov
fe15bbbf1e linting 2023-03-19 23:09:49 -06:00
Michael Pilosov
b87f5a329c working client 2023-03-19 23:09:40 -06:00
Michael Pilosov
e717f60e06 adding client 2023-03-19 21:45:47 -06:00
4 changed files with 109 additions and 7 deletions

View File

@ -78,3 +78,9 @@ The full syntax is equivalent to:
```bash ```bash
announce_server start_registry --address 0.0.0.0 --port 4999 --heartbeat_interval 5 --heartbeat_timeout 3 announce_server start_registry --address 0.0.0.0 --port 4999 --heartbeat_interval 5 --heartbeat_timeout 3
``` ```
To test connections, run:
```bash
announce_server start_client --host-ip 0.0.0.0 --host-port 4999
```

View File

@ -1,6 +1,7 @@
import argparse import argparse
from announce_server import register_service from announce_server import register_service
from announce_server.client import start_client
from announce_server.server import start_server from announce_server.server import start_server
@ -31,6 +32,20 @@ def main():
help="Heartbeat timeout in seconds", help="Heartbeat timeout in seconds",
) )
# Start client subcommand
start_client_parser = subparsers.add_parser(
"start_client", help="Start the client server"
)
start_client_parser.add_argument(
"--host-ip",
type=str,
default="0.0.0.0",
help="Host IP address (default: 0.0.0.0)",
)
start_client_parser.add_argument(
"--host-port", type=int, default=4999, help="Host port number (default: 4999)"
)
args = parser.parse_args() args = parser.parse_args()
if args.command == "start_registry": if args.command == "start_registry":
@ -40,6 +55,8 @@ def main():
heartbeat_interval=args.heartbeat_interval, heartbeat_interval=args.heartbeat_interval,
heartbeat_timeout=args.heartbeat_timeout, heartbeat_timeout=args.heartbeat_timeout,
) )
elif args.command == "start_client":
start_client(host_ip=args.host_ip, host_port=args.host_port)
else: else:
parser.print_help() parser.print_help()

View File

@ -0,0 +1,57 @@
import argparse
import asyncio
import signal
import threading
from http.server import HTTPServer, SimpleHTTPRequestHandler
import socketio
from .decorator import register_service
from .get_ip import get_ip_address
def start_client(host_ip="0.0.0.0", host_port=4999):
@register_service(
name="test client",
ip=get_ip_address(),
port=13373,
host_ip=host_ip,
host_port=host_port,
)
def server(port=13373):
httpd = HTTPServer(("", port), SimpleHTTPRequestHandler)
print(f"Serving HTTP on 0.0.0.0 port {port} (http://0.0.0.0:{port}/) ...")
def serve_forever_nonblocking():
httpd.serve_forever()
server_thread = threading.Thread(target=serve_forever_nonblocking)
server_thread.start()
return server_thread
try:
server_thread = server()
while True:
pass
except (KeyboardInterrupt, asyncio.exceptions.CancelledError):
print("Cleaning up and shutting down...")
# server_thread.join()
finally:
print("Shutting down test client...")
if __name__ == "__main__":
parser = argparse.ArgumentParser(description="Start announce_server client.")
parser.add_argument(
"--host-ip",
type=str,
default="0.0.0.0",
help="Host IP address (default: 0.0.0.0)",
)
parser.add_argument(
"--host-port", type=int, default=4999, help="Host port number (default: 4999)"
)
args = parser.parse_args()
start_client(args.host_ip, args.host_port)

View File

@ -1,3 +1,4 @@
import argparse
import asyncio import asyncio
import signal import signal
@ -164,9 +165,30 @@ def start_server(address, port, heartbeat_interval, heartbeat_timeout):
if __name__ == "__main__": if __name__ == "__main__":
start_server( parser = argparse.ArgumentParser(description="Start announce_server client.")
address="0.0.0.0",
port=4999, parser.add_argument("--ip", default="0.0.0.0", help="IP address of the host server")
heartbeat_interval=5, parser.add_argument(
heartbeat_timeout=3, "--port", default=4999, type=int, help="Port of the host server"
)
parser.add_argument(
"--heartbeat-interval",
default=5,
type=float,
help="Heartbeat interval in seconds",
)
parser.add_argument(
"--heartbeat-timeout",
default=3,
type=float,
help="Heartbeat timeout in seconds",
)
args = parser.parse_args()
start_server(
address=args.ip,
port=args.port,
heartbeat_interval=args.heartbeat_interval,
heartbeat_timeout=args.heartbeat_timeout,
) )