X-Git-Url: http://git.bitcoin.ninja/index.cgi?a=blobdiff_plain;f=youtube_dl%2Fextractor%2Fmelonvod.py;h=bd8cf13ab44048257ef52e5f81268ed7cfd5d6d3;hb=dbeafce5d58b0d40b7af35e5276f77855ced81a4;hp=9b00ce8e32391798082005f0854c08e0fd01f09f;hpb=abf3494ac7b78498d8f95c92548e857b7673c7de;p=youtube-dl diff --git a/youtube_dl/extractor/melonvod.py b/youtube_dl/extractor/melonvod.py index 9b00ce8e3..bd8cf13ab 100644 --- a/youtube_dl/extractor/melonvod.py +++ b/youtube_dl/extractor/melonvod.py @@ -2,19 +2,21 @@ from __future__ import unicode_literals from .common import InfoExtractor -from ..utils import int_or_none +from ..utils import ( + int_or_none, + urljoin, +) class MelonVODIE(InfoExtractor): - _VALID_URL = r'https?://vod\.melon\.com/video/detail2\.html?.*mvId=(?P[0-9]+)' + _VALID_URL = r'https?://vod\.melon\.com/video/detail2\.html?\?.*?mvId=(?P[0-9]+)' _TEST = { 'url': 'http://vod.melon.com/video/detail2.htm?mvId=50158734', - 'md5': '461fc04c6d23cbf49f4fef4d61851d32', 'info_dict': { 'id': '50158734', 'ext': 'mp4', - 'title': 'Jessica \'Wonderland\' MV Making Film', - 'thumbnail': 're:^https?://.*\.jpg$', + 'title': "Jessica 'Wonderland' MV Making Film", + 'thumbnail': r're:^https?://.*\.jpg$', 'artist': 'Jessica (제시카)', 'upload_date': '20161212', 'duration': 203, @@ -29,24 +31,35 @@ class MelonVODIE(InfoExtractor): play_info = self._download_json( 'http://vod.melon.com/video/playerInfo.json', video_id, - note='Downloading playerInfo', query={'mvId': video_id} - ) + note='Downloading player info JSON', query={'mvId': video_id}) + title = play_info['mvInfo']['MVTITLE'] - artist = ', '.join([artist['ARTISTNAMEWEBLIST'] for artist in play_info.get('artistList', [])]) info = self._download_json( 'http://vod.melon.com/delivery/streamingInfo.json', video_id, - note='Downloading streamingInfo', - query={'contsId': video_id, 'contsType': 'VIDEO'} - ) - stream_info = info.get('streamingInfo', {}) - m3u8_url = stream_info.get('encUrl') - formats = self._extract_m3u8_formats(m3u8_url, video_id, 'mp4', m3u8_id='hls') + note='Downloading streaming info JSON', + query={ + 'contsId': video_id, + 'contsType': 'VIDEO', + }) + + stream_info = info['streamingInfo'] + + formats = self._extract_m3u8_formats( + stream_info['encUrl'], video_id, 'mp4', m3u8_id='hls') self._sort_formats(formats) - thumbnail = info.get('staticDomain', '') + stream_info.get('imgPath', '') + artist_list = play_info.get('artistList') + artist = None + if isinstance(artist_list, list): + artist = ', '.join( + [a['ARTISTNAMEWEBLIST'] + for a in artist_list if a.get('ARTISTNAMEWEBLIST')]) + + thumbnail = urljoin(info.get('staticDomain'), stream_info.get('imgPath')) + duration = int_or_none(stream_info.get('playTime')) - upload_date = stream_info.get('mvSvcOpenDt', '')[:8] + upload_date = stream_info.get('mvSvcOpenDt', '')[:8] or None return { 'id': video_id,