Исправление багов, добавление подсказок к каждой команде.
This commit is contained in:
parent
958b5c50c0
commit
09c0a397a2
240
anon.py
240
anon.py
@ -50,111 +50,116 @@ def start(message):
|
|||||||
def reg(message):
|
def reg(message):
|
||||||
try:
|
try:
|
||||||
db = load()
|
db = load()
|
||||||
if len(message.text.split()) == 2:
|
if not ok_args(bot, message, 2, '```\n/reg никнейм```'):
|
||||||
nick = message.text.split()[1]
|
return 0
|
||||||
# Проверка ника
|
nick = message.text.split()[1]
|
||||||
if not nick_ok(bot, message, nick):
|
# Проверка ника
|
||||||
return 0
|
if not nick_ok(bot, message, nick):
|
||||||
if nick in db:
|
return 0
|
||||||
bot.reply_to(message, "Данный пользователь уже зарегистрирован.")
|
if nick in db:
|
||||||
elif str(message.chat.id) in db:
|
bot.reply_to(message, "Данный пользователь уже зарегистрирован.")
|
||||||
bot.reply_to(message, "Вы уже зарегистрированы.")
|
elif str(message.chat.id) in db:
|
||||||
else:
|
bot.reply_to(message, "Вы уже зарегистрированы.")
|
||||||
user = user_(message.chat.id, hash(randint(74287, 5747962)))
|
|
||||||
db[nick] = user
|
|
||||||
db[message.chat.id] = nick
|
|
||||||
|
|
||||||
save(db)
|
|
||||||
bot.reply_to(message, "Вы зарегистрировались!\nПриятного использования.")
|
|
||||||
else:
|
else:
|
||||||
bot.reply_to(message, "Вы ввели не 2 аргумента, нужно: /reg ЛюбойНикнейм")
|
user = user_(message.chat.id, hash(randint(74287, 5747962)))
|
||||||
|
db[nick] = user
|
||||||
|
db[message.chat.id] = nick
|
||||||
|
|
||||||
|
save(db)
|
||||||
|
bot.reply_to(message, "Вы зарегистрировались!\nПриятного использования.")
|
||||||
except:
|
except:
|
||||||
catch_error(bot, message)
|
catch_error(bot, message)
|
||||||
|
|
||||||
@bot.message_handler(commands=['b'])
|
@bot.message_handler(commands=['b'])
|
||||||
def b(message):
|
def b(message):
|
||||||
try:
|
try:
|
||||||
if is_auth(bot, message):
|
if not is_auth(bot, message) or not ok_args(bot, message, 2, '```\n/b :ник``` или ```\n/b ник```'):
|
||||||
db = load()
|
return 0
|
||||||
nick = db[str(message.chat.id)]
|
db = load()
|
||||||
user = db[nick]
|
nick = db[str(message.chat.id)]
|
||||||
block = message.text.split()[1]
|
user = db[nick]
|
||||||
|
block = message.text.split()[1]
|
||||||
|
|
||||||
# Block by ":user"
|
# Block by ":user"
|
||||||
if block[0] == ":":
|
if block[0] == ":":
|
||||||
block = block[1:]
|
block = block[1:]
|
||||||
|
|
||||||
if block in db:
|
if block in db:
|
||||||
if db[block].id not in user.blocks:
|
if db[block].id not in user.blocks:
|
||||||
user.blocks.append(db[block].id)
|
user.blocks.append(db[block].id)
|
||||||
save(db)
|
save(db)
|
||||||
bot.reply_to(message, f"Пользователь {telebot.formatting.hcode(block)} был заблокирован.",parse_mode="HTML")
|
bot.reply_to(message, f"Пользователь {telebot.formatting.hcode(block)} был заблокирован.",parse_mode="HTML")
|
||||||
else:
|
else:
|
||||||
bot.reply_to(message, "Данного пользователя не существует.")
|
bot.reply_to(message, "Данного пользователя не существует.")
|
||||||
except:
|
except:
|
||||||
catch_error(bot, message)
|
catch_error(bot, message)
|
||||||
|
|
||||||
@bot.message_handler(commands=['u'])
|
@bot.message_handler(commands=['u'])
|
||||||
def u(message):
|
def u(message):
|
||||||
try:
|
try:
|
||||||
if is_auth(bot, message):
|
if not is_auth(bot, message) or not ok_args(bot, message, 2, '```\n/u :ник``` или ```\n/u ник```'):
|
||||||
db = load()
|
return 0
|
||||||
nick = db[str(message.chat.id)]
|
db = load()
|
||||||
user = db[nick]
|
nick = db[str(message.chat.id)]
|
||||||
block = message.text.split()[1]
|
user = db[nick]
|
||||||
|
block = message.text.split()[1]
|
||||||
|
|
||||||
# Unblock by ":user"
|
# Unblock by ":user"
|
||||||
if block[0] == ":":
|
if block[0] == ":":
|
||||||
block = block[1:]
|
block = block[1:]
|
||||||
|
|
||||||
if db[block].id in user.blocks:
|
if block in db and db[block].id in user.blocks:
|
||||||
user.blocks.remove(db[block].id)
|
user.blocks.remove(db[block].id)
|
||||||
save(db)
|
save(db)
|
||||||
bot.reply_to(message, f"Была снята блокировка с пользователя {telebot.formatting.hcode(block)}",parse_mode="HTML")
|
bot.reply_to(message, f"Была снята блокировка с пользователя {telebot.formatting.hcode(block)}",parse_mode="HTML")
|
||||||
|
else:
|
||||||
|
bot.reply_to(message, "Данного пользователя не существует.")
|
||||||
except:
|
except:
|
||||||
catch_error(bot, message)
|
catch_error(bot, message)
|
||||||
|
|
||||||
@bot.message_handler(commands=['nick'])
|
@bot.message_handler(commands=['nick'])
|
||||||
def nick(message):
|
def nick(message):
|
||||||
try:
|
try:
|
||||||
if is_auth(bot, message):
|
if not is_auth(bot, message) or not ok_args(bot, message, 2, '```\n/nick ник```'):
|
||||||
db = load()
|
return 0
|
||||||
new_nick = message.text.split()[1]
|
db = load()
|
||||||
# Проверка ника
|
new_nick = message.text.split()[1]
|
||||||
if not nick_ok(message, new_nick):
|
# Проверка ника
|
||||||
return 0
|
if not nick_ok(bot, message, new_nick):
|
||||||
old_nick = db[str(message.chat.id)]
|
return 0
|
||||||
|
old_nick = db[str(message.chat.id)]
|
||||||
|
|
||||||
if new_nick not in db:
|
if new_nick not in db:
|
||||||
db[new_nick] = db[old_nick]
|
db[new_nick] = db[old_nick]
|
||||||
db[new_nick].avatar = "♿️"
|
db[new_nick].avatar = "♿️"
|
||||||
db[str(message.chat.id)] = new_nick
|
db[str(message.chat.id)] = new_nick
|
||||||
del db[old_nick]
|
del db[old_nick]
|
||||||
save(db)
|
save(db)
|
||||||
bot.reply_to(message,f"Вы успешно сменили ник с {telebot.formatting.hcode(old_nick)} на {telebot.formatting.hcode(new_nick)}",parse_mode="HTML")
|
bot.reply_to(message,f"Вы успешно сменили ник с {telebot.formatting.hcode(old_nick)} на {telebot.formatting.hcode(new_nick)}",parse_mode="HTML")
|
||||||
bot.reply_to(message, """Ваша аватарка сброшена до стандартной: ♿️
|
bot.reply_to(message, """Ваша аватарка сброшена до стандартной: ♿️
|
||||||
Также вы можете сбросить публичный ключ: /key_res""")
|
Также вы можете сбросить публичный ключ: /key_res""")
|
||||||
else:
|
else:
|
||||||
bot.reply_to(message,"Данный ник уже занят")
|
bot.reply_to(message,"Данный ник уже занят")
|
||||||
except:
|
except:
|
||||||
catch_error(bot, message)
|
catch_error(bot, message)
|
||||||
|
|
||||||
@bot.message_handler(commands=['av'])
|
@bot.message_handler(commands=['av'])
|
||||||
def av(message):
|
def av(message):
|
||||||
try:
|
try:
|
||||||
if is_auth(bot, message):
|
if not is_auth(bot, message) or not ok_args(bot, message, 2, '```\n/av ❄️```'):
|
||||||
db = load()
|
return 0
|
||||||
if not len(message.text.split()) > 1:
|
db = load()
|
||||||
bot.reply_to(message,"Укажите аватарку")
|
if not len(message.text.split()) > 1:
|
||||||
return 0
|
bot.reply_to(message,"Укажите аватарку")
|
||||||
new_avatar = message.text.split()[1]
|
return 0
|
||||||
if len(new_avatar) > 10:
|
new_avatar = message.text.split()[1]
|
||||||
bot.reply_to(message,"Слишком большое количество символов для аватарки")
|
if len(new_avatar) > 10:
|
||||||
else:
|
bot.reply_to(message,"Слишком большое количество символов для аватарки")
|
||||||
nick = db[str(message.chat.id)]
|
else:
|
||||||
db[nick].avatar = new_avatar
|
nick = db[str(message.chat.id)]
|
||||||
save(db)
|
db[nick].avatar = new_avatar
|
||||||
bot.reply_to(message,"Новая аватарка успешно установлена")
|
save(db)
|
||||||
|
bot.reply_to(message,"Новая аватарка успешно установлена")
|
||||||
except:
|
except:
|
||||||
catch_error(bot, message)
|
catch_error(bot, message)
|
||||||
|
|
||||||
@ -163,54 +168,53 @@ def av(message):
|
|||||||
@bot.message_handler(commands=['key'])
|
@bot.message_handler(commands=['key'])
|
||||||
def key(message):
|
def key(message):
|
||||||
try:
|
try:
|
||||||
if len(message.text.split()) == 2:
|
if not is_auth(bot, message) or not ok_args(bot, message, 2, '```\n/key ник``` или ```\n/key :ник```'):
|
||||||
db = load()
|
return 0
|
||||||
nick = message.text.split()[1]
|
db = load()
|
||||||
if nick[0] == ':':
|
nick = message.text.split()[1]
|
||||||
nick = nick[1:]
|
if nick[0] == ':':
|
||||||
key = db[nick].pkey
|
nick = nick[1:]
|
||||||
bot.reply_to(message,f"Ключ пользователя: {telebot.formatting.hcode(key)}", parse_mode="HTML")
|
key = db[nick].pkey
|
||||||
else:
|
bot.reply_to(message,f"Ключ пользователя: {telebot.formatting.hcode(key)}", parse_mode="HTML")
|
||||||
bot.reply_to(message,"/key ник")
|
|
||||||
except:
|
except:
|
||||||
catch_error(bot, message)
|
catch_error(bot, message)
|
||||||
|
|
||||||
@bot.message_handler(commands=['ver'])
|
@bot.message_handler(commands=['ver'])
|
||||||
def ver(message):
|
def ver(message):
|
||||||
try:
|
try:
|
||||||
if len(message.text.split()) == 3:
|
if not is_auth(bot, message) or not ok_args(bot, message, 3, '```\n/ver ник ключ``` или ```\n/ver :ник ключ```'):
|
||||||
db = load()
|
return 0
|
||||||
nick = message.text.split()[1]
|
db = load()
|
||||||
if nick[0] == ':':
|
nick = message.text.split()[1]
|
||||||
nick = nick[1:]
|
if nick[0] == ':':
|
||||||
key = message.text.split()[2]
|
nick = nick[1:]
|
||||||
if not nick in db:
|
key = message.text.split()[2]
|
||||||
bot.reply_to(message,"Не существует такого пользователя")
|
if not nick in db:
|
||||||
return 0
|
bot.reply_to(message,"Не существует такого пользователя")
|
||||||
|
return 0
|
||||||
|
|
||||||
if key == db[nick].pkey:
|
if key == db[nick].pkey:
|
||||||
bot.reply_to(message,"✅ Ключи совпадают")
|
bot.reply_to(message,"✅ Ключи совпадают")
|
||||||
else:
|
|
||||||
bot.reply_to(message,"❌ Ключи не совпадают")
|
|
||||||
else:
|
else:
|
||||||
bot.reply_to(message,"/ver ник ключ")
|
bot.reply_to(message,"❌ Ключи не совпадают")
|
||||||
except:
|
except:
|
||||||
catch_error(bot, message)
|
catch_error(bot, message)
|
||||||
|
|
||||||
@bot.message_handler(commands=['key_res'])
|
@bot.message_handler(commands=['key_res'])
|
||||||
def key_res(message):
|
def key_res(message):
|
||||||
try:
|
try:
|
||||||
if is_auth(bot, message):
|
if not is_auth(bot, message) or not ok_args(bot, message, 1, '```\n/key_res```'):
|
||||||
db = load()
|
return 0
|
||||||
|
db = load()
|
||||||
|
|
||||||
key = hash(randint(74287, 5747962))
|
key = hash(randint(74287, 5747962))
|
||||||
nick = db[str(message.chat.id)]
|
nick = db[str(message.chat.id)]
|
||||||
old_key = db[nick].pkey
|
old_key = db[nick].pkey
|
||||||
|
|
||||||
db[nick].pkey = key
|
db[nick].pkey = key
|
||||||
save(db)
|
save(db)
|
||||||
|
|
||||||
bot.reply_to(message,f"""🔑 Ключ успешно сброшен.
|
bot.reply_to(message,f"""🔑 Ключ успешно сброшен.
|
||||||
|
|
||||||
Старый ключ: {telebot.formatting.hcode(old_key)}
|
Старый ключ: {telebot.formatting.hcode(old_key)}
|
||||||
Новый ключ: {telebot.formatting.hcode(key)}""",parse_mode="HTML")
|
Новый ключ: {telebot.formatting.hcode(key)}""",parse_mode="HTML")
|
||||||
@ -223,15 +227,16 @@ def key_res(message):
|
|||||||
@bot.message_handler(commands=['me'])
|
@bot.message_handler(commands=['me'])
|
||||||
def me(message):
|
def me(message):
|
||||||
try:
|
try:
|
||||||
if is_auth(bot, message):
|
if not is_auth(bot, message) or not ok_args(bot, message, 1, '```\n/me```'):
|
||||||
db = load()
|
return 0
|
||||||
nick = db[str(message.chat.id)]
|
db = load()
|
||||||
user = db[nick]
|
nick = db[str(message.chat.id)]
|
||||||
ch = user.channel
|
user = db[nick]
|
||||||
if not user.channel:
|
ch = user.channel
|
||||||
ch = "Не задан."
|
if not user.channel:
|
||||||
|
ch = "Не задан."
|
||||||
|
|
||||||
bot.reply_to(message, f"""Заданный канал: {telebot.formatting.hcode(ch)}
|
bot.reply_to(message, f"""Заданный канал: {telebot.formatting.hcode(ch)}
|
||||||
|
|
||||||
Ваш ник: {telebot.formatting.hcode(nick)}
|
Ваш ник: {telebot.formatting.hcode(nick)}
|
||||||
Ваша аватарка: {telebot.formatting.hcode(user.avatar)}
|
Ваша аватарка: {telebot.formatting.hcode(user.avatar)}
|
||||||
@ -263,10 +268,14 @@ def catch_all_messages(message):
|
|||||||
bot.reply_to(message, "Не существует данного пользователя.")
|
bot.reply_to(message, "Не существует данного пользователя.")
|
||||||
elif user.channel != None:
|
elif user.channel != None:
|
||||||
channel = user.channel
|
channel = user.channel
|
||||||
|
db = load()
|
||||||
|
# Проверяем существование пользователя
|
||||||
|
if channel not in db:
|
||||||
|
bot.reply_to(message, "Не существует данного пользователя.")
|
||||||
|
return 0
|
||||||
# Проверяем ключи
|
# Проверяем ключи
|
||||||
if not key_valid(bot, message, channel):
|
if not key_valid(bot, message, channel):
|
||||||
return 0
|
return 0
|
||||||
db = load()
|
|
||||||
|
|
||||||
if message.chat.id not in db[channel].blocks:
|
if message.chat.id not in db[channel].blocks:
|
||||||
try:
|
try:
|
||||||
@ -299,7 +308,10 @@ def catch_all_messages(message):
|
|||||||
caption = ""
|
caption = ""
|
||||||
bot.send_video(db[channel].id, vid_id, caption = f"{telebot.formatting.hcode(':'+nick) + avatar}", parse_mode="HTML")
|
bot.send_video(db[channel].id, vid_id, caption = f"{telebot.formatting.hcode(':'+nick) + avatar}", parse_mode="HTML")
|
||||||
else:
|
else:
|
||||||
bot.send_message(db[channel].id, f"{telebot.formatting.hcode(':'+nick) + avatar}\n" + message.text, parse_mode="HTML")
|
try:
|
||||||
|
bot.send_message(db[channel].id, f"{telebot.formatting.hcode(':'+nick) + avatar}\n" + message.text, parse_mode="HTML")
|
||||||
|
except:
|
||||||
|
catch_error(bot, message, 'spec_symb')
|
||||||
|
|
||||||
except:
|
except:
|
||||||
catch_error(bot, message)
|
catch_error(bot, message)
|
||||||
|
@ -17,10 +17,12 @@ def catch_error(bot, message, err_type = None):
|
|||||||
logging.error(traceback.format_exc()) # Логирование ошибок
|
logging.error(traceback.format_exc()) # Логирование ошибок
|
||||||
err = log_stream.getvalue() # Ошибка -> переменная
|
err = log_stream.getvalue() # Ошибка -> переменная
|
||||||
|
|
||||||
bot.reply_to(message, "Critical error:\n\n" + telebot.formatting.hcode(err), parse_mode='HTML')
|
bot.reply_to(message, 'Critical error:\n\n' + telebot.formatting.hcode(err), parse_mode='HTML')
|
||||||
|
|
||||||
# Очистка логов
|
# Очистка логов
|
||||||
log_stream.truncate(0)
|
log_stream.truncate(0)
|
||||||
log_stream.seek(0)
|
log_stream.seek(0)
|
||||||
|
elif err_type == 'spec_symb':
|
||||||
|
bot.reply_to(message, 'Невозможно отправить сообщение из-за специфических символов')
|
||||||
except:
|
except:
|
||||||
pass
|
pass
|
||||||
|
62
func.py
62
func.py
@ -21,32 +21,34 @@ def is_auth(bot, message):
|
|||||||
from re import sub, compile
|
from re import sub, compile
|
||||||
# -> True/False
|
# -> True/False
|
||||||
def nick_ok(bot, message, nick):
|
def nick_ok(bot, message, nick):
|
||||||
if len(nick) > 30:
|
try:
|
||||||
bot.reply_to(message,"Слишком длинный ник, попробуйте короче.")
|
if len(nick) > 30:
|
||||||
return False
|
bot.reply_to(message,"Слишком длинный ник, попробуйте короче.")
|
||||||
if is_num(nick):
|
return False
|
||||||
bot.reply_to(message,"Ник должен содержать хоть 1 букву, попробуйте ещё раз.")
|
if is_num(nick):
|
||||||
return False
|
bot.reply_to(message,"Ник должен содержать хоть 1 букву, попробуйте ещё раз.")
|
||||||
|
return False
|
||||||
|
|
||||||
en = True
|
en = True
|
||||||
ru = True
|
ru = True
|
||||||
# Если только английский
|
# Если только английский
|
||||||
regex = compile('[^a-zA-Z0-9]')
|
regex = compile('[^a-zA-Z0-9]')
|
||||||
check = regex.sub('', nick)
|
check = regex.sub('', nick)
|
||||||
if check != nick:
|
if check != nick:
|
||||||
en = False
|
en = False
|
||||||
# Если только русский
|
# Если только русский
|
||||||
regex = compile('[^а-яА-ЯЁё0-9]')
|
regex = compile('[^а-яА-ЯЁё0-9]')
|
||||||
check = regex.sub('', nick)
|
check = regex.sub('', nick)
|
||||||
if check != nick:
|
if check != nick:
|
||||||
ru = False
|
ru = False
|
||||||
|
|
||||||
if en == False and ru == False:
|
if en == False and ru == False:
|
||||||
bot.reply_to(message,"Нельзя смешивать алфавиты и ставить спец.-символы, попробуйте ещё раз")
|
bot.reply_to(message,"Нельзя смешивать алфавиты и ставить спец.-символы, попробуйте ещё раз")
|
||||||
return False
|
return False
|
||||||
|
|
||||||
return True
|
|
||||||
|
|
||||||
|
return True
|
||||||
|
except:
|
||||||
|
catch_error(bot, message)
|
||||||
|
|
||||||
# Проверяем совпадение ключей при отправке сообщений
|
# Проверяем совпадение ключей при отправке сообщений
|
||||||
# -> True/False
|
# -> True/False
|
||||||
@ -79,3 +81,17 @@ def key_valid(bot, message, channel):
|
|||||||
return False
|
return False
|
||||||
except:
|
except:
|
||||||
catch_error(bot, message)
|
catch_error(bot, message)
|
||||||
|
|
||||||
|
|
||||||
|
# Проверка на количество аргументов
|
||||||
|
# ok_args(bot, message, 2, '/nick никнейм') + '/nick test' = True
|
||||||
|
def ok_args(bot, message, count, mess):
|
||||||
|
try:
|
||||||
|
count_args = len(message.text.split())
|
||||||
|
if not count_args == count:
|
||||||
|
bot.reply_to(message, mess, parse_mode="Markdown")
|
||||||
|
return False
|
||||||
|
else:
|
||||||
|
return True
|
||||||
|
except:
|
||||||
|
catch_error(bot, message)
|
||||||
|
Loading…
Reference in New Issue
Block a user