2019-11-11 08:56:08 +00:00
|
|
|
|
import aiohttp
|
|
|
|
|
import asyncio
|
|
|
|
|
import datetime
|
|
|
|
|
import logging
|
|
|
|
|
import dateparser
|
|
|
|
|
from royalnet.commands import *
|
2019-11-28 01:30:40 +00:00
|
|
|
|
from royalnet.serf.telegram.escape import escape
|
2019-11-11 08:56:08 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
log = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class PeertubeCommand(Command):
|
|
|
|
|
name: str = "peertube"
|
|
|
|
|
|
|
|
|
|
description: str = "Guarda quando è uscito l'ultimo video su RoyalTube."
|
|
|
|
|
|
|
|
|
|
_ready = asyncio.Event()
|
|
|
|
|
|
|
|
|
|
_latest_date: datetime.datetime = None
|
|
|
|
|
|
|
|
|
|
def __init__(self, interface: CommandInterface):
|
|
|
|
|
super().__init__(interface)
|
|
|
|
|
if self.interface.name == "telegram":
|
|
|
|
|
self.loop.create_task(self._ready_up())
|
|
|
|
|
self.loop.create_task(self._update())
|
|
|
|
|
|
|
|
|
|
async def _get_json(self):
|
|
|
|
|
log.debug("Getting jsonfeed")
|
|
|
|
|
async with aiohttp.ClientSession() as session:
|
2019-11-28 01:30:40 +00:00
|
|
|
|
async with session.get(self.interface.cfg["Peertube"]["feed_url"]) as response:
|
2019-11-11 08:56:08 +00:00
|
|
|
|
log.debug("Parsing jsonfeed")
|
|
|
|
|
j = await response.json()
|
|
|
|
|
log.debug("Jsonfeed parsed successfully")
|
|
|
|
|
return j
|
|
|
|
|
|
|
|
|
|
async def _send(self, message):
|
|
|
|
|
client = self.interface.bot.client
|
|
|
|
|
await self.interface.bot.safe_api_call(client.send_message,
|
2019-11-28 01:30:40 +00:00
|
|
|
|
chat_id=self.interface.cfg["Telegram"]["main_group_id"],
|
|
|
|
|
text=escape(message),
|
2019-11-11 08:56:08 +00:00
|
|
|
|
parse_mode="HTML",
|
|
|
|
|
disable_webpage_preview=True)
|
|
|
|
|
|
|
|
|
|
async def _ready_up(self):
|
|
|
|
|
j = await self._get_json()
|
|
|
|
|
if j["version"] != "https://jsonfeed.org/version/1":
|
2019-11-28 01:30:40 +00:00
|
|
|
|
raise ConfigurationError("url is not a jsonfeed")
|
2019-11-11 08:56:08 +00:00
|
|
|
|
videos = j["items"]
|
|
|
|
|
for video in reversed(videos):
|
|
|
|
|
date_modified = dateparser.parse(video["date_modified"])
|
|
|
|
|
if self._latest_date is None or date_modified > self._latest_date:
|
|
|
|
|
log.debug(f"Found newer video: {date_modified}")
|
|
|
|
|
self._latest_date = date_modified
|
|
|
|
|
self._ready.set()
|
|
|
|
|
|
|
|
|
|
async def _update(self):
|
|
|
|
|
await self._ready.wait()
|
|
|
|
|
while True:
|
|
|
|
|
j = await self._get_json()
|
|
|
|
|
videos = j["items"]
|
|
|
|
|
for video in reversed(videos):
|
|
|
|
|
date_modified = dateparser.parse(video["date_modified"])
|
|
|
|
|
if date_modified > self._latest_date:
|
|
|
|
|
log.debug(f"Found newer video: {date_modified}")
|
|
|
|
|
self._latest_date = date_modified
|
|
|
|
|
await self._send(f"🆕 Nuovo video su RoyalTube!\n"
|
|
|
|
|
f"[b]{video['title']}[/b]\n"
|
|
|
|
|
f"{video['url']}")
|
2019-11-28 01:30:40 +00:00
|
|
|
|
await asyncio.sleep(self.interface.cfg["Peertube"]["feed_update_timeout"])
|
2019-11-11 08:56:08 +00:00
|
|
|
|
|
|
|
|
|
async def run(self, args: CommandArgs, data: CommandData) -> None:
|
|
|
|
|
if self.interface.name != "telegram":
|
|
|
|
|
raise UnsupportedError()
|
|
|
|
|
await data.reply(f"ℹ️ Ultimo video caricato il: [b]{self._latest_date.isoformat()}[/b]")
|