|
|
@ -0,0 +1,100 @@ |
|
|
|
# coding: utf-8 |
|
|
|
from __future__ import unicode_literals |
|
|
|
|
|
|
|
import json |
|
|
|
import re |
|
|
|
|
|
|
|
from .common import InfoExtractor |
|
|
|
from ..utils import unified_strdate |
|
|
|
|
|
|
|
|
|
|
|
class TheSixtyOneIE(InfoExtractor): |
|
|
|
_VALID_URL = r'''(?x)https?://(?:www\.)?thesixtyone\.com/ |
|
|
|
(?:.*?/)* |
|
|
|
(?: |
|
|
|
s| |
|
|
|
song/comments/list| |
|
|
|
song |
|
|
|
)/(?P<id>[A-Za-z0-9]+)/?$''' |
|
|
|
_SONG_URL_TEMPLATE = 'http://thesixtyone.com/s/{0:}' |
|
|
|
_SONG_FILE_URL_TEMPLATE = 'http://{audio_server:}.thesixtyone.com/thesixtyone_production/audio/{0:}_stream' |
|
|
|
_THUMBNAIL_URL_TEMPLATE = '{photo_base_url:}_desktop' |
|
|
|
_TESTS = [ |
|
|
|
{ |
|
|
|
'url': 'http://www.thesixtyone.com/s/SrE3zD7s1jt/', |
|
|
|
'md5': '821cc43b0530d3222e3e2b70bb4622ea', |
|
|
|
'info_dict': { |
|
|
|
'id': 'SrE3zD7s1jt', |
|
|
|
'ext': 'mp3', |
|
|
|
'title': 'CASIO - Unicorn War Mixtape', |
|
|
|
'thumbnail': 're:^https?://.*_desktop$', |
|
|
|
'upload_date': '20071217', |
|
|
|
'duration': 3208, |
|
|
|
} |
|
|
|
}, |
|
|
|
{ |
|
|
|
'url': 'http://www.thesixtyone.com/song/comments/list/SrE3zD7s1jt', |
|
|
|
'only_matching': True, |
|
|
|
}, |
|
|
|
{ |
|
|
|
'url': 'http://www.thesixtyone.com/s/ULoiyjuJWli#/s/SrE3zD7s1jt/', |
|
|
|
'only_matching': True, |
|
|
|
}, |
|
|
|
{ |
|
|
|
'url': 'http://www.thesixtyone.com/#/s/SrE3zD7s1jt/', |
|
|
|
'only_matching': True, |
|
|
|
}, |
|
|
|
{ |
|
|
|
'url': 'http://www.thesixtyone.com/song/SrE3zD7s1jt/', |
|
|
|
'only_matching': True, |
|
|
|
}, |
|
|
|
] |
|
|
|
|
|
|
|
_DECODE_MAP = { |
|
|
|
"x": "a", |
|
|
|
"m": "b", |
|
|
|
"w": "c", |
|
|
|
"q": "d", |
|
|
|
"n": "e", |
|
|
|
"p": "f", |
|
|
|
"a": "0", |
|
|
|
"h": "1", |
|
|
|
"e": "2", |
|
|
|
"u": "3", |
|
|
|
"s": "4", |
|
|
|
"i": "5", |
|
|
|
"o": "6", |
|
|
|
"y": "7", |
|
|
|
"r": "8", |
|
|
|
"c": "9" |
|
|
|
} |
|
|
|
|
|
|
|
def _real_extract(self, url): |
|
|
|
mobj = re.match(self._VALID_URL, url) |
|
|
|
song_id = mobj.group('id') |
|
|
|
|
|
|
|
webpage = self._download_webpage( |
|
|
|
self._SONG_URL_TEMPLATE.format(song_id), song_id) |
|
|
|
|
|
|
|
song_data = json.loads(self._search_regex( |
|
|
|
r'"%s":\s(\{.*?\})' % song_id, webpage, 'song_data')) |
|
|
|
keys = [self._DECODE_MAP.get(s, s) for s in song_data['key']] |
|
|
|
url = self._SONG_FILE_URL_TEMPLATE.format( |
|
|
|
"".join(reversed(keys)), **song_data) |
|
|
|
|
|
|
|
formats = [{ |
|
|
|
'format_id': 'sd', |
|
|
|
'url': url, |
|
|
|
'ext': 'mp3', |
|
|
|
}] |
|
|
|
|
|
|
|
return { |
|
|
|
'id': song_id, |
|
|
|
'title': '{artist:} - {name:}'.format(**song_data), |
|
|
|
'formats': formats, |
|
|
|
'comment_count': song_data.get('comments_count'), |
|
|
|
'duration': song_data.get('play_time'), |
|
|
|
'like_count': song_data.get('score'), |
|
|
|
'thumbnail': self._THUMBNAIL_URL_TEMPLATE.format(**song_data), |
|
|
|
'upload_date': unified_strdate(song_data.get('publish_date')), |
|
|
|
} |