-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathrss.py
124 lines (103 loc) · 4.72 KB
/
rss.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
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
121
122
123
124
import os
import sys
import feedparser
from sql import db
from time import sleep
from pyrogram import Client, filters
from pyrogram.errors import FloodWait
from apscheduler.schedulers.background import BackgroundScheduler
try:
api_id = int(os.environ["API_ID"]) # Get it from my.telegram.org
api_hash = os.environ["API_HASH"] # Get it from my.telegram.org
feed_urls = list(set(i for i in os.environ["FEED_URLS"].split("|"))) # RSS Feed URL of the site.
bot_token = os.environ["BOT_TOKEN"] # Get it by creating a bot on https://t.me/botfather
log_channel = int(os.environ["LOG_CHANNEL"]) # Telegram Channel ID where the bot is added and have write permission. You can use group ID too.
check_interval = int(os.environ.get("INTERVAL", 10)) # Check Interval in seconds.
max_instances = int(os.environ.get("MAX_INSTANCES", 3)) # Max parallel instance to be used.
str_session = os.environ.get("STR_SESSION") #String session generate using your tg mobile number for sending mirror cmd on your behalf. Generate using python gen_str.py
mirr_chat = int(os.environ.get("MIRROR_CHAT_ID", "-1")) #Group/chat_id of mirror chat or mirror bot to send mirror cmd
mirr_cmd = os.environ.get("MIRROR_CMD", "/mirror") #if you have changed default cmd of mirror bot, replace this.
except Exception as e:
print(e)
print("One or more variables missing or have error. Exiting !")
sys.exit(1)
for feed_url in feed_urls:
if db.get_link(feed_url) == None:
db.update_link(feed_url, "*")
app = Client(":memory:", api_id=api_id, api_hash=api_hash, bot_token=bot_token)
app2 = None
if str_session is not None and str_session != "":
app2 = Client(str_session, api_id=api_id, api_hash=api_hash)
@app.on_message(filters.command(["up"]))
async def reply_up_bot(client, msg):
if msg.chat.id in [log_channel, mirr_chat]:
await msg.reply_text(f"Up Bro")
if app2 is not None:
@app2.on_message(filters.command(["up"]))
async def reply_up_ub(client, msg):
if msg.chat.id in [log_channel, mirr_chat]:
await msg.reply_text(f"Up Bro")
def create_feed_checker(feed_url):
def check_feed():
FEED = feedparser.parse(feed_url)
if len(FEED.entries) == 0:
print(f"RSS Feed at {feed_url} returned no entries")
try:
app.send_message(log_channel, f"RSS Feed at {feed_url} returned no entries")
except FloodWait as e:
print(f"FloodWait: {e.x} seconds")
sleep(e.x)
except Exception as e:
print(e)
return
first_entry = FEED.entries[0]
last_id_from_db = db.get_link(feed_url).link
if last_id_from_db == "*":
message = f"**{first_entry.title}**\n```{first_entry.link}```"
try:
if "TombDoc" in first_entry.link or "Galaxy" in first_entry.link:
app.send_message(log_channel, message)
else:
print(f"{first_entry.link}: >>skipped<<")
if app2 is not None:
mirr_msg = f"{mirr_cmd} {first_entry.link}"
app2.send_message(mirr_chat, mirr_msg)
except FloodWait as e:
print(f"FloodWait: {e.x} seconds")
sleep(e.x)
except Exception as e:
print(e)
db.update_link(feed_url, first_entry.id)
return
for entry_num, entry in enumerate(FEED.entries):
# Have reached the end of new entries
if entry.id == last_id_from_db:
# No new entry
if entry_num == 0:
print(f"Checked feed for {feed_url}: {entry.id}")
break
# ↓ Edit this message as your needs.
message = f"**{entry.title}**\n```{entry.link}```"
try:
if "1080p" in entry.link or "2160p" in entry.link or "psa" in entry.link:
app.send_message(log_channel, message)
else:
print(f"{entry.link}: >>skipped<<")
if app2 is not None:
mirr_msg = f"{mirr_cmd} {entry.link}"
app2.send_message(mirr_chat, mirr_msg)
except FloodWait as e:
print(f"FloodWait: {e.x} seconds")
sleep(e.x)
except Exception as e:
print(e)
db.update_link(feed_url, first_entry.id)
return check_feed
scheduler = BackgroundScheduler()
for feed_url in feed_urls:
feed_checker = create_feed_checker(feed_url)
scheduler.add_job(feed_checker, "interval", seconds=check_interval, max_instances=max_instances)
scheduler.start()
if app2 is not None:
app2.start()
app.run()