-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathclient_send.py
More file actions
121 lines (103 loc) · 3.77 KB
/
client_send.py
File metadata and controls
121 lines (103 loc) · 3.77 KB
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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
from socket import socket, AF_INET, SOCK_STREAM, gaierror
import datetime
import sys
import logging
import log.client_log_config
from common.decorators import log
# from common.variables import DEFAULT_USER, DEFAULT_PORT, ACTION, TIME, USER, PRESENCE, ERROR, RESPONSE, ALLERT, \
# ACCOUNT_NAME, STATUS, TYPE
from common.variables import *
from common.utils import get_message, send_message
LOG = logging.getLogger('client')
@log
def create_presence(akk_name):
"""
Получает имя пользователя и генерирует presence сообщение
:param akk_name: str
:return: dict
"""
msg = {
ACTION: PRESENCE,
TIME: datetime.datetime.now().timestamp(),
TYPE: STATUS,
USER: {
ACCOUNT_NAME: akk_name,
STATUS: "Yep, I am here!"
}
}
LOG.info('Cоздано PRESENCE сообщение')
return msg
def create_message(text, akk_name, to='#'):
"""
Получает текст имя отправителя и получателя и генерирует message
:param text: str
:param akk_name: str
:param to: str
:return: dict
"""
msg = {
ACTION: MSG,
TIME: datetime.datetime.now().timestamp(),
TO: to,
FROM: akk_name,
MESSAGE: text
}
LOG.info('Cоздано MESSAGE сообщение')
return msg
@log
def parse_response(response):
"""
Проверяет ответ от сервера
:param response: dict
:return:
"""
if response.get(RESPONSE) == 200:
LOG.debug(f'Получен ответ от сервера - {response[RESPONSE]}: {response[ALLERT]}')
return f'{response[RESPONSE]}: {response[ALLERT]}'
elif response.get(RESPONSE) == 400:
LOG.debug(f'Получен ответ от сервера - {response[RESPONSE]}: {response[ERROR]}')
return f'{response[RESPONSE]}: {response[ERROR]}'
elif response.get(ACTION) == MSG:
LOG.debug(f'Получен ответ от сервера - {response[ALLERT]}')
return f'{response[ALLERT]}'
@log
def main():
try:
addr = sys.argv[1]
if '-p' in sys.argv:
index = sys.argv.index('-p')
port = int(sys.argv[index + 1])
else:
port = DEFAULT_PORT
if '-n' in sys.argv:
index = sys.argv.index('-n')
akk_name = sys.argv[index + 1]
else:
akk_name = DEFAULT_USER
except IndexError:
LOG.error('Не введен ip адрес сервера')
except OverflowError:
LOG.error('Введен неправильный порт, порт должен быть от 0-65535')
except ValueError:
LOG.error('Введен неправильный порт, порт должен быть числом от 0-65535')
try:
with socket(AF_INET, SOCK_STREAM) as client_socket:
client_socket.connect((addr, port))
LOG.info(f'Клиент подключился к серверу {addr} порт {port}')
send_message(client_socket, create_presence(akk_name))
response = get_message(client_socket)
response = parse_response(response)
print(response)
print('Для завершения работы введите !!!')
while True:
text = input('Введите сообщение:')
if text == '!!!':
client_socket.close()
break
send_message(client_socket, create_message(text, akk_name))
except gaierror:
LOG.error('Неправильно введен Ip адрес')
except ConnectionRefusedError as err:
LOG.error(err)
if __name__ == "__main__":
main()