mirror of
				https://github.com/yt-dlp/yt-dlp.git
				synced 2025-10-31 14:45:14 +00:00 
			
		
		
		
	[azubu] Remove extractor as the site is gone (closes #12813)
This commit is contained in:
		| @@ -1,6 +1,7 @@ | |||||||
| version <unreleased> | version <unreleased> | ||||||
|  |  | ||||||
| Extractors | Extractors | ||||||
|  | - [azubu] Remove extractor (#12813) | ||||||
| * [porn91] Fix extraction (#12814) | * [porn91] Fix extraction (#12814) | ||||||
| + [generic] Support Brightcove videos in <iframe> (#12482) | + [generic] Support Brightcove videos in <iframe> (#12482) | ||||||
| + [brightcove] Support URLs with bcpid instead of playerID (#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, |     AZMedienPlaylistIE, | ||||||
|     AZMedienShowPlaylistIE, |     AZMedienShowPlaylistIE, | ||||||
| ) | ) | ||||||
| from .azubu import AzubuIE, AzubuLiveIE |  | ||||||
| from .baidu import BaiduVideoIE | from .baidu import BaiduVideoIE | ||||||
| from .bambuser import BambuserIE, BambuserChannelIE | from .bambuser import BambuserIE, BambuserChannelIE | ||||||
| from .bandcamp import BandcampIE, BandcampAlbumIE | from .bandcamp import BandcampIE, BandcampAlbumIE | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Yen Chi Hsuan
					Yen Chi Hsuan