mirror of
https://github.com/NeteaseCloudMusicApiEnhanced/api-enhanced.git
synced 2026-03-21 11:03:15 +00:00
feat: add song download url api end point for 302
* This will redirect access from http://localhost:3000/song/url/v1?id=2756058128&level=exhigh to actual resource url
This commit is contained in:
parent
b027aca40a
commit
59241631db
53
module/song_download_url_v1_302.js
Normal file
53
module/song_download_url_v1_302.js
Normal file
@ -0,0 +1,53 @@
|
||||
// 获取客户端歌曲下载链接 - v1
|
||||
// 此版本不再采用 br 作为音质区分的标准
|
||||
// 而是采用 standard, exhigh, lossless, hires, jyeffect(高清环绕声), sky(沉浸环绕声), jymaster(超清母带) 进行音质判断
|
||||
|
||||
const createOption = require('../util/option.js')
|
||||
module.exports = async (query, request) => {
|
||||
const data = {
|
||||
id: query.id,
|
||||
immerseType: 'c51',
|
||||
level: query.level,
|
||||
}
|
||||
const response = await request(
|
||||
`/api/song/enhance/download/url/v1`,
|
||||
data,
|
||||
createOption(query),
|
||||
)
|
||||
let url = response?.body?.data?.[0]?.url
|
||||
|
||||
if (!url) {
|
||||
const fallbackData = {
|
||||
ids: `[${query.id}]`,
|
||||
level: query.level,
|
||||
encodeType: 'flac',
|
||||
}
|
||||
if (query.level === 'sky') {
|
||||
fallbackData.immerseType = 'c51'
|
||||
}
|
||||
const fallback = await request(
|
||||
`/api/song/enhance/player/url/v1`,
|
||||
fallbackData,
|
||||
createOption(query),
|
||||
)
|
||||
url = fallback?.body?.data?.[0]?.url
|
||||
|
||||
if (!url) {
|
||||
return fallback
|
||||
}
|
||||
|
||||
return {
|
||||
status: 302,
|
||||
body: '',
|
||||
cookie: fallback.cookie || [],
|
||||
redirectUrl: url,
|
||||
}
|
||||
}
|
||||
|
||||
return {
|
||||
status: 302,
|
||||
body: '',
|
||||
cookie: response.cookie || [],
|
||||
redirectUrl: url,
|
||||
}
|
||||
}
|
||||
@ -210,6 +210,7 @@ async function consturctServer(moduleDefs) {
|
||||
'daily_signin.js': '/daily_signin',
|
||||
'fm_trash.js': '/fm_trash',
|
||||
'personal_fm.js': '/personal_fm',
|
||||
'song_download_url_v1_302.js': '/song/url/v1/302',
|
||||
}
|
||||
|
||||
/**
|
||||
@ -221,7 +222,7 @@ async function consturctServer(moduleDefs) {
|
||||
|
||||
for (const moduleDef of moduleDefinitions) {
|
||||
// Register the route.
|
||||
app.use(moduleDef.route, async (req, res) => {
|
||||
app.all(moduleDef.route, async (req, res) => {
|
||||
;[req.query, req.body].forEach((item) => {
|
||||
// item may be undefined (some environments / middlewares).
|
||||
// Guard access to avoid "Cannot read properties of undefined (reading 'cookie')".
|
||||
@ -307,6 +308,11 @@ async function consturctServer(moduleDefs) {
|
||||
}
|
||||
}
|
||||
}
|
||||
if (moduleResponse.redirectUrl) {
|
||||
res.redirect(moduleResponse.status || 302, moduleResponse.redirectUrl)
|
||||
return
|
||||
}
|
||||
|
||||
res.status(moduleResponse.status).send(moduleResponse.body)
|
||||
} catch (/** @type {*} */ moduleResponse) {
|
||||
logger.error(`${decode(req.originalUrl)}`, {
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user