forked from TGExplore/TG-Files-to-Link
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path__main__.py
72 lines (58 loc) · 2.18 KB
/
__main__.py
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
# tgfilestream - A Telegram bot that can stream Telegram files to users over HTTP.
# Copyright (C) 2019 Tulir Asokan
#
# 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 sys
from aiohttp import web
from telethon import functions
from .telegram import client, transfer
from .web_routes import routes
from .config import host, port, public_url
from .log import log
server = web.Application()
server.add_routes(routes)
runner = web.AppRunner(server)
loop = asyncio.get_event_loop()
async def start() -> None:
await client.start()
config = await client(functions.help.GetConfigRequest())
for option in config.dc_options:
if option.ip_address == client.session.server_address:
if client.session.dc_id != option.id:
log.warning(f"Fixed DC ID in session from {client.session.dc_id} to {option.id}")
client.session.set_dc(option.id, option.ip_address, option.port)
client.session.save()
break
transfer.post_init()
await runner.setup()
await web.TCPSite(runner, host, port).start()
async def stop() -> None:
await runner.cleanup()
await client.disconnect()
try:
loop.run_until_complete(start())
except Exception:
log.fatal("Failed to initialize", exc_info=True)
sys.exit(2)
log.info("Initialization complete")
log.debug(f"Listening at http://{host}:{port}")
log.debug(f"Public URL prefix is {public_url}")
try:
loop.run_forever()
except KeyboardInterrupt:
loop.run_until_complete(stop())
except Exception:
log.fatal("Fatal error in event loop", exc_info=True)
sys.exit(3)