Remove `HikkaDL` as redundant

pull/1/head
hikariatama 2022-05-26 18:07:13 +00:00
parent 71682ba8a1
commit a837428cea
3 changed files with 0 additions and 188 deletions

View File

@ -328,10 +328,6 @@ class Modules:
not db.get("hikka", "disable_quickstart", False)
or x != "quickstart.py"
)
and (
db.get("hikka.main", "use_dl_btn", True)
or x != "hikka_dl.py"
)
),
os.listdir(os.path.join(utils.get_base_dir(), MODULES_NAME)),
)

View File

@ -1,163 +0,0 @@
# █ █ ▀ █▄▀ ▄▀█ █▀█ ▀ ▄▀█ ▀█▀ ▄▀█ █▀▄▀█ ▄▀█
# █▀█ █ █ █ █▀█ █▀▄ █ ▄ █▀█ █ █▀█ █ ▀ █ █▀█
#
# © Copyright 2022
#
# https://t.me/hikariatama
#
# 🔒 Licensed under the GNU GPLv3
# 🌐 https://www.gnu.org/licenses/agpl-3.0.html
# scope: inline
# requires: websockets
import asyncio
import json
import logging
import re
import websockets
from telethon.tl.functions.contacts import UnblockRequest
from telethon.tl.functions.messages import SendReactionRequest
from .. import loader
logger = logging.getLogger(__name__)
ALLOWED_ORIGINS = [
"https://github.com/morisummerz/ftg-mods/raw/main",
"https://raw.githubusercontent.com/morisummerz/ftg-mods/main",
"https://mods.morisummer.ml",
"https://gitlab.com/cakestwix/friendly-userbot-modules/-/raw/master",
"https://twix.nonfalse-networks.net.ua/modules",
"https://mods.hikariatama.ru",
"https://raw.githubusercontent.com/hikariatama/ftg/master",
"https://github.com/hikariatama/ftg/raw/master",
"https://raw.githubusercontent.com/hikariatama/host/master",
"https://github.com/hikariatama/host/raw/master",
]
class RefreshToken(Exception):
"""Placeholder"""
@loader.tds
class HikkaDLMod(loader.Module):
"""Downloads stuff"""
strings = {"name": "HikkaDL"}
_connected = False
async def _wss(self):
logger.debug("Connecting to HikkaDL websocket....")
async with websockets.connect(
f"wss://hikka.hikariatama.ru/ws/{self.get('token')}"
) as wss:
while True:
ans = json.loads(await wss.recv())
self._connected = True
self._no_revoke = False
if ans["event"] == "dlmod":
try:
msg = (
await self._client.get_messages(
ans["channel"],
ids=[ans["message_id"]],
)
)[0]
except Exception:
await wss.send("msg_404")
continue
try:
link = re.search(
r".dlmod (https://[^ ]*\.py)",
msg.raw_text,
).group(1)
except Exception:
await wss.send("link_404")
continue
if "/".join(link.split("/")[:-1]).lower() not in ALLOWED_ORIGINS:
await wss.send("🚫 Origin is not allowed")
continue
# Modules' creators spend so much time to create cool modules
# so this code part is a little propriety gesture. Send a ❤
# to a message with a link to currently downloading module
try:
await self._client(
SendReactionRequest(
peer=ans["channel"],
msg_id=ans["message_id"],
reaction="❤️",
)
)
except Exception:
pass
m = await self._client.send_message("me", f".dlmod {link}")
if "dlmod" not in self.allmodules.commands:
await wss.send(
"Loader is unavailable. Perhaps, userbot is not yet fully loaded"
)
continue
await self.allmodules.commands["dlmod"](m)
load = (await self._client.get_messages(m.peer_id, ids=[m.id]))[0]
await wss.send(load.raw_text.splitlines()[0])
await m.delete()
if ans["event"] == "update":
logger.debug("Socket keep-alive timer expired, reconnecting...")
return
if ans["event"] == "invalid_token":
logger.debug("Refreshing token...")
raise RefreshToken
async def _connect(self):
self._no_revoke = False
while True:
try:
await self._wss()
except RefreshToken:
logger.debug("Token became invalid, revoking...")
await self._get_token()
except Exception:
logger.debug("Socket disconnected, retry in 5 sec", exc_info=True)
self._connected = False
await asyncio.sleep(5)
async def _get_token(self):
async with self._client.conversation(self._bot) as conv:
m = await conv.send_message("/token")
r = await conv.get_response()
token = r.raw_text
await m.delete()
await r.delete()
if not token.startswith("kirito_") and not token.startswith("asuna_"):
raise loader.LoadError("Can't get token")
self.set("token", token)
await self._client.delete_dialog(self._bot)
async def client_ready(self, client, db):
self._db = db
self._client = client
self._bot = "@hikka_userbot"
await self._client(UnblockRequest(id=self._bot))
if not self.get("token"):
await self._get_token()
self._task = asyncio.ensure_future(self._connect())
async def on_unload(self):
self._task.cancel()

View File

@ -664,27 +664,6 @@ class HikkaSettingsMod(loader.Module):
}
),
],
[
(
{
"text": self.strings("download_btn"),
"callback": self.inline__setting,
"args": (
"use_dl_btn",
False,
),
}
if self._db.get(main.__name__, "use_dl_btn", True)
else {
"text": self.strings("no_download_btn"),
"callback": self.inline__setting,
"args": (
"use_dl_btn",
True,
),
}
),
],
[
{
"text": self.strings("btn_restart"),