Compare commits

...

5 Commits

Author SHA1 Message Date
Xingchen Song(宋星辰) c0c9686b66
Merge e9f033fbfc into 46f4c80bc3 2024-09-07 12:37:22 -04:00
sepro 46f4c80bc3
[ie/SampleFocus] Fix extractor (#10947)
Closes #10945
Authored by: seproDev
2024-09-07 17:06:12 +02:00
xingchensong e9f033fbfc [ximalaya.com] Add VIP support, refine code 2024-09-02 14:27:36 +08:00
xingchensong db245d0376 [ximalaya.com] Add VIP support, try to pass ut 2024-08-23 14:03:19 +08:00
xingchensong ed0433a69f [ximalaya.com] Add VIP support 2024-08-23 13:47:27 +08:00
2 changed files with 60 additions and 2 deletions

View File

@ -36,7 +36,7 @@ class SampleFocusIE(InfoExtractor):
def _real_extract(self, url):
display_id = self._match_id(url)
webpage = self._download_webpage(url, display_id)
webpage = self._download_webpage(url, display_id, impersonate=True)
sample_id = self._search_regex(
r'<input[^>]+id=(["\'])sample_id\1[^>]+value=(?:["\'])(?P<id>\d+)',
@ -82,7 +82,15 @@ class SampleFocusIE(InfoExtractor):
return {
'id': sample_id,
'title': title,
'url': mp3_url,
'formats': [{
'url': mp3_url,
'ext': 'mp3',
'vcodec': 'none',
'acodec': 'mp3',
'http_headers': {
'Referer': url,
},
}],
'display_id': display_id,
'thumbnail': thumbnail,
'uploader': uploader,

View File

@ -1,6 +1,9 @@
import base64
import math
import time
from .common import InfoExtractor
from .videa import VideaIE
from ..utils import InAdvancePagedList, str_or_none, traverse_obj, try_call
@ -71,8 +74,37 @@ class XimalayaIE(XimalayaBaseIE):
'like_count': int,
},
},
{
# VIP-restricted audio
'url': 'https://www.ximalaya.com/sound/562111701',
'only_matching': True,
},
]
@staticmethod
def _decrypt_filename(audio_info):
seed = float(audio_info['seed'])
file_id = audio_info['fileId']
cgstr = ''
key = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ/\\:._-1234567890'
for _ in range(len(key)):
seed = float(int(211 * seed + 30031) % 65536)
r = int(seed / 65536 * len(key))
cgstr += key[r]
key = key.replace(key[r], '')
parts = file_id.split('*')
filename = ''.join(cgstr[int(part)] for part in parts if part.isdigit())
if not filename.startswith('/'):
filename = '/' + filename
return filename
@staticmethod
def _decrypt_url_params(audio_info):
params = VideaIE.rc4(base64.b64decode(audio_info['ep']),
'xkt3a41psizxrh9l').split('-')
sign, token, timestamp = params[1], params[2], params[3]
return sign, token, timestamp
def _real_extract(self, url):
scheme = 'https' if url.startswith('https') else 'http'
@ -82,6 +114,24 @@ class XimalayaIE(XimalayaBaseIE):
audio_info_file, audio_id,
f'Downloading info json {audio_info_file}', 'Unable to download info file')
# NOTE(xcsong): VIP-restricted audio
if audio_info.get('is_paid'):
ts = int(time.time())
audio_info_file = f'{scheme}://mpay.ximalaya.com/mobile/track/pay/{audio_id}/{ts}?device=pc&isBackend=true&_={ts}'
audio_info = self._download_json(
audio_info_file, audio_id,
f'Downloading VIP info json {audio_info_file}', 'Unable to download VIP info file')
filename = self._decrypt_filename(audio_info)
sign, token, timestamp = self._decrypt_url_params(audio_info)
buy_key = audio_info.get('buyKey')
duration = audio_info.get('duration')
domain = audio_info.get('domain')
api_version = audio_info.get('apiVersion')
args = f'?sign={sign}&buy_key={buy_key}&token={token}&timestamp={timestamp}&duration={duration}'
audio_info['play_path_64'] = f'{domain}/download/{api_version}{filename}{args}'
if '_preview_' in audio_info['play_path_64']:
self.report_warning('Please use correct cookies to download VIP audios!')
formats = [{
'format_id': f'{bps}k',
'url': audio_info[k],