2021-02-01 15:13:11 +00:00
|
|
|
|
import asyncio
|
2021-08-07 07:56:48 +00:00
|
|
|
|
import json
|
2021-04-08 15:21:40 +00:00
|
|
|
|
import os
|
2021-02-01 15:13:11 +00:00
|
|
|
|
import traceback
|
|
|
|
|
|
2021-08-07 07:56:48 +00:00
|
|
|
|
from core.elements import FetchTarget
|
|
|
|
|
from core.loader.decorator import command
|
2021-08-04 16:14:23 +00:00
|
|
|
|
from core.logger import Logger
|
2021-08-07 07:56:48 +00:00
|
|
|
|
from core.scheduler import Scheduler
|
2021-08-04 16:14:23 +00:00
|
|
|
|
from core.utils import get_url
|
|
|
|
|
from database import BotDBUtil
|
2021-03-21 08:14:28 +00:00
|
|
|
|
|
|
|
|
|
|
2021-04-10 14:41:19 +00:00
|
|
|
|
def getfileversions(path):
|
2021-04-08 12:23:38 +00:00
|
|
|
|
if not os.path.exists(path):
|
|
|
|
|
a = open(path, 'a')
|
|
|
|
|
a.close()
|
|
|
|
|
w = open(path, 'r+')
|
2021-02-01 15:13:11 +00:00
|
|
|
|
s = w.read().split('\n')
|
|
|
|
|
w.close()
|
|
|
|
|
return s
|
|
|
|
|
|
2021-08-04 16:14:23 +00:00
|
|
|
|
|
|
|
|
|
@command('mcv_rss', autorun=True)
|
2021-08-07 07:56:48 +00:00
|
|
|
|
async def mcv_rss(bot: FetchTarget):
|
2021-08-07 03:37:17 +00:00
|
|
|
|
@Scheduler.scheduled_job('interval', seconds=30)
|
2021-06-05 10:25:21 +00:00
|
|
|
|
async def java_main():
|
|
|
|
|
url = 'http://launchermeta.mojang.com/mc/game/version_manifest.json'
|
2021-02-01 15:13:11 +00:00
|
|
|
|
try:
|
2021-04-10 14:41:19 +00:00
|
|
|
|
version_file = os.path.abspath('./assets/mcversion.txt')
|
2021-08-04 16:14:23 +00:00
|
|
|
|
Logger.info('Checking mcv...')
|
2021-04-10 14:41:19 +00:00
|
|
|
|
verlist = getfileversions(version_file)
|
2021-08-04 16:14:23 +00:00
|
|
|
|
file = json.loads(await get_url(url))
|
2021-02-01 15:13:11 +00:00
|
|
|
|
release = file['latest']['release']
|
|
|
|
|
snapshot = file['latest']['snapshot']
|
|
|
|
|
if release not in verlist:
|
2021-08-04 16:14:23 +00:00
|
|
|
|
Logger.info(f'huh, we find {release}.')
|
|
|
|
|
get_target_id = BotDBUtil.Module.get_enabled_this('mcv_rss')
|
|
|
|
|
for x in get_target_id:
|
|
|
|
|
fetch = bot.fetch_target(x)
|
|
|
|
|
if fetch:
|
|
|
|
|
try:
|
|
|
|
|
await fetch.sendMessage('启动器已更新' + file['latest']['release'] + '正式版。')
|
|
|
|
|
await asyncio.sleep(0.5)
|
|
|
|
|
except Exception:
|
|
|
|
|
traceback.print_exc()
|
2021-04-10 14:41:19 +00:00
|
|
|
|
addversion = open(version_file, 'a')
|
2021-02-01 15:13:11 +00:00
|
|
|
|
addversion.write('\n' + release)
|
|
|
|
|
addversion.close()
|
2021-04-10 14:41:19 +00:00
|
|
|
|
verlist = getfileversions(version_file)
|
2021-02-01 15:13:11 +00:00
|
|
|
|
if snapshot not in verlist:
|
2021-08-04 16:14:23 +00:00
|
|
|
|
Logger.info(f'huh, we find {snapshot}.')
|
|
|
|
|
get_target_id = BotDBUtil.Module.get_enabled_this('mcv_rss')
|
|
|
|
|
for x in get_target_id:
|
|
|
|
|
fetch = bot.fetch_target(x)
|
|
|
|
|
if fetch:
|
|
|
|
|
try:
|
|
|
|
|
await fetch.sendMessage('启动器已更新' + file['latest']['snapshot'] + '快照。')
|
|
|
|
|
await asyncio.sleep(0.5)
|
|
|
|
|
except Exception:
|
|
|
|
|
traceback.print_exc()
|
2021-02-01 15:13:11 +00:00
|
|
|
|
addversion = open('./assets/mcversion.txt', 'a')
|
|
|
|
|
addversion.write('\n' + snapshot)
|
|
|
|
|
addversion.close()
|
2021-08-04 16:14:23 +00:00
|
|
|
|
Logger.info('mcv checked.')
|
2021-02-01 15:13:11 +00:00
|
|
|
|
except Exception:
|
|
|
|
|
traceback.print_exc()
|
|
|
|
|
|
2021-04-10 14:41:19 +00:00
|
|
|
|
|
2021-08-07 07:56:48 +00:00
|
|
|
|
@command('mcv_jira_rss', autorun=True)
|
|
|
|
|
async def mcv_jira_rss(bot: FetchTarget):
|
|
|
|
|
@Scheduler.scheduled_job('interval', seconds=30)
|
|
|
|
|
async def java_jira():
|
|
|
|
|
urls = {'Java版': 'https://bugs.mojang.com/rest/api/2/project/10400/versions',
|
|
|
|
|
'基岩版': 'https://bugs.mojang.com/rest/api/2/project/10200/versions',
|
|
|
|
|
'Minecraft Dungeons': 'https://bugs.mojang.com/rest/api/2/project/11901/versions'}
|
|
|
|
|
for name in urls:
|
2021-08-07 03:37:17 +00:00
|
|
|
|
try:
|
2021-08-07 07:56:48 +00:00
|
|
|
|
version_file = os.path.abspath(f'./assets/mcjira_{name}.txt')
|
|
|
|
|
Logger.info(f'Checking Jira mcv {name}...')
|
2021-08-07 03:37:17 +00:00
|
|
|
|
verlist = getfileversions(version_file)
|
2021-08-07 07:56:48 +00:00
|
|
|
|
file = json.loads(await get_url(urls[name]))
|
|
|
|
|
releases = []
|
2021-08-07 03:37:17 +00:00
|
|
|
|
for v in file:
|
|
|
|
|
if not v['archived']:
|
2021-08-07 07:56:48 +00:00
|
|
|
|
releases.append(v['name'])
|
|
|
|
|
for release in releases:
|
|
|
|
|
if release not in verlist:
|
|
|
|
|
Logger.info(f'huh, we find {release}.')
|
|
|
|
|
verlist.append(release)
|
2021-08-07 03:37:17 +00:00
|
|
|
|
get_target_id = BotDBUtil.Module.get_enabled_this('mcv_jira_rss')
|
2021-08-07 07:56:48 +00:00
|
|
|
|
for id_ in get_target_id:
|
|
|
|
|
fetch = bot.fetch_target(id_)
|
2021-08-07 03:37:17 +00:00
|
|
|
|
if fetch:
|
2021-08-07 07:56:48 +00:00
|
|
|
|
send = await fetch.sendMessage(
|
|
|
|
|
f'Jira已更新{name} {release}。\n(Jira上的信息仅作版本号预览用,不代表启动器已更新此版本)')
|
2021-08-07 03:37:17 +00:00
|
|
|
|
addversion = open(version_file, 'a')
|
2021-08-07 07:56:48 +00:00
|
|
|
|
addversion.write('\n' + release)
|
2021-08-07 03:37:17 +00:00
|
|
|
|
addversion.close()
|
2021-08-07 07:56:48 +00:00
|
|
|
|
Logger.info('jira mcv checked.')
|
2021-08-07 03:37:17 +00:00
|
|
|
|
except Exception:
|
|
|
|
|
traceback.print_exc()
|