mirror of
https://github.com/MeoProject/lx-music-api-server.git
synced 2025-05-23 19:17:41 +08:00
83 lines
3.4 KiB
Python
83 lines
3.4 KiB
Python
# ----------------------------------------
|
|
# - mode: python -
|
|
# - author: helloplhm-qwq -
|
|
# - name: lx.py -
|
|
# - project: lx-music-api-server -
|
|
# - license: MIT -
|
|
# ----------------------------------------
|
|
# This file is part of the "lx-music-api-server" project.
|
|
|
|
from . import Httpx
|
|
from . import config
|
|
from . import scheduler
|
|
from .variable import iscn
|
|
from .log import log
|
|
from aiohttp.web import Response
|
|
import ujson as json
|
|
import re
|
|
|
|
logger = log('lx_script')
|
|
|
|
async def get_response(retry = 0):
|
|
if (retry > 10):
|
|
raise Exception('请求源脚本内容失败')
|
|
baseurl = 'https://raw.githubusercontent.com/lxmusics/lx-music-api-server/main/lx-music-source-example.js'
|
|
try:
|
|
if (iscn and (retry % 2) == 0):
|
|
req = await Httpx.AsyncRequest('https://mirror.ghproxy.com/' + baseurl)
|
|
else:
|
|
req = await Httpx.AsyncRequest(baseurl)
|
|
except:
|
|
return await get_response(retry + 1)
|
|
return req
|
|
|
|
async def get_script():
|
|
req = await get_response()
|
|
if (req.status == 200):
|
|
with open('./lx-music-source-example.js', 'w') as f:
|
|
f.write(req.text)
|
|
f.close()
|
|
logger.info('更新源脚本成功')
|
|
else:
|
|
raise Exception('请求源脚本内容失败')
|
|
|
|
async def generate_script_response(request):
|
|
if (request.query.get('key') != config.read_config('security.key.value') and config.read_config('security.key.enable')):
|
|
return 'key验证失败'
|
|
try:
|
|
with open('./lx-music-source-example.js', 'r') as f:
|
|
script = f.read()
|
|
except:
|
|
return '本地无源脚本'
|
|
scriptLines = script.split('\n')
|
|
newScriptLines = []
|
|
for line in scriptLines:
|
|
line = line.strip()
|
|
if (line.startswith('const API_URL')):
|
|
newScriptLines.append(f'const API_URL = "{request.scheme}://{request.host}"')
|
|
elif (line.startswith('const API_KEY')):
|
|
newScriptLines.append(f'const API_KEY = "{config.read_config("security.key.value")}"')
|
|
elif (line.startswith("* @name")):
|
|
newScriptLines.append(" * @name " + config.read_config("common.download_config.name"))
|
|
elif (line.startswith("* @description")):
|
|
newScriptLines.append(" * @description " + config.read_config("common.download_config.intro"))
|
|
elif (line.startswith("* @author")):
|
|
newScriptLines.append((" * @author helloplhm-qwq & Folltoshe & " + config.read_config("common.download_config.author")) if config.read_config("common.download_config.author") else " * @author helloplhm-qwq & Folltoshe")
|
|
elif (line.startswith("* @version")):
|
|
newScriptLines.append(" * @version " + config.read_config("common.download_config.version"))
|
|
elif (line.startswith("const DEV_ENABLE ")):
|
|
newScriptLines.append("const DEV_ENABLE = " + str(config.read_config("common.download_config.dev")).lower())
|
|
else:
|
|
newScriptLines.append(line)
|
|
r = '\n'.join(newScriptLines)
|
|
|
|
r = re.sub(r'const MUSIC_QUALITY = {[^}]+}', f'const MUSIC_QUALITY = JSON.parse(\'{json.dumps(config.read_config("common.download_config.quality"))}\')', r)
|
|
|
|
return Response(text = r, content_type = 'text/javascript',
|
|
headers = {
|
|
'Content-Disposition': 'attachment; filename=lx-music-source.js'
|
|
})
|
|
|
|
if (config.read_config('common.allow_download_script')):
|
|
scheduler.append('update_script', get_script)
|