mirror of
https://github.com/NeteaseCloudMusicApiEnhanced/api-enhanced.git
synced 2026-03-21 19:13:10 +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',
|
'daily_signin.js': '/daily_signin',
|
||||||
'fm_trash.js': '/fm_trash',
|
'fm_trash.js': '/fm_trash',
|
||||||
'personal_fm.js': '/personal_fm',
|
'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) {
|
for (const moduleDef of moduleDefinitions) {
|
||||||
// Register the route.
|
// Register the route.
|
||||||
app.use(moduleDef.route, async (req, res) => {
|
app.all(moduleDef.route, async (req, res) => {
|
||||||
;[req.query, req.body].forEach((item) => {
|
;[req.query, req.body].forEach((item) => {
|
||||||
// item may be undefined (some environments / middlewares).
|
// item may be undefined (some environments / middlewares).
|
||||||
// Guard access to avoid "Cannot read properties of undefined (reading 'cookie')".
|
// 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)
|
res.status(moduleResponse.status).send(moduleResponse.body)
|
||||||
} catch (/** @type {*} */ moduleResponse) {
|
} catch (/** @type {*} */ moduleResponse) {
|
||||||
logger.error(`${decode(req.originalUrl)}`, {
|
logger.error(`${decode(req.originalUrl)}`, {
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user