mirror of
https://github.com/yt-dlp/yt-dlp
synced 2024-12-30 22:24:28 +01:00
33 lines
1.2 KiB
Python
33 lines
1.2 KiB
Python
|
from .common import InfoExtractor
|
||
|
from ..utils import js_to_json, traverse_obj
|
||
|
|
||
|
|
||
|
class MonsterSirenHypergryphMusicIE(InfoExtractor):
|
||
|
_VALID_URL = r'https?://monster-siren\.hypergryph\.com/music/(?P<id>\d+)'
|
||
|
_TESTS = [{
|
||
|
'url': 'https://monster-siren.hypergryph.com/music/514562',
|
||
|
'info_dict': {
|
||
|
'id': '514562',
|
||
|
'ext': 'wav',
|
||
|
'artist': ['塞壬唱片-MSR'],
|
||
|
'album': 'Flame Shadow',
|
||
|
'title': 'Flame Shadow',
|
||
|
}
|
||
|
}]
|
||
|
|
||
|
def _real_extract(self, url):
|
||
|
audio_id = self._match_id(url)
|
||
|
webpage = self._download_webpage(url, audio_id)
|
||
|
json_data = self._search_json(
|
||
|
r'window\.g_initialProps\s*=', webpage, 'data', audio_id, transform_source=js_to_json)
|
||
|
|
||
|
return {
|
||
|
'id': audio_id,
|
||
|
'title': traverse_obj(json_data, ('player', 'songDetail', 'name')),
|
||
|
'url': traverse_obj(json_data, ('player', 'songDetail', 'sourceUrl')),
|
||
|
'ext': 'wav',
|
||
|
'vcodec': 'none',
|
||
|
'artist': traverse_obj(json_data, ('player', 'songDetail', 'artists')),
|
||
|
'album': traverse_obj(json_data, ('musicPlay', 'albumDetail', 'name'))
|
||
|
}
|