Archived
1
0
Fork 0
This repository has been archived on 2024-04-26. You can view files and clone it, but cannot push or open issues or pull requests.
akari-bot/schedulers/mcv_rss.py

188 lines
8.1 KiB
Python
Raw Normal View History

import re
import traceback
from urllib.parse import quote
import ujson as json
from bs4 import BeautifulSoup
from google_play_scraper import app as google_play_scraper
from config import Config
from core.queue import JobQueue
from core.logger import Logger
from core.scheduler import Scheduler, IntervalTrigger
from core.utils.http import get_url
from core.utils.ip import IP
from core.utils.storedata import get_stored_list, update_stored_list
async def get_article(version):
match_snapshot = re.match(r'.*?w.*', version)
link = False
if match_snapshot:
link = 'https://www.minecraft.net/en-us/article/minecraft-snapshot-' + version
match_prerelease1 = re.match(r'(.*?)-pre(.*[0-9])', version)
match_prerelease2 = re.match(r'(.*?) Pre-Release (.*[0-9])', version)
if match_prerelease1:
match_prerelease = match_prerelease1
elif match_prerelease2:
match_prerelease = match_prerelease2
else:
match_prerelease = False
if match_prerelease:
link = f'https://www.minecraft.net/en-us/article/minecraft-' + re.sub("\\.", "-", match_prerelease.group(1)) \
+ f'-pre-release-{match_prerelease.group(2)}'
match_release_candidate = re.match(r'(.*?)-rc(.*[0-9])', version)
if match_release_candidate:
link = f'https://www.minecraft.net/en-us/article/minecraft-' + re.sub("\\.", "-",
match_release_candidate.group(1)) \
+ f'-release-candidate-{match_release_candidate.group(2)}'
if not link:
link = 'https://www.minecraft.net/en-us/article/minecraft-java-edition-' + re.sub("\\.", "-", version)
webrender = Config('web_render')
if not webrender:
return
get = webrender + '/source?url=' + quote(link)
try:
html = await get_url(get, attempt=1)
soup = BeautifulSoup(html, 'html.parser')
title = soup.find('h1')
if title.text == 'WERE SSSSSSSORRY':
return '', ''
else:
return link, title.text
except Exception:
traceback.print_exc()
return '', ''
trigger_times = 60 if not Config('slower_schedule') else 180
@Scheduler.scheduled_job(IntervalTrigger(seconds=trigger_times))
async def mcv_rss():
url = 'https://piston-meta.mojang.com/mc/game/version_manifest.json'
try:
verlist = get_stored_list('scheduler', 'mcv_rss')
file = json.loads(await get_url(url, attempt=1))
release = file['latest']['release']
snapshot = file['latest']['snapshot']
if release not in verlist:
Logger.info(f'huh, we find {release}.')
await JobQueue.trigger_hook_all('mcv_rss', message='mcv_rss.message.mcv_rss.release',
i18n=True, version=file['latest']['release'])
verlist.append(release)
update_stored_list('scheduler', 'mcv_rss', verlist)
article = await get_article(release)
if article[0] != '':
get_stored_news_title = get_stored_list('scheduler', 'mcnews')
if article[1] not in get_stored_news_title:
await JobQueue.trigger_hook_all('minecraft_news', message='minecraft_news.message.update_log', i18n=True, version=release, article=article[0])
get_stored_news_title.append(article[1])
update_stored_list('scheduler', 'mcnews', get_stored_news_title)
if snapshot not in verlist:
Logger.info(f'huh, we find {snapshot}.')
await JobQueue.trigger_hook_all('mcv_rss', message='mcv_rss.message.mcv_rss.snapshot', i18n=True, version=file['latest']['snapshot'])
verlist.append(snapshot)
update_stored_list('scheduler', 'mcv_rss', verlist)
article = await get_article(snapshot)
if article[0] != '':
get_stored_news_title = get_stored_list('scheduler', 'mcnews')
if article[1] not in get_stored_news_title:
await JobQueue.trigger_hook_all('minecraft_news', message='minecraft_news.message.update_log', i18n=True, version=snapshot, article=article[0])
get_stored_news_title.append(article[1])
update_stored_list('scheduler', 'mcnews', get_stored_news_title)
except Exception:
traceback.print_exc()
@Scheduler.scheduled_job(IntervalTrigger(seconds=180))
async def mcbv_rss():
if IP.country == 'China' or IP.country is None:
return # 中国大陆无法访问Google Play商店
try:
verlist = get_stored_list('scheduler', 'mcbv_rss')
version = google_play_scraper('com.mojang.minecraftpe')['version']
if version not in verlist:
Logger.info(f'huh, we find bedrock {version}.')
await JobQueue.trigger_hook_all('mcbv_rss', message='mcv_rss.message.mcbv_rss', i18n=True, version=version)
verlist.append(version)
update_stored_list('scheduler', 'mcbv_rss', verlist)
except Exception:
traceback.print_exc()
@Scheduler.scheduled_job(IntervalTrigger(seconds=trigger_times))
async def mcv_jira_rss():
try:
verlist = get_stored_list('scheduler', 'mcv_jira_rss')
file = json.loads(await get_url('https://bugs.mojang.com/rest/api/2/project/10400/versions', 200, attempt=1))
releases = []
for v in file:
if not v['archived']:
releases.append(v['name'])
else:
if v['name'] not in verlist:
verlist.append(v['name'])
for release in releases:
if release not in verlist:
Logger.info(f'huh, we find {release}.')
if release.lower().find('future version') != -1:
await JobQueue.trigger_hook_all('mcv_jira_rss', message='mcv_rss.message.mcv_jira_rss.future', i18n=True, version=release)
else:
await JobQueue.trigger_hook_all('mcv_jira_rss', message='mcv_rss.message.mcv_jira_rss', i18n=True, version=release)
verlist.append(release)
update_stored_list('scheduler', 'mcv_jira_rss', verlist)
except Exception:
traceback.print_exc()
@Scheduler.scheduled_job(IntervalTrigger(seconds=trigger_times))
async def mcbv_jira_rss():
try:
verlist = get_stored_list('scheduler', 'mcbv_jira_rss')
file = json.loads(await get_url('https://bugs.mojang.com/rest/api/2/project/10200/versions', 200, attempt=1))
releases = []
for v in file:
if not v['archived']:
releases.append(v['name'])
else:
if v['name'] not in verlist:
verlist.append(v['name'])
for release in releases:
if release not in verlist:
Logger.info(f'huh, we find {release}.')
await JobQueue.trigger_hook_all('mcbv_jira_rss', message='mcv_rss.message.mcbv_jira_rss',
i18n=True, version=release)
verlist.append(release)
update_stored_list('scheduler', 'mcbv_jira_rss', verlist)
except Exception:
traceback.print_exc()
@Scheduler.scheduled_job(IntervalTrigger(seconds=trigger_times))
async def mcdv_jira_rss():
try:
verlist = get_stored_list('scheduler', 'mcdv_jira_rss')
file = json.loads(await get_url('https://bugs.mojang.com/rest/api/2/project/11901/versions', 200, attempt=1))
releases = []
for v in file:
if not v['archived']:
releases.append(v['name'])
else:
if v['name'] not in verlist:
verlist.append(v['name'])
for release in releases:
if release not in verlist:
Logger.info(f'huh, we find {release}.')
await JobQueue.trigger_hook_all('mcdv_jira_rss', message='mcv_rss.message.mcdv_jira_rss',
i18n=True, version=release)
verlist.append(release)
update_stored_list('scheduler', 'mcdv_jira_rss', verlist)
except Exception:
traceback.print_exc()