forked from Arasan254/TF-File-store-bot
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathbot.py
More file actions
120 lines (103 loc) · 5.61 KB
/
bot.py
File metadata and controls
120 lines (103 loc) · 5.61 KB
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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
from aiohttp import web
from plugins import web_server
import pyromod.listen
from pyrogram import Client
from pyrogram.enums import ParseMode
import sys
from datetime import datetime
from config import API_HASH, API_ID, LOGGER, BOT_TOKEN, TG_BOT_WORKERS, FORCE_SUB_CHANNEL_1, FORCE_SUB_CHANNEL_2, FORCE_SUB_CHANNEL_3, FORCE_SUB_CHANNEL_4, CHANNEL_ID, PORT
import pyrogram.utils
pyrogram.utils.MIN_CHANNEL_ID = -1009999999999
class Bot(Client):
def __init__(self):
super().__init__(
name="Bot",
api_hash=API_HASH,
api_id=API_ID,
plugins={"root": "plugins"},
workers=TG_BOT_WORKERS,
bot_token=BOT_TOKEN
)
self.LOGGER = LOGGER
async def start(self):
await super().start()
usr_bot_me = await self.get_me()
self.uptime = datetime.now()
if FORCE_SUB_CHANNEL_1:
try:
link = (await self.get_chat(FORCE_SUB_CHANNEL_1)).invite_link
if not link:
await self.export_chat_invite_link(FORCE_SUB_CHANNEL_1)
link = (await self.get_chat(FORCE_SUB_CHANNEL_1)).invite_link
self.invitelink1 = link
except Exception as a:
self.LOGGER(__name__).warning(a)
self.LOGGER(__name__).warning("Bot Can't Export Invite link From Force Sub Channel!")
self.LOGGER(__name__).warning(f"Please Double Check The FORCE_SUB_CHANNEL_1 Value And Make Sure Bot Is Admin In Channel With Invite Users Via Link Permission, Current Force Sub Channel Value: {FORCE_SUB_CHANNEL_1}")
self.LOGGER(__name__).info("\nBot Stopped. https://t.me/tech_freak_tamil for Support")
sys.exit()
if FORCE_SUB_CHANNEL_2:
try:
link = (await self.get_chat(FORCE_SUB_CHANNEL_2)).invite_link
if not link:
await self.export_chat_invite_link(FORCE_SUB_CHANNEL_2)
link = (await self.get_chat(FORCE_SUB_CHANNEL_2)).invite_link
self.invitelink2 = link
except Exception as a:
self.LOGGER(__name__).warning(a)
self.LOGGER(__name__).warning("Bot can't Export Invite link from Force Sub Channel!")
self.LOGGER(__name__).warning(f"Please Double check the FORCE_SUB_CHANNEL_2 value and Make sure Bot is Admin in channel with Invite Users via Link Permission, Current Force Sub Channel Value: {FORCE_SUB_CHANNEL_2}")
self.LOGGER(__name__).info("\nBot Stopped. https://t.me/tech_freak_tamil for support")
sys.exit()
if FORCE_SUB_CHANNEL_3:
try:
link = (await self.get_chat(FORCE_SUB_CHANNEL_3)).invite_link
if not link:
await self.export_chat_invite_link(FORCE_SUB_CHANNEL_3)
link = (await self.get_chat(FORCE_SUB_CHANNEL_3)).invite_link
self.invitelink3 = link
except Exception as a:
self.LOGGER(__name__).warning(a)
self.LOGGER(__name__).warning("Bot Can't Export Invite link From Force Sub Channel!")
self.LOGGER(__name__).warning(f"Please Double Check The FORCE_SUB_CHANNELS Value And Make Sure Bot Is Admin In Channel With Invite Users Via Link Permission, Current Force Sub Channel Value: {FORCE_SUB_CHANNEL_3}")
self.LOGGER(__name__).info("\nBot Stopped. https://t.me/tech_freak_tamil For Support")
sys.exit()
if FORCE_SUB_CHANNEL_4:
try:
link = (await self.get_chat(FORCE_SUB_CHANNEL_4)).invite_link
if not link:
await self.export_chat_invite_link(FORCE_SUB_CHANNEL_4)
link = (await self.get_chat(FORCE_SUB_CHANNEL_4)).invite_link
self.invitelink4 = link
except Exception as a:
self.LOGGER(__name__).warning(a)
self.LOGGER(__name__).warning("Bot Can't Export Invite link From Force Sub Channel!")
self.LOGGER(__name__).warning(f"Please Double Check The FORCE_SUB_CHANNEL Value And Make Sure Bot Is Admin In Channel With Invite Users Via Link Permission, Current Force Sub Channel Value: {FORCE_SUB_CHANNEL_4}")
self.LOGGER(__name__).info("\nBot Stopped. https://t.me/tech_freak_tamil For Support")
sys.exit()
try:
db_channel = await self.get_chat(CHANNEL_ID)
self.db_channel = db_channel
test = await self.send_message(chat_id = db_channel.id, text = "BOT started !!!")
await test.delete()
except Exception as e:
self.LOGGER(__name__).warning(e)
self.LOGGER(__name__).warning(f"Make Sure Bot Is Admin In DB Channel, And Double Check The CHANNEL_ID Value, Current Value: {CHANNEL_ID}")
self.LOGGER(__name__).info("\nBot Stopped. https://t.me/tech_freak_tamil For Support")
sys.exit()
self.set_parse_mode(ParseMode.HTML)
self.LOGGER(__name__).info(f"Bot Running...!\n\nCreated By \nhttps://t.me/Tech_freak_tamil")
self.LOGGER(__name__).info(f"""ミ💖 TFT Developer 💖彡""")
self.username = usr_bot_me.username
#web-response
app = web.AppRunner(await web_server())
await app.setup()
bind_address = "0.0.0.0"
await web.TCPSite(app, bind_address, PORT).start()
async def stop(self, *args):
await super().stop()
self.LOGGER(__name__).info("Bot Stopped...")
# Tech freak
# Don't Remove Credit!!!
# Telegram Channel @Tech_freak_tamil
# Developer @devilo7