-
-
Notifications
You must be signed in to change notification settings - Fork 300
/
Copy pathrandom.py
97 lines (87 loc) · 3.17 KB
/
random.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
#
# Ultroid - UserBot
#
# This file is a part of < https://github.com/TeamUltroid/Ultroid/ >
# PLease read the GNU Affero General Public License in
# <https://www.github.com/TeamUltroid/Ultroid/blob/main/LICENSE/>.
"""
✘ Commands Available -
• `Get some Random Content.`
• `{i}random dog`
• `{i}random duck`
• `{i}random cat`
• `{i}random fox`
• `{i}random quote`
• `{i}random word`
• `{i}random car`
• `{i}random celebrity`
"""
from bs4 import BeautifulSoup as bs
from . import HNDLR, async_searcher, ultroid_cmd
# These Api's are Collected From
# ---- https://github.com/public-apis/public-apis
API_LIST = {
"cat": "https://aws.random.cat/meow",
"dog": "https://random.dog/woof.json",
"duck": "https://random-d.uk/api/random",
"fox": "https://randomfox.ca/floof/",
# "funfact": "https://asli-fun-fact-api.herokuapp.com/",
"quote": "https://api.themotivate365.com/stoic-quote",
"quotable": "http://api.quotable.io/random",
"word": "https://random-words-api.vercel.app/word",
# "words": "https://random-word-api.herokuapp.com/word?number=10",
# "food": "https://foodish-api.herokuapp.com/api/",
"car": "https://forza-api.tk/",
}
SCRAP_LIST = {"celebrity": "https://www.randomcelebritygenerator.com/"}
@ultroid_cmd(pattern="random ?(.*)")
async def random_magic(event):
if "randomuser" in event.text:
return
match = event.pattern_match.group(1)
if not (match and match in [*list(API_LIST.keys()), *list(SCRAP_LIST.keys())]):
return await event.eor(f"`Input Missing/Wrong..`\n`{HNDLR}help random`")
text, bsC, file = None, None, None
ret = match in SCRAP_LIST
try:
req = await async_searcher(
API_LIST.get(match) or SCRAP_LIST.get(match),
re_json=not ret,
re_content=ret,
)
except Exception as er:
return await event.eor(str(er))
if ret:
bsC = bs(req, "html.parser", from_encoding="utf-8")
if match == "cat":
file = req["file"]
elif match in ["dog", "duck"]:
file = req["url"]
elif match in ["car", "fox", "food"]:
file = req["image"]
elif match == "funfact":
text = req["data"]["fact"]
elif match == "quote":
text = f"**{req['data']['quote']}**\n\n~ {req['data']['author']}"
elif match == "quotable":
text = f'`{req["content"]}`' + "~ `{req['author']}`"
elif match == "word":
req = req[0]
text = f"**Random Word**\n- `{req['word']}` : `{req['definition']}`"
elif match == "words":
text = "**• Random Words**\n\n"
for word in req:
text += f"--`{word}`\n"
elif match == "celebrity" and bsC:
file = SCRAP_LIST[match] + bsC.find("img", "featured-celebrity-image")["src"]
name = bsC.find("div", "info").find("h1").text
text = f"• **Name :** `{name}`\n"
desc = bsC.find("p", "fame").text.replace("\n", "")
text += f" - __{desc}__\n\n"
bd = bsC.find("p", "birth-dates").text.replace("\n", "")
text += f"• **Birth Dates :** {bd}\n"
text += "-" * 10
if text and not file:
return await event.eor(text)
await event.reply(text, file=file)
await event.delete()