iShotaBot/defs/post.py

219 lines
8.2 KiB
Python
Raw Normal View History

2022-10-05 15:15:35 +00:00
import asyncio
import contextlib
import os
import re
2022-10-06 07:40:03 +00:00
import time
2022-10-05 15:15:35 +00:00
from asyncio import sleep
from io import BytesIO
2022-10-05 15:20:36 +00:00
from typing import List, Dict
2022-10-05 15:15:35 +00:00
from pyrogram.errors import FloodWait
from pyrogram.types import Message
from defs.glover import lofter_channel
from defs.lofter import lofter_link
from models.services.lofter import LofterPost as LofterPostModel
2022-10-06 07:40:03 +00:00
from models.models.lofter import Lofter as LofterModel
2022-10-05 15:15:35 +00:00
from init import request, bot
2023-01-12 13:19:54 +00:00
pattern = re.compile(r"<[^>]+>", re.S)
2022-10-05 15:15:35 +00:00
class LofterPost:
def __init__(self, url: str, offset: str):
try:
self.grainId = int(url)
except ValueError:
2023-01-12 13:19:54 +00:00
self.grainId = int(url[url.find("grainId=") + 8 :].split("&")[0])
2022-10-05 15:15:35 +00:00
try:
self.offset = int(offset)
except ValueError:
self.offset = 0
self.url = f"https://api.lofter.com/api-grain/grain/getH5Detail.json?grainId={self.grainId}&offset="
async def get_data(self):
if self.offset == -1:
return None
res = await request.get(self.url + str(self.offset))
assert res.status_code == 200
return res.json()
class Item:
2023-01-12 13:19:54 +00:00
def __init__(
self,
url,
origin_url,
title,
user_id,
username,
name,
tags,
comment,
post_id,
first,
static,
):
self.url = url.split("?")[0]
2022-10-05 15:15:35 +00:00
self.origin_url = origin_url
2022-10-06 07:40:03 +00:00
self.user_id = str(user_id)
2022-10-05 15:15:35 +00:00
self.username = username
2022-10-06 07:40:03 +00:00
self.post_id = post_id
self.first = first
2022-10-05 15:15:35 +00:00
self.static = static
2023-01-12 13:19:54 +00:00
title = pattern.sub("\n", title).strip()[:500]
self.text = (
f"<b>Lofter Status Info</b>\n\n"
f"<code>{title}</code>\n\n"
f'✍️ <a href="https://{username}.lofter.com/">{name}</a>\n'
f"{tags}\n"
f"{comment}"
)
2022-10-05 15:15:35 +00:00
2022-10-06 07:40:03 +00:00
async def check_exists(self):
2023-01-12 13:19:54 +00:00
return await LofterPostModel.get_by_post_and_user_id(
self.user_id, self.post_id
)
2022-10-06 07:40:03 +00:00
async def add_to_db(self):
post = LofterModel(
user_id=self.user_id,
username=self.username,
post_id=self.post_id,
2023-01-12 13:19:54 +00:00
timestamp=int(time.time()),
2022-10-06 07:40:03 +00:00
)
await LofterPostModel.add_post(post)
2022-10-05 15:15:35 +00:00
async def init(self):
file = await request.get(self.url, timeout=30)
file = BytesIO(file.content)
file.name = os.path.basename(self.url)
return file
async def upload(self, file):
try:
if self.static:
2023-01-12 13:19:54 +00:00
await bot.send_document(
lofter_channel,
file,
caption=self.text,
disable_notification=True,
reply_markup=lofter_link(
self.url, self.origin_url, self.username
),
)
2022-10-05 15:15:35 +00:00
else:
2023-01-12 13:19:54 +00:00
await bot.send_photo(
lofter_channel,
file,
caption=self.text,
disable_notification=True,
reply_markup=lofter_link(
self.url, self.origin_url, self.username
),
)
2022-10-05 15:15:35 +00:00
except FloodWait as e:
await asyncio.sleep(e.value + 0.5)
await self.upload(file)
@staticmethod
2022-10-05 15:20:36 +00:00
def parse_data(data: List[Dict]) -> List[Item]:
2022-10-05 15:15:35 +00:00
datas = []
for i in data:
if post_data := i.get("postData"):
2022-10-06 07:40:03 +00:00
user_id, username, name, comment = 0, "", "", ""
2022-10-05 15:15:35 +00:00
if blog_info := post_data.get("blogInfo"):
2022-10-06 07:40:03 +00:00
user_id = blog_info.get("blogId", 0)
2022-10-05 15:15:35 +00:00
username = blog_info.get("blogName", "")
name = blog_info.get("blogNickName", "")
if post_count_view := post_data.get("postCountView"):
a = post_count_view.get("responseCount", 0)
b = post_count_view.get("hotCount", 0)
c = post_count_view.get("favoriteCount", 0)
comment = f"评论({a}) 热度({b}) 喜欢({c})"
if post_view := post_data.get("postView"):
title = post_view.get("digest", "")
permalink = post_view.get("permalink", "")
origin_url = f"https://{username}.lofter.com/post/{permalink}"
tags = "".join(f"#{i} " for i in post_view.get("tagList", []))
if photo_post_view := post_view.get("photoPostView"):
if photo_links := photo_post_view.get("photoLinks"):
2022-10-06 07:40:03 +00:00
first = True
2022-10-05 15:15:35 +00:00
for photo in photo_links:
if url := photo.get("orign"):
width = photo.get("ow", 0)
height = photo.get("oh", 0)
static = abs(height - width) > 1300
2023-01-12 13:19:54 +00:00
datas.append(
LofterPost.Item(
url,
origin_url,
title,
user_id,
username,
name,
tags,
comment,
permalink,
first,
static,
)
)
2022-10-06 07:40:03 +00:00
first = False
2022-10-05 15:15:35 +00:00
return datas
2022-10-05 15:20:36 +00:00
async def get_items(self) -> List[Item]:
datas: List[LofterPost.Item] = []
2022-10-05 15:33:05 +00:00
data = await self.get_data()
if data:
2022-10-05 15:15:35 +00:00
data = data.get("data", {})
2022-10-05 15:33:05 +00:00
if data:
2022-10-05 15:15:35 +00:00
self.offset = data.get("offset", 0)
2022-10-05 15:33:05 +00:00
if posts := data.get("posts", []):
datas = self.parse_data(posts)
2022-10-05 15:15:35 +00:00
return datas
async def upload(self, message: Message):
2022-10-05 15:33:05 +00:00
msg = await message.reply_text("正在上传中...")
2022-10-06 07:40:03 +00:00
success, error, skip = 0, 0, 0
temp_skip = False
2022-10-05 15:33:05 +00:00
while True:
2022-10-05 15:15:35 +00:00
try:
2022-10-05 15:33:05 +00:00
items = await self.get_items()
if not items:
break
for item in items:
try:
2022-10-06 07:40:03 +00:00
if item.first:
if await item.check_exists():
temp_skip = True
skip += 1
await sleep(0.5)
continue
else:
temp_skip = False
elif temp_skip:
skip += 1
continue
2022-10-05 15:33:05 +00:00
file = await item.init()
await item.upload(file)
2022-10-06 07:40:03 +00:00
if item.first:
await item.add_to_db()
2022-10-05 15:33:05 +00:00
success += 1
2022-10-06 07:40:03 +00:00
await sleep(0.5)
except Exception as e:
print(f"Error uploading file: {e}")
2022-10-05 15:33:05 +00:00
error += 1
if (success + error) % 10 == 0:
with contextlib.suppress(Exception):
2023-01-12 13:19:54 +00:00
await msg.edit(
f"已成功上传{success}条,失败{error}条,跳过 {skip} 条,第 {success + error + skip}"
)
2022-10-05 15:33:05 +00:00
if self.offset == -1:
break
2022-10-06 07:40:03 +00:00
except Exception as e:
print(f"Error uploading file: {e}")
2022-10-05 15:33:05 +00:00
continue
2023-01-12 13:19:54 +00:00
await msg.edit(
f"上传完成,成功{success}条,失败{error}条,跳过 {skip} 条,总共 {success + error + skip}"
)