Добрый день, у меня есть определенный код(представлен ниже), он берет новые сообщения из одного телеграмма канала и пересылает его в приватный канал администратора, администратор одобряет пост и он отправляется в другой уже основной канал.
Что требуется?
Нужно добавить возможность редактировать сообщения в канале администратора
И есть проблема в боте - бот не может работать с альбомами. если в посте больше чем 1 фотка он отказывается нормально работать
Код:
Что требуется?
Нужно добавить возможность редактировать сообщения в канале администратора
И есть проблема в боте - бот не может работать с альбомами. если в посте больше чем 1 фотка он отказывается нормально работать
Код:
Python:
from pyrogram import Client, filters # телеграм клиент
import shelve # файловая база данных
db = shelve.open('data.db', writeback=True)
# Создать можно на my.telegram.org
API_ID =
API_HASH = ''
PRIVATE_PUBLIC = '' # канал для управления ботом
PUBLIC_PUBLIC = '' # канал куда будем репостить
SOURCE_PUBLICS = [] #Каналы откуда берем посты
PHONE_NUMBER = '' # номер зарегистрованный в телеге
# создаем клиент телеграм
app = Client("cyberpunk", api_id=API_ID, api_hash=API_HASH,
phone_number=PHONE_NUMBER)
# обработчик нового сообщения
# вызывается при появлении нового поста в одном из пабликов-доноров
@app.on_message(filters.chat(SOURCE_PUBLICS))
def new_channel_post(client, message):
# сохраняем пост в базу (функцию add_post_to_db определим потом)
post_id = add_post_to_db(message)
# пересылаем пост в скрытый паблик
message.forward(PRIVATE_PUBLIC)
# в скрытый паблик отправляем присвоенный id поста
client.send_message(PRIVATE_PUBLIC, post_id)
# потом для пересылки в публичный паблик админ должен отправить боту этот id
# функция сохранения поста в бд
# генерирует уникальный id для поста и возвратит этот id
def add_post_to_db(message):
try:
# генерируем уникальный id для поста, равен максимальному в базе + 1
new_id = max(int(k) for k in db.keys()
if k.isdigit()) + 1
except:
# если постов еще нет в базе вылетит ошибка и мы попадем сюда
# тогда id ставим = 1
new_id = 1
# запись в базу необходимой информации про пост
# Обратите внимание, shelve поддеживает только строковые ключи
db[str(new_id)] = {
'username': message.sender_chat.username, # паблик-донор
'message_id': message.id, # внутренний id сообщения
}
return new_id
# обработчик нового сообщения из скрытого паблика
# если админ пишет в паблик `132+` это значит переслать пост с id = 132 в публичный паблик
@app.on_message(filters.chat(PRIVATE_PUBLIC)
& filters.regex(r'\d+\+') # фильтр текста сообщения `{число}+`
)
def post_request(client, message):
# получаем id поста из сообщения (обрезаем "+" в конце)
post_id = str(message.text).strip('+')
# получаем из базы пост по этому id
post = db.get(post_id)
if post is None:
# если нет в базе пишем в скрытый паблик ошибку
client.send_message(PRIVATE_PUBLIC, '`ERROR NO POST ID IN DB`')
# и выходим
return
try:
# по данным из базы, получаем pyrogram обьект сообщения
msg = client.get_messages(post['username'], post['message_id'])
# пересылаем его в паблик
# as_copy=True значит, что мы не будем отображать паблик донор, будто это наш пост XD
msg.copy(PUBLIC_PUBLIC)
# отправляем сообщение в скрытый паблик о успехе
client.send_message(PRIVATE_PUBLIC, f'`ПОСТ ОПУБЛИКОВАН!`')
except Exception as e:
# если произойдет какая-то ошибка в 3 строчках выше - сообщим админу
client.send_message(PRIVATE_PUBLIC, f'`ОШИБКА {e}`')
if __name__ == '__main__':
print('Atempt to run telegrabber')
app.run() # эта строка запустит все обработчики