-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathclient2.py
88 lines (81 loc) · 3.62 KB
/
client2.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
88
import threading, queue, socket, struct
class Receiver(threading.Thread):
def __init__(self):
threading.Thread.__init__(self)
with open("conn_info.txt") as file:
self.IP, _, self.port, h = file.readlines()
file.close()
self.header = struct.Struct(h)
self.done = False
self.q = queue.Queue()
self.__unfinishedMessage = ""
self.raw_socket = socket.socket(socket.AF_INET,
socket.SOCK_STREAM)
self.raw_socket.setsockopt(socket.SOL_SOCKET,
socket.SO_REUSEADDR, 1)
self.raw_socket.bind(('', int(self.port)))
self.raw_socket.listen(5)
self.recv_sock, sockname = self.raw_socket.accept()
self.recv_sock.shutdown(socket.SHUT_WR)
self.recv_sock.settimeout(0.0)
def run(self):
while not self.done:
try:
message = self.recv_sock.recv(4096)
except TimeoutError:
print("TImeout Error Attempting to reconnect")
self.recv_sock.close()
self.raw_socket.close()
del self.recv_sock, self.raw_socket
self.__init__()
continue
except BlockingIOError:
continue
if message:
sizeOfMessage = self.header.unpack(message[0:self.header.size])[0]
receivedMessage = message[self.header.size:].decode('ascii')
self.__unfinishedMessage += receivedMessage
if sizeOfMessage == len(self.__unfinishedMessage):
self.q.put_nowait(self.__unfinishedMessage)
self.__unfinishedMessage = ""
message = ""
self.recv_sock.close()
self.raw_socket.close()
class Sender(threading.Thread):
def __init__(self):
threading.Thread.__init__(self)
with open("conn_info.txt") as file:
self.IP, self.port, _, self.formatCharacter = file.readlines()
file.close()
self.sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
self.sock.setsockopt(socket.SOL_SOCKET,
socket.SO_REUSEADDR, 1)
self.sock.connect((self.IP, int(self.port)))
self.sock.setblocking(False)
self.sock.settimeout(0.0)
print("Connected to ", self.IP, "with name: ", self.sock.getpeername())
self.currentRoom = "@@broadcast@@"
self.q = queue.Queue()
self.done = False
def run(self):
while not self.done:
if not self.q.empty():
userInput = self.q.get(block = False)
if userInput.lower() == '`exit': # Close Stuff; need to finish
self.done = True #signal other threads.
break
header = struct.Struct(self.formatCharacter)
##Need to add which room
if userInput[0:2] == "`/":
separated = userInput[2:].partition(" ")
self.currentRoom = separated[0]
userInput = separated[2]
toSend = userInput + ":`:" + self.currentRoom
# ^ Rooms now handled by server.
encoded_toSend = header.pack(len(toSend)) + toSend.encode("ascii")
try:
self.sock.sendall(encoded_toSend)
print("Sent ", encoded_toSend, "to", self.sock)
except socket.error as e:
print("Error was ", e)
self.sock.close()