-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmain.py
More file actions
93 lines (67 loc) · 3.41 KB
/
main.py
File metadata and controls
93 lines (67 loc) · 3.41 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
import logging
import telebot
import utils.dpaste as dpaste
import utils.pastebin as pastebin
import utils.tokens as tokens
# Amount of created pastes (global var)
pastes_count: int = 0
# Create bot instance
bot = telebot.TeleBot(tokens.TELEGRAM_BOT_TOKEN)
# Logging settings
logging.basicConfig(format='%(asctime)s,%(msecs)d %(name)s %(levelname)s %(message)s',
datefmt='%H:%M:%S',
level=logging.DEBUG)
logging.getLogger("urllib3").setLevel(logging.WARNING)
log = logging.getLogger('logger')
def parse_message(message: telebot.types.Message) -> tuple:
# Read message from user and parse service (pastebin or dpaste),
# name, code and language from it
name = message.reply_to_message.from_user.first_name
if not name:
name = "Anonymous"
service = message.text.split()[0].replace('/', '')
lang = ' '.join(message.text.split()[1:])
code = message.reply_to_message.text
return service, name, code, lang
@bot.message_handler(func=lambda message : '/pastebin' in message.text or '/dpaste' in message.text)
def handle_paste_command(message: telebot.types.Message) -> telebot.types.Message:
# Handling '/pastebin' and '/dpaste' commands
# User must reply to message with code
if not message.reply_to_message:
return bot.reply_to(message, 'Вы должны ответить на сообщение с кодом')
service, name, code, lang = parse_message(message)
log.info(f'Got {service} request from {message.from_user.first_name} \
for {lang if lang else "unspecified"} language')
if service == 'pastebin':
if tokens.PASTEBIN_API_TOKEN:
paste = pastebin.create_paste(name, code, lang)
else:
paste = 'Невозможно загрузить на Pastebin. Попробуйте /dpaste'
elif service == 'dpaste':
paste = dpaste.create_paste(name, code, lang)
else:
log.error(f"Got an unexpected service: {service}")
paste = 'Произошла ошибка'
return bot.reply_to(message, paste, disable_web_page_preview=True)
@bot.message_handler(commands=['start'])
def handle_start_command(message: telebot.types.Message) -> telebot.types.Message:
# Handling '/start' command
log.info(f'{message.from_user.first_name} started bot')
reply = 'Добро пожаловать!\nВведите /help для получения справки по использованию бота.'
return bot.send_message(message.from_user.id, reply)
@bot.message_handler(commands=['help'])
def handle_help_command(message: telebot.types.Message) -> telebot.types.Message:
# Handling '/help' command
log.info(f'{message.from_user.first_name} reads help message')
reply = '''
Для того, чтобы бот загрузил ваш код для начала пришлите ему сообщение\
с кодом, затем ответьте на него командой /pastebin *язык* или /dpaste *язык*.\n
Например:\n/pastebin c++ или /dpaste питон\n
Бот обработает сообщение и пришлет ссылку на страницу с вашим кодом. \
Каждая ссылка активна ровно 24 часа :)
'''
return bot.send_message(message.from_user.id, reply)
if __name__ == '__main__':
log.info('Bot started')
bot.polling()
log.info('Bot shutdown')