refactor: update unblock settings and improve song URL matching logic

This commit is contained in:
ElyPrism 2025-12-21 12:00:50 +08:00
parent c649cd6da1
commit 52eb1586c2
No known key found for this signature in database
5 changed files with 40 additions and 50 deletions

View File

@ -10,8 +10,8 @@ PROXY_URL = "https://your-proxy-url.com/?proxy="
### UnblockNeteaseMusic 设置项 ### UnblockNeteaseMusic 设置项
## 启用全局解灰, 无论是否调用参数都会使用解灰(推荐开启) ## 启用全局解灰, 无论是否调用参数都会使用解灰(推荐开启)
ENABLE_GENERAL_UNBLOCK = true ENABLE_GENERAL_UNBLOCK = false
## 歌曲启用无损音质 ## 歌曲启用无损音质
ENABLE_FLAC = true ENABLE_FLAC = true
## 启用无损音质时,是否选择音质最高的 ## 启用无损音质时,是否选择音质最高的

View File

@ -9,7 +9,7 @@ module.exports = async (query, request) => {
const { const {
matchID, matchID,
} = require('@neteasecloudmusicapienhanced/unblockmusic-utils') } = require('@neteasecloudmusicapienhanced/unblockmusic-utils')
const result = await matchID(query.id) const result = await matchID(query.id, query.source)
const proxy = process.env.PROXY_URL const proxy = process.env.PROXY_URL
logger.info('开始解灰', query.id, result) logger.info('开始解灰', query.id, result)
const useProxy = process.env.ENABLE_PROXY || 'false' const useProxy = process.env.ENABLE_PROXY || 'false'
@ -22,6 +22,7 @@ module.exports = async (query, request) => {
body: { body: {
code: 200, code: 200,
data: result.data.url, data: result.data.url,
proxyUrl: result.proxyUrl || '',
}, },
} }
} catch (e) { } catch (e) {

View File

@ -6,8 +6,9 @@
const logger = require('../util/logger.js') const logger = require('../util/logger.js')
const createOption = require('../util/option.js') const createOption = require('../util/option.js')
module.exports = async (query, request) => { module.exports = async (query, request) => {
const match = require('@unblockneteasemusic/server') const {
const source = ['pyncmd', 'bodian', 'kuwo', 'qq', 'migu', 'kugou'] matchID,
} = require('@neteasecloudmusicapienhanced/unblockmusic-utils')
require('dotenv').config() require('dotenv').config()
const data = { const data = {
ids: '[' + query.id + ']', ids: '[' + query.id + ']',
@ -16,45 +17,34 @@ module.exports = async (query, request) => {
} }
if (query.unblock === 'true') { if (query.unblock === 'true') {
try { try {
const result = await match(query.id, source) const result = await matchID(query.id, query.source)
logger.info('Starting unblock(uses modules unblock):', query.id, result) logger.info('Starting unblock(uses modules unblock):', query.id, result)
// avoid optional chaining for compatibility const useProxy = process.env.ENABLE_PROXY || 'false'
let url
if (Array.isArray(result)) {
url = result[0] && result[0].url ? result[0].url : result[0]
} else {
url = result && result.url ? result.url : result
}
// decide proxyUrl after we resolved the actual url value
let proxyUrl = '' let proxyUrl = ''
if (url) { if (result.data.url && result.data.url.includes('kuwo')) {
if (url.includes('kuwo')) { proxyUrl =
const useProxy = process.env.ENABLE_PROXY || 'false' useProxy === 'true' && process.env.PROXY_URL
if (useProxy === 'true' && process.env.PROXY_URL) { ? process.env.PROXY_URL + result.data.url
proxyUrl = process.env.PROXY_URL + url : result.data.url
} else { }
proxyUrl = url return {
} status: 200,
} body: {
return { code: 200,
status: 200, msg: 'Warning: you can only adjust unblock source song_url_unblock interface, use /song/url/match instead.',
body: { data: [
code: 200, {
msg: 'Warning: you can only adjust unblock source in dotenv config, use /song/url/match instead.', id: Number(query.id),
data: [ url: result.data.url,
{ type: 'flac',
id: Number(query.id), level: query.level,
url, freeTrialInfo: 'null',
type: 'flac', fee: 0,
level: query.level, proxyUrl: proxyUrl || '',
freeTrialInfo: 'null', },
fee: 0, ],
proxyUrl: proxyUrl || '', },
}, cookie: [],
],
},
cookie: [],
}
} }
} catch (e) { } catch (e) {
console.error('Error in unblockneteasemusic:', e) console.error('Error in unblockneteasemusic:', e)

View File

@ -254,13 +254,12 @@ async function consturctServer(moduleDefs) {
!song.url || !song.url ||
[1, 4].includes(song.fee) [1, 4].includes(song.fee)
) { ) {
const match = require('@unblockneteasemusic/server') const {
const source = process.env.UNBLOCK_SOURCE matchID,
? process.env.UNBLOCK_SOURCE.split(',') } = require('@neteasecloudmusicapienhanced/unblockmusic-utils')
: ['pyncmd', 'bodian', 'kuwo', 'qq', 'migu', 'kugou'] logger.info('Starting unblock(uses general unblock):', req.query.id)
logger.info('Starting unblock(uses general unblock):', source) const result = await matchID(req.query.id)
const { url } = await match(req.query.id, source) song.url = result.data.url
song.url = url
song.freeTrialInfo = 'null' song.freeTrialInfo = 'null'
logger.info('Unblock success! url:', song.url) logger.info('Unblock success! url:', song.url)
} }

View File

@ -20,6 +20,6 @@
"env": { "env": {
"NODE_ENV": "production", "NODE_ENV": "production",
"ENABLE_FLAC": "true", "ENABLE_FLAC": "true",
"ENABLE_GENERAL_UNBLOCK": "true" "ENABLE_GENERAL_UNBLOCK": "false"
} }
} }