|
@@ -3,7 +3,11 @@ from __future__ import unicode_literals
|
|
|
import json
|
|
|
|
|
|
from .common import InfoExtractor
|
|
|
-from ..utils import float_or_none
|
|
|
+from ..utils import (
|
|
|
+ ExtractorError,
|
|
|
+ float_or_none,
|
|
|
+ sanitized_Request,
|
|
|
+)
|
|
|
|
|
|
|
|
|
class AzubuIE(InfoExtractor):
|
|
@@ -91,3 +95,37 @@ class AzubuIE(InfoExtractor):
|
|
|
'view_count': view_count,
|
|
|
'formats': formats,
|
|
|
}
|
|
|
+
|
|
|
+
|
|
|
+class AzubuLiveIE(InfoExtractor):
|
|
|
+ _VALID_URL = r'http://www.azubu.tv/(?P<id>[^/]+)$'
|
|
|
+
|
|
|
+ _TEST = {
|
|
|
+ 'url': 'http://www.azubu.tv/MarsTVMDLen',
|
|
|
+ 'only_matching': True,
|
|
|
+ }
|
|
|
+
|
|
|
+ def _real_extract(self, url):
|
|
|
+ user = self._match_id(url)
|
|
|
+
|
|
|
+ info = self._download_json(
|
|
|
+ 'http://api.azubu.tv/public/modules/last-video/{0}/info'.format(user),
|
|
|
+ user)['data']
|
|
|
+ if info['type'] != 'STREAM':
|
|
|
+ raise ExtractorError('{0} is not streaming live'.format(user), expected=True)
|
|
|
+
|
|
|
+ req = sanitized_Request(
|
|
|
+ 'https://edge-elb.api.brightcove.com/playback/v1/accounts/3361910549001/videos/ref:' + info['reference_id'])
|
|
|
+ req.add_header('Accept', 'application/json;pk=BCpkADawqM1gvI0oGWg8dxQHlgT8HkdE2LnAlWAZkOlznO39bSZX726u4JqnDsK3MDXcO01JxXK2tZtJbgQChxgaFzEVdHRjaDoxaOu8hHOO8NYhwdxw9BzvgkvLUlpbDNUuDoc4E4wxDToV')
|
|
|
+ bc_info = self._download_json(req, user)
|
|
|
+ m3u8_url = next(source['src'] for source in bc_info['sources'] if source['container'] == 'M2TS')
|
|
|
+ formats = self._extract_m3u8_formats(m3u8_url, user, ext='mp4')
|
|
|
+
|
|
|
+ return {
|
|
|
+ 'id': info['id'],
|
|
|
+ 'title': self._live_title(info['title']),
|
|
|
+ 'uploader_id': user,
|
|
|
+ 'formats': formats,
|
|
|
+ 'is_live': True,
|
|
|
+ 'thumbnail': bc_info['poster'],
|
|
|
+ }
|