fix: announcement

This commit is contained in:
xtaodada 2024-09-30 21:34:58 +08:00
parent 5c737450cd
commit 3091144ba0
Signed by: xtaodada
GPG Key ID: 4CBB3F4FA8C85659
3 changed files with 36 additions and 53 deletions

View File

@ -1,11 +1,13 @@
from datetime import datetime from typing import TYPE_CHECKING
from typing import Optional
from mipac import Route from mipac import Route
from init import bot from init import bot
from misskey_init import MisskeyBot from misskey_init import MisskeyBot
if TYPE_CHECKING:
from mipac.models.announcement import Announcement
announcement_template = """<b>Misskey Announcement</b> announcement_template = """<b>Misskey Announcement</b>
<b>{0}</b> <b>{0}</b>
@ -13,28 +15,16 @@ announcement_template = """<b>Misskey Announcement</b>
{1}""" {1}"""
class Announcement: class UnreadAnnouncement:
def __init__(self, data, misskey_bot: MisskeyBot): def __init__(self, data: "Announcement", misskey_bot: MisskeyBot):
self.misskey_bot = misskey_bot self.misskey_bot = misskey_bot
self.id = data["id"] self.id = data.id
self.title = data["title"] self.title = data.title
self.text = data["text"] self.text = data.text
self.is_read = data["is_read"] self.is_read = data.is_read
self.image_url = data["image_url"] self.image_url = data.image_url
self._created_at = data["created_at"] self.created_at = data.created_at
self._updated_at = data["updated_at"] self.updated_at = data.updated_at
@property
def created_at(self) -> datetime:
return datetime.strptime(self._created_at, "%Y-%m-%dT%H:%M:%S.%fZ")
@property
def updated_at(self) -> Optional[datetime]:
return (
datetime.strptime(self._updated_at, "%Y-%m-%dT%H:%M:%S.%fZ")
if self._updated_at
else None
)
async def send_notice(self): async def send_notice(self):
if not self.image_url: if not self.image_url:
@ -67,17 +57,3 @@ class Announcement:
auth=True, auth=True,
lower=True, lower=True,
) )
async def get_unread_announcements(misskey_bot: MisskeyBot):
data = {
"limit": 10,
"withUnreads": True,
}
req = await misskey_bot.core.http.request(
Route("POST", "/api/announcements"),
json=data,
auth=True,
lower=True,
)
return [Announcement(i, misskey_bot) for i in req]

View File

@ -1,14 +0,0 @@
from defs.announcement import get_unread_announcements
from misskey_init import misskey_bot_map
from models.services.scheduler import scheduler
# @scheduler.scheduled_job("interval", minutes=15, id="check_announcement")
async def announcement():
for bot in misskey_bot_map.values():
data = await get_unread_announcements(bot)
for an in data:
try:
await an.send_notice()
finally:
await an.mark_as_read()

View File

@ -1,14 +1,35 @@
import contextlib import contextlib
from typing import TYPE_CHECKING
from defs.announcement import UnreadAnnouncement
from init import bot from init import bot
from misskey_init import init_misskey_bot, misskey_bot_map from misskey_init import init_misskey_bot, misskey_bot_map
from models.services.scheduler import scheduler from models.services.scheduler import scheduler
if TYPE_CHECKING:
from mipac import MeDetailed
from misskey_init import MisskeyBot
bot.loop.create_task(init_misskey_bot()) bot.loop.create_task(init_misskey_bot())
@scheduler.scheduled_job("cron", hour=1, id="daily_status") async def get_unread_announcements(me: "MeDetailed", m_bot: "MisskeyBot"):
if not me:
return
un = [UnreadAnnouncement(an, m_bot) for an in me.unread_announcements]
for an in un:
try:
await an.send_notice()
finally:
await an.mark_as_read()
@scheduler.scheduled_job("cron", minute=30, id="daily_status")
async def daily_status(): async def daily_status():
for m_bot in misskey_bot_map.values(): for m_bot in misskey_bot_map.values():
with contextlib.suppress(Exception): with contextlib.suppress(Exception):
await m_bot.core.api.get_me() me = await m_bot.core.api.get_me()
await get_unread_announcements(me, m_bot)