Исправление бага с Low-Admin

main
Your Name 5 months ago
parent 8bf89c7a6d
commit 35d48a6307

@ -54,14 +54,13 @@ def write_users():
# LA - Low Admin. # LA - Low Admin.
# Admin permissions in bot without admin rights. # Admin permissions in bot without admin rights.
def read_la(): def read_la():
global la with open('la.json', 'r') as openfile:
with open('la.json', 'r') as openfile: la = json.load(openfile)
la = json.load(openfile) return la
def write_la(): def write_la(la):
global la js = json.dumps(la, indent=2)
js = json.dumps(la, indent=2) with open("la.json", "w") as outfile:
with open("la.json", "w") as outfile: outfile.write(js)
outfile.write(js)
####################FAST HASH################# ####################FAST HASH#################
from xxhash import xxh32 from xxhash import xxh32
@ -147,7 +146,6 @@ def get_time(message):
if time: if time:
break break
for f in list(formats.keys()): for f in list(formats.keys()):
# print(i, ' ', f)
if f in i: if f in i:
try: try:
time = [i[:-1], int(i[:-1]) * formats[i[-1]][0] , formats[i[-1]][1] ] time = [i[:-1], int(i[:-1]) * formats[i[-1]][0] , formats[i[-1]][1] ]
@ -158,7 +156,7 @@ def get_time(message):
return time return time
def have_rights(message, set_la = False): def have_rights(message, set_la = False):
global la ; read_la() la = read_la()
if message.from_user.id in get_admins(message): if message.from_user.id in get_admins(message):
return True return True
elif is_anon(message): elif is_anon(message):
@ -225,6 +223,8 @@ def help(message):
/chatid Айди чата /chatid Айди чата
/del Удаление сообщения /del Удаление сообщения
/la - всё о режиме 'low admin'
/secret Функция для получения ссылки html на пользователя в лс. /secret Функция для получения ссылки html на пользователя в лс.
/html <code> Отправка текста сообщения в режиме формата html. /html <code> Отправка текста сообщения в режиме формата html.
@ -411,21 +411,30 @@ def chatid(message):
def have_la(id): def have_la(id):
try: try:
global la ; read_la() la = read_la()
if id in la: if id in la:
return True return True
else: else:
la[id] = [] la[id] = []
write_la() write_la(la)
return True return True
except Exception as e: except Exception as e:
catch_error(message, e) catch_error(message, e)
@bot.message_handler(commands=['la'])
def la(message):
bot.reply_to(message, f'''Доступные команды:
{telebot.formatting.hcode("/la-list")} - список администраторов в режиме low-admin
{telebot.formatting.hcode("/la-add @nick")} - добавить в администраторы
{telebot.formatting.hcode("/la-del @nick")} - удалить из администраторов
''', parse_mode = 'HTML')
@bot.message_handler(commands=['la-list']) @bot.message_handler(commands=['la-list'])
def la_list(message): def la_list(message):
try: try:
if have_rights(message, set_la=True): if have_rights(message, set_la=True):
global la ; read_la() la = read_la()
if have_la(str(message.chat.id)): if have_la(str(message.chat.id)):
s = "Список администраторов в режиме low-admin:\n" s = "Список администраторов в режиме low-admin:\n"
for i in la[str(message.chat.id)]: for i in la[str(message.chat.id)]:
@ -438,11 +447,13 @@ def la_list(message):
def la_add(message): def la_add(message):
try: try:
if have_rights(message, set_la=True): if have_rights(message, set_la=True):
global la ; read_la() la = read_la()
if have_la(message.chat.id): if have_la(message.chat.id):
nick = message.text.split()[1][1:] nick = message.text.split()[1][1:]
la[message.chat.id].append(nick) print(la)
write_la() la[str(message.chat.id)].append(nick)
print(la)
write_la(la)
bot.reply_to(message, f"Пользователь @{nick} успешно добавлен в список администраторов.") bot.reply_to(message, f"Пользователь @{nick} успешно добавлен в список администраторов.")
except Exception as e: except Exception as e:
catch_error(message, e) catch_error(message, e)
@ -451,13 +462,13 @@ def la_add(message):
def la_del(message, set_la=True): def la_del(message, set_la=True):
try: try:
if have_rights(message, set_la=True): if have_rights(message, set_la=True):
global la ; read_la() la = read_la()
if have_la(message.chat.id): if have_la(message.chat.id):
nick = message.text.split()[1][1:] nick = message.text.split()[1][1:]
if nick in la[message.chat.id]: if nick in la[str(message.chat.id)]:
del la[message.chat.id] la[str(message.chat.id)].remove(nick)
write_la() write_la(la)
bot.reply_to(message, f"Пользователь @{nick} был исключён из списка администраторов.") bot.reply_to(message, f"Пользователь @{nick} был исключён из списка администраторов.")
except Exception as e: except Exception as e:
catch_error(message, e) catch_error(message, e)
@ -557,7 +568,7 @@ def catch_error(message, e, err_type = None):
##################MAIN THREAD##### ##################MAIN THREAD#####
#''' '''
while True: while True:
try: try:
bot.polling() bot.polling()
@ -565,6 +576,6 @@ while True:
exit() exit()
except: except:
pass pass
#''' '''
bot.polling() bot.polling()
#''' #'''

Loading…
Cancel
Save