mirror of
https://github.com/NeteaseCloudMusicApiEnhanced/api-enhanced.git
synced 2026-02-04 12:53:10 +00:00
Compare commits
6 Commits
c649cd6da1
...
9f70e34356
| Author | SHA1 | Date | |
|---|---|---|---|
| 9f70e34356 | |||
| 584d4a4adc | |||
| 15808c482b | |||
| 5010a1f358 | |||
| ec2aa231c4 | |||
| 52eb1586c2 |
@ -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
|
||||||
## 启用无损音质时,是否选择音质最高的
|
## 启用无损音质时,是否选择音质最高的
|
||||||
|
|||||||
@ -9,11 +9,11 @@ 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'
|
||||||
if (result.data.url.includes('kuwo')) {
|
if (result.data.url && result.data.url.includes('kuwo')) {
|
||||||
result.proxyUrl =
|
result.proxyUrl =
|
||||||
useProxy === 'true' ? proxy + result.data.url : result.data.url
|
useProxy === 'true' ? proxy + result.data.url : result.data.url
|
||||||
}
|
}
|
||||||
@ -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) {
|
||||||
|
|||||||
@ -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: Customizing unblock sources is not supported on this endpoint. Please 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)
|
||||||
|
|||||||
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@neteasecloudmusicapienhanced/api",
|
"name": "@neteasecloudmusicapienhanced/api",
|
||||||
"version": "4.29.19",
|
"version": "4.29.20",
|
||||||
"description": "A revival project for NeteaseCloudMusicApi Node.js Services (Half Refactor & Enhanced)|| 网易云音乐 API 备份 + 增强 || 本项目自原版v4.28.0版本后开始自行维护",
|
"description": "A revival project for NeteaseCloudMusicApi Node.js Services (Half Refactor & Enhanced)|| 网易云音乐 API 备份 + 增强 || 本项目自原版v4.28.0版本后开始自行维护",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"dev": "nodemon app.js",
|
"dev": "nodemon app.js",
|
||||||
@ -66,8 +66,7 @@
|
|||||||
"data"
|
"data"
|
||||||
],
|
],
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@neteasecloudmusicapienhanced/unblockmusic-utils": "^0.1.1",
|
"@neteasecloudmusicapienhanced/unblockmusic-utils": "^0.1.2",
|
||||||
"@unblockneteasemusic/server": "^0.28.0",
|
|
||||||
"axios": "^1.13.2",
|
"axios": "^1.13.2",
|
||||||
"crypto-js": "^4.2.0",
|
"crypto-js": "^4.2.0",
|
||||||
"dotenv": "^17.2.3",
|
"dotenv": "^17.2.3",
|
||||||
|
|||||||
13
pnpm-lock.yaml
generated
13
pnpm-lock.yaml
generated
@ -9,11 +9,8 @@ importers:
|
|||||||
.:
|
.:
|
||||||
dependencies:
|
dependencies:
|
||||||
'@neteasecloudmusicapienhanced/unblockmusic-utils':
|
'@neteasecloudmusicapienhanced/unblockmusic-utils':
|
||||||
specifier: ^0.1.1
|
specifier: ^0.1.2
|
||||||
version: 0.1.1
|
version: 0.1.2
|
||||||
'@unblockneteasemusic/server':
|
|
||||||
specifier: ^0.28.0
|
|
||||||
version: 0.28.0
|
|
||||||
axios:
|
axios:
|
||||||
specifier: ^1.13.2
|
specifier: ^1.13.2
|
||||||
version: 1.13.2
|
version: 1.13.2
|
||||||
@ -228,8 +225,8 @@ packages:
|
|||||||
'@jridgewell/trace-mapping@0.3.31':
|
'@jridgewell/trace-mapping@0.3.31':
|
||||||
resolution: {integrity: sha512-zzNR+SdQSDJzc8joaeP8QQoCQr8NuYx2dIIytl1QeBEZHJ9uW6hebsrYgbz8hJwUQao3TWCMtmfV8Nu1twOLAw==}
|
resolution: {integrity: sha512-zzNR+SdQSDJzc8joaeP8QQoCQr8NuYx2dIIytl1QeBEZHJ9uW6hebsrYgbz8hJwUQao3TWCMtmfV8Nu1twOLAw==}
|
||||||
|
|
||||||
'@neteasecloudmusicapienhanced/unblockmusic-utils@0.1.1':
|
'@neteasecloudmusicapienhanced/unblockmusic-utils@0.1.2':
|
||||||
resolution: {integrity: sha512-CihuY2gOVTnBY1wkHZBAEW2SCUHPo16KrNuxl1O8ESFdn+1TJRzlEjaPKFrG2yrwrEbzj0SV/na8tvNVyPqz1g==}
|
resolution: {integrity: sha512-yhzMU+AaNI3QBm4KnKSJ2k0qy9oDKE0SjEfEHiGYNC0eTnAvCYvk+dZ1AuLzpm6b8yVLzK+oo+RvQwOd/zo5JQ==}
|
||||||
hasBin: true
|
hasBin: true
|
||||||
|
|
||||||
'@nodelib/fs.scandir@2.1.5':
|
'@nodelib/fs.scandir@2.1.5':
|
||||||
@ -2757,7 +2754,7 @@ snapshots:
|
|||||||
'@jridgewell/resolve-uri': 3.1.2
|
'@jridgewell/resolve-uri': 3.1.2
|
||||||
'@jridgewell/sourcemap-codec': 1.5.5
|
'@jridgewell/sourcemap-codec': 1.5.5
|
||||||
|
|
||||||
'@neteasecloudmusicapienhanced/unblockmusic-utils@0.1.1':
|
'@neteasecloudmusicapienhanced/unblockmusic-utils@0.1.2':
|
||||||
dependencies:
|
dependencies:
|
||||||
'@unblockneteasemusic/server': 0.28.0
|
'@unblockneteasemusic/server': 0.28.0
|
||||||
axios: 1.13.2
|
axios: 1.13.2
|
||||||
|
|||||||
13
server.js
13
server.js
@ -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)
|
||||||
}
|
}
|
||||||
|
|||||||
@ -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"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user