-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmessage_manager.py
95 lines (66 loc) · 2.61 KB
/
message_manager.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
89
90
91
92
93
94
95
import sys
import random
from manager import Manager
# TODO: make singleton
class MessageManager(Manager):
CLIENT_DST_SIZE = 16
CLIENT_SRC_SIZE = 16
MSG_ID_SIZE = 4
def __init__(self):
self.__table_name = "messages"
super().__init__(self.__class__.__name__)
sql_create = "CREATE TABLE {}(ID int PRIMARY KEY NOT NULL, ToClient varchar({}),\
FromClient varchar({}), Type int, Content BLOB);".format(self.__table_name,
self.CLIENT_DST_SIZE, self.CLIENT_SRC_SIZE)
try:
self.init_table(self.__table_name, sql_create)
except:
self.__log_exception("Failed to initiate message manager")
sys.exit()
# Wrappers for logging functionality
def __log_debug(self, msg):
self.logger.debug(msg)
def __log_info(self, msg):
self.logger.info(msg)
def __log_critical(self, msg):
self.logger.critical(msg)
def __log_exception(self, msg):
self.logger.exception(msg)
def add_message(self, client_dst, client_src, msg_type, content= ""):
#sqlite will auto-generate ID
query = "INSERT INTO {} VALUES(?, ?, ?, ?, ?);".format(self.__table_name)
# low probability for msg with same id
msg_id = random.randint(1, 0xffffffff)
params = [msg_id, client_dst, client_src, msg_type, content]
try:
self.do_sql(query, params)
except:
self.__log_debug("Falied to add new message")
return None
return msg_id
def delete_message(self, msg_id):
query = "DELETE FROM {} WHERE ID = ?;".format(self.__table_name)
params = [msg_id]
rows = []
try:
rows = self.do_sql(query, params)
except:
self.__log_debug("Failed to fetch messages for client")
def fetch_messages(self, client_id):
self.__log_debug("Client {} requested all messages".format(client_id))
query = "SELECT FromClient, ID, Type, Content FROM {} WHERE ToClient = ?;".format(self.__table_name)
params = [client_id]
rows = []
try:
rows = self.do_sql(query, params)
except:
self.__log_debug("Failed to fetch messages for client")
return rows
def fetch_all_messages(self):
query = "SELECT * FROM {};".format(self.__table_name)
params = []
try:
rows = self.do_sql(query, params)
except:
self.__log_debug("Failed to fetch messages for client")
return rows