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> | ||||
|  | ||||
| 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
	 Yen Chi Hsuan
					Yen Chi Hsuan