mirror of
				https://gitlab.com/ytdl-org/youtube-dl.git
				synced 2025-11-04 04:57:07 -05:00 
			
		
		
		
	[azubu] Remove extractor as the site is gone (closes #12813)
This commit is contained in:
		@@ -1,6 +1,7 @@
 | 
			
		||||
version <unreleased>
 | 
			
		||||
 | 
			
		||||
Extractors
 | 
			
		||||
- [azubu] Remove extractor (#12813)
 | 
			
		||||
* [porn91] Fix extraction (#12814)
 | 
			
		||||
+ [generic] Support Brightcove videos in <iframe> (#12482)
 | 
			
		||||
+ [brightcove] Support URLs with bcpid instead of playerID (#12482)
 | 
			
		||||
 
 | 
			
		||||
@@ -1,140 +0,0 @@
 | 
			
		||||
from __future__ import unicode_literals
 | 
			
		||||
 | 
			
		||||
import json
 | 
			
		||||
 | 
			
		||||
from .common import InfoExtractor
 | 
			
		||||
from ..utils import (
 | 
			
		||||
    ExtractorError,
 | 
			
		||||
    float_or_none,
 | 
			
		||||
    sanitized_Request,
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class AzubuIE(InfoExtractor):
 | 
			
		||||
    _VALID_URL = r'https?://(?:www\.)?azubu\.(?:tv|uol.com.br)/[^/]+#!/play/(?P<id>\d+)'
 | 
			
		||||
    _TESTS = [
 | 
			
		||||
        {
 | 
			
		||||
            'url': 'http://www.azubu.tv/GSL#!/play/15575/2014-hot6-cup-last-big-match-ro8-day-1',
 | 
			
		||||
            'md5': 'a88b42fcf844f29ad6035054bd9ecaf4',
 | 
			
		||||
            'info_dict': {
 | 
			
		||||
                'id': '15575',
 | 
			
		||||
                'ext': 'mp4',
 | 
			
		||||
                'title': '2014 HOT6 CUP LAST BIG MATCH Ro8 Day 1',
 | 
			
		||||
                'description': 'md5:d06bdea27b8cc4388a90ad35b5c66c01',
 | 
			
		||||
                'thumbnail': r're:^https?://.*\.jpe?g',
 | 
			
		||||
                'timestamp': 1417523507.334,
 | 
			
		||||
                'upload_date': '20141202',
 | 
			
		||||
                'duration': 9988.7,
 | 
			
		||||
                'uploader': 'GSL',
 | 
			
		||||
                'uploader_id': 414310,
 | 
			
		||||
                'view_count': int,
 | 
			
		||||
            },
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
            'url': 'http://www.azubu.tv/FnaticTV#!/play/9344/-fnatic-at-worlds-2014:-toyz---%22i-love-rekkles,-he-has-amazing-mechanics%22-',
 | 
			
		||||
            'md5': 'b72a871fe1d9f70bd7673769cdb3b925',
 | 
			
		||||
            'info_dict': {
 | 
			
		||||
                'id': '9344',
 | 
			
		||||
                'ext': 'mp4',
 | 
			
		||||
                'title': 'Fnatic at Worlds 2014: Toyz - "I love Rekkles, he has amazing mechanics"',
 | 
			
		||||
                'description': 'md5:4a649737b5f6c8b5c5be543e88dc62af',
 | 
			
		||||
                'thumbnail': r're:^https?://.*\.jpe?g',
 | 
			
		||||
                'timestamp': 1410530893.320,
 | 
			
		||||
                'upload_date': '20140912',
 | 
			
		||||
                'duration': 172.385,
 | 
			
		||||
                'uploader': 'FnaticTV',
 | 
			
		||||
                'uploader_id': 272749,
 | 
			
		||||
                'view_count': int,
 | 
			
		||||
            },
 | 
			
		||||
            'skip': 'Channel offline',
 | 
			
		||||
        },
 | 
			
		||||
    ]
 | 
			
		||||
 | 
			
		||||
    def _real_extract(self, url):
 | 
			
		||||
        video_id = self._match_id(url)
 | 
			
		||||
 | 
			
		||||
        data = self._download_json(
 | 
			
		||||
            'http://www.azubu.tv/api/video/%s' % video_id, video_id)['data']
 | 
			
		||||
 | 
			
		||||
        title = data['title'].strip()
 | 
			
		||||
        description = data.get('description')
 | 
			
		||||
        thumbnail = data.get('thumbnail')
 | 
			
		||||
        view_count = data.get('view_count')
 | 
			
		||||
        user = data.get('user', {})
 | 
			
		||||
        uploader = user.get('username')
 | 
			
		||||
        uploader_id = user.get('id')
 | 
			
		||||
 | 
			
		||||
        stream_params = json.loads(data['stream_params'])
 | 
			
		||||
 | 
			
		||||
        timestamp = float_or_none(stream_params.get('creationDate'), 1000)
 | 
			
		||||
        duration = float_or_none(stream_params.get('length'), 1000)
 | 
			
		||||
 | 
			
		||||
        renditions = stream_params.get('renditions') or []
 | 
			
		||||
        video = stream_params.get('FLVFullLength') or stream_params.get('videoFullLength')
 | 
			
		||||
        if video:
 | 
			
		||||
            renditions.append(video)
 | 
			
		||||
 | 
			
		||||
        if not renditions and not user.get('channel', {}).get('is_live', True):
 | 
			
		||||
            raise ExtractorError('%s said: channel is offline.' % self.IE_NAME, expected=True)
 | 
			
		||||
 | 
			
		||||
        formats = [{
 | 
			
		||||
            'url': fmt['url'],
 | 
			
		||||
            'width': fmt['frameWidth'],
 | 
			
		||||
            'height': fmt['frameHeight'],
 | 
			
		||||
            'vbr': float_or_none(fmt['encodingRate'], 1000),
 | 
			
		||||
            'filesize': fmt['size'],
 | 
			
		||||
            'vcodec': fmt['videoCodec'],
 | 
			
		||||
            'container': fmt['videoContainer'],
 | 
			
		||||
        } for fmt in renditions if fmt['url']]
 | 
			
		||||
        self._sort_formats(formats)
 | 
			
		||||
 | 
			
		||||
        return {
 | 
			
		||||
            'id': video_id,
 | 
			
		||||
            'title': title,
 | 
			
		||||
            'description': description,
 | 
			
		||||
            'thumbnail': thumbnail,
 | 
			
		||||
            'timestamp': timestamp,
 | 
			
		||||
            'duration': duration,
 | 
			
		||||
            'uploader': uploader,
 | 
			
		||||
            'uploader_id': uploader_id,
 | 
			
		||||
            'view_count': view_count,
 | 
			
		||||
            'formats': formats,
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class AzubuLiveIE(InfoExtractor):
 | 
			
		||||
    _VALID_URL = r'https?://(?:www\.)?azubu\.(?:tv|uol.com.br)/(?P<id>[^/]+)$'
 | 
			
		||||
 | 
			
		||||
    _TESTS = [{
 | 
			
		||||
        'url': 'http://www.azubu.tv/MarsTVMDLen',
 | 
			
		||||
        'only_matching': True,
 | 
			
		||||
    }, {
 | 
			
		||||
        'url': 'http://azubu.uol.com.br/adolfz',
 | 
			
		||||
        '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')
 | 
			
		||||
        self._sort_formats(formats)
 | 
			
		||||
 | 
			
		||||
        return {
 | 
			
		||||
            'id': info['id'],
 | 
			
		||||
            'title': self._live_title(info['title']),
 | 
			
		||||
            'uploader_id': user,
 | 
			
		||||
            'formats': formats,
 | 
			
		||||
            'is_live': True,
 | 
			
		||||
            'thumbnail': bc_info['poster'],
 | 
			
		||||
        }
 | 
			
		||||
@@ -87,7 +87,6 @@ from .azmedien import (
 | 
			
		||||
    AZMedienPlaylistIE,
 | 
			
		||||
    AZMedienShowPlaylistIE,
 | 
			
		||||
)
 | 
			
		||||
from .azubu import AzubuIE, AzubuLiveIE
 | 
			
		||||
from .baidu import BaiduVideoIE
 | 
			
		||||
from .bambuser import BambuserIE, BambuserChannelIE
 | 
			
		||||
from .bandcamp import BandcampIE, BandcampAlbumIE
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user