-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.py
87 lines (71 loc) · 3 KB
/
server.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
import socketserver
import logging
from ProtocolImplementation.ServerProtocolImplementation.ServerProtocol import FileHandler, ProtocolHandler
import socket
import os
import argparse
HOST, PORT = "127.0.0.1", 9999
class ThreadedTCPRequestHandler(socketserver.BaseRequestHandler):
def handle(self):
logging.info(f"New connection {self.client_address}")
s: socket.socket = self.request
protocol_handler = ProtocolHandler(s)
name = protocol_handler.get_input("Name: ")
if not name: return
surname = protocol_handler.get_input("Surname: ")
if not surname: return
logging.info(f"Name: {name} Surname: {surname}")
file_handler = FileHandler(name, surname, s)
while True:
cmd = protocol_handler.get_input(">> ") # command
if not cmd: break
logging.debug(f"Received: {cmd}")
if cmd == 'u' or cmd == 'U':
filename = protocol_handler.get_input("Filename: ")
if not filename: break
logging.info(f"Upload request from {self.client_address}. File: {filename}")
file_handler.upload(filename)
elif cmd == 'd' or cmd == 'D':
filename = protocol_handler.get_input("Filename: ")
if not filename: break
logging.info(f"Download request from {self.client_address}. File: {filename}")
file_handler.download(filename)
elif cmd == 'l' or cmd == 'L':
s = "\n"
ls = os.listdir(os.path.join(os.getcwd(), f"{name}_{surname}"))
for ele in ls:
s += f"{ele}\n"
protocol_handler.send_output(s)
elif cmd == 'h' or cmd == 'H':
protocol_handler.send_output("""u/U: upload
d/D: Download
l/L: List
h/H: Help
q: Exit""")
elif cmd == 'q':
protocol_handler.close_connection()
break
else:
protocol_handler.send_output("Command not found")
# s.close_connection()
class ThreadedTCPServer(socketserver.ThreadingMixIn, socketserver.TCPServer):
pass
def main():
global HOST, PORT
logging.basicConfig(level=logging.DEBUG, format="%(threadName)s --> %(asctime)s - %(levelname)s: %(message)s",
datefmt="%H:%M:%S")
parser = argparse.ArgumentParser()
parser.add_argument("-a", "--address", help="host address", default=HOST, type=str, dest="address")
parser.add_argument("-p", "--port", help="port number", default=PORT, type=int, dest="port")
args = parser.parse_args()
PORT = args.port
HOST = args.address
logging.info(f"Server running on {HOST}:{PORT}...")
server = ThreadedTCPServer((HOST, PORT), ThreadedTCPRequestHandler)
try:
server.serve_forever()
except KeyboardInterrupt:
print("\nStopping server. Waiting for the termination of all open connections...")
server.server_close()
if __name__ == "__main__":
main()