49 lines
1.9 KiB
Python
49 lines
1.9 KiB
Python
|
# lazyleech - Telegram bot primarily to leech from torrents and upload to Telegram
|
||
|
# Copyright (c) 2021 lazyleech developers <theblankx protonmail com, meliodas_bot protonmail com>
|
||
|
#
|
||
|
# This program is free software: you can redistribute it and/or modify
|
||
|
# it under the terms of the GNU Affero General Public License as published
|
||
|
# by the Free Software Foundation, either version 3 of the License, or
|
||
|
# (at your option) any later version.
|
||
|
#
|
||
|
# This program is distributed in the hope that it will be useful,
|
||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
# GNU Affero General Public License for more details.
|
||
|
#
|
||
|
# You should have received a copy of the GNU Affero General Public License
|
||
|
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||
|
|
||
|
import asyncio
|
||
|
import logging
|
||
|
import traceback
|
||
|
from pyrogram import idle
|
||
|
from . import app, ADMIN_CHATS, preserved_logs
|
||
|
from .utils.upload_worker import upload_worker
|
||
|
|
||
|
logging.basicConfig(level=logging.INFO)
|
||
|
logging.getLogger('pyrogram.syncer').setLevel(logging.WARNING)
|
||
|
|
||
|
async def main():
|
||
|
async def _autorestart_worker():
|
||
|
while True:
|
||
|
try:
|
||
|
await upload_worker()
|
||
|
except Exception as ex:
|
||
|
preserved_logs.append(ex)
|
||
|
logging.exception('upload worker commited suicide')
|
||
|
tb = traceback.format_exc()
|
||
|
for i in ADMIN_CHATS:
|
||
|
try:
|
||
|
await app.send_message(i, 'upload worker commited suicide')
|
||
|
await app.send_message(i, tb, parse_mode=None)
|
||
|
except Exception:
|
||
|
logging.exception('failed %s', i)
|
||
|
tb = traceback.format_exc()
|
||
|
asyncio.create_task(_autorestart_worker())
|
||
|
await app.start()
|
||
|
await idle()
|
||
|
await app.stop()
|
||
|
|
||
|
app.loop.run_until_complete(main())
|