mirror of
				https://github.com/ytdl-org/youtube-dl.git
				synced 2025-10-29 09:26:20 -07:00 
			
		
		
		
	Compare commits
	
		
			10 Commits
		
	
	
		
			2014.02.22
			...
			2014.02.22
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 2fcc873c4c | ||
|  | 23c2baadb3 | ||
|  | 521ee82334 | ||
|  | 1df96e59ce | ||
|  | 3e123c1e28 | ||
|  | f38da66731 | ||
|  | 06aabfc422 | ||
|  | 1052d2bfec | ||
|  | 7928024f57 | ||
|  | 3eb38acb43 | 
| @@ -46,6 +46,7 @@ __authors__  = ( | ||||
|     'Andreas Schmitz', | ||||
|     'Michael Kaiser', | ||||
|     'Niklas Laxström', | ||||
|     'David Triendl', | ||||
| ) | ||||
|  | ||||
| __license__ = 'Public Domain' | ||||
|   | ||||
| @@ -12,7 +12,6 @@ from .http import HttpFD | ||||
| from ..utils import ( | ||||
|     struct_pack, | ||||
|     struct_unpack, | ||||
|     compat_urllib_request, | ||||
|     compat_urlparse, | ||||
|     format_bytes, | ||||
|     encodeFilename, | ||||
| @@ -117,8 +116,8 @@ class FlvReader(io.BytesIO): | ||||
|         self.read_unsigned_char() | ||||
|         # flags | ||||
|         self.read(3) | ||||
|         # BootstrapinfoVersion | ||||
|         bootstrap_info_version = self.read_unsigned_int() | ||||
|  | ||||
|         self.read_unsigned_int()  # BootstrapinfoVersion | ||||
|         # Profile,Live,Update,Reserved | ||||
|         self.read(1) | ||||
|         # time scale | ||||
| @@ -127,15 +126,15 @@ class FlvReader(io.BytesIO): | ||||
|         self.read_unsigned_long_long() | ||||
|         # SmpteTimeCodeOffset | ||||
|         self.read_unsigned_long_long() | ||||
|         # MovieIdentifier | ||||
|         movie_identifier = self.read_string() | ||||
|  | ||||
|         self.read_string()  # MovieIdentifier | ||||
|         server_count = self.read_unsigned_char() | ||||
|         # ServerEntryTable | ||||
|         for i in range(server_count): | ||||
|             self.read_string() | ||||
|         quality_count = self.read_unsigned_char() | ||||
|         # QualityEntryTable | ||||
|         for i in range(server_count): | ||||
|         for i in range(quality_count): | ||||
|             self.read_string() | ||||
|         # DrmData | ||||
|         self.read_string() | ||||
|   | ||||
| @@ -19,6 +19,7 @@ from .bbccouk import BBCCoUkIE | ||||
| from .blinkx import BlinkxIE | ||||
| from .bliptv import BlipTVIE, BlipTVUserIE | ||||
| from .bloomberg import BloombergIE | ||||
| from .br import BRIE | ||||
| from .breakcom import BreakIE | ||||
| from .brightcove import BrightcoveIE | ||||
| from .c56 import C56IE | ||||
| @@ -240,6 +241,7 @@ from .vesti import VestiIE | ||||
| from .vevo import VevoIE | ||||
| from .vice import ViceIE | ||||
| from .viddler import ViddlerIE | ||||
| from .videobam import VideoBamIE | ||||
| from .videodetective import VideoDetectiveIE | ||||
| from .videofyme import VideofyMeIE | ||||
| from .videopremium import VideoPremiumIE | ||||
|   | ||||
							
								
								
									
										80
									
								
								youtube_dl/extractor/br.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										80
									
								
								youtube_dl/extractor/br.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,80 @@ | ||||
| # coding: utf-8 | ||||
| from __future__ import unicode_literals | ||||
|  | ||||
| import re | ||||
|  | ||||
| from .common import InfoExtractor | ||||
| from ..utils import ExtractorError | ||||
|  | ||||
|  | ||||
| class BRIE(InfoExtractor): | ||||
|     IE_DESC = "Bayerischer Rundfunk Mediathek" | ||||
|     _VALID_URL = r"^https?://(?:www\.)?br\.de/mediathek/video/(?:sendungen/)?(?P<id>[a-z0-9\-]+)\.html$" | ||||
|     _BASE_URL = "http://www.br.de" | ||||
|  | ||||
|     _TEST = { | ||||
|         "url": "http://www.br.de/mediathek/video/anselm-gruen-114.html", | ||||
|         "md5": "c4f83cf0f023ba5875aba0bf46860df2", | ||||
|         "info_dict": { | ||||
|             "id": "2c8d81c5-6fb7-4a74-88d4-e768e5856532", | ||||
|             "ext": "mp4", | ||||
|             "title": "Feiern und Verzichten", | ||||
|             "description": "Anselm Grün: Feiern und Verzichten", | ||||
|             "uploader": "BR/Birgit Baier", | ||||
|             "upload_date": "20140301" | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     def _real_extract(self, url): | ||||
|         mobj = re.match(self._VALID_URL, url) | ||||
|         display_id = mobj.group('id') | ||||
|         page = self._download_webpage(url, display_id) | ||||
|         xml_url = self._search_regex( | ||||
|             r"return BRavFramework\.register\(BRavFramework\('avPlayer_(?:[a-f0-9-]{36})'\)\.setup\({dataURL:'(/mediathek/video/[a-z0-9/~_.-]+)'}\)\);", page, "XMLURL") | ||||
|         xml = self._download_xml(self._BASE_URL + xml_url, None) | ||||
|  | ||||
|         videos = [{ | ||||
|             "id": xml_video.get("externalId"), | ||||
|             "title": xml_video.find("title").text, | ||||
|             "formats": self._extract_formats(xml_video.find("assets")), | ||||
|             "thumbnails": self._extract_thumbnails(xml_video.find("teaserImage/variants")), | ||||
|             "description": " ".join(xml_video.find("shareTitle").text.splitlines()), | ||||
|             "uploader": xml_video.find("author").text, | ||||
|             "upload_date": "".join(reversed(xml_video.find("broadcastDate").text.split("."))), | ||||
|             "webpage_url": xml_video.find("permalink").text, | ||||
|         } for xml_video in xml.findall("video")] | ||||
|  | ||||
|         if len(videos) > 1: | ||||
|             self._downloader.report_warning( | ||||
|                 'found multiple videos; please ' | ||||
|                 'report this with the video URL to http://yt-dl.org/bug') | ||||
|         if not videos: | ||||
|             raise ExtractorError('No video entries found') | ||||
|         return videos[0] | ||||
|  | ||||
|     def _extract_formats(self, assets): | ||||
|         formats = [{ | ||||
|             "url": asset.find("downloadUrl").text, | ||||
|             "ext": asset.find("mediaType").text, | ||||
|             "format_id": asset.get("type"), | ||||
|             "width": int(asset.find("frameWidth").text), | ||||
|             "height": int(asset.find("frameHeight").text), | ||||
|             "tbr": int(asset.find("bitrateVideo").text), | ||||
|             "abr": int(asset.find("bitrateAudio").text), | ||||
|             "vcodec": asset.find("codecVideo").text, | ||||
|             "container": asset.find("mediaType").text, | ||||
|             "filesize": int(asset.find("size").text), | ||||
|         } for asset in assets.findall("asset") | ||||
|             if asset.find("downloadUrl") is not None] | ||||
|  | ||||
|         self._sort_formats(formats) | ||||
|         return formats | ||||
|  | ||||
|     def _extract_thumbnails(self, variants): | ||||
|         thumbnails = [{ | ||||
|             "url": self._BASE_URL + variant.find("url").text, | ||||
|             "width": int(variant.find("width").text), | ||||
|             "height": int(variant.find("height").text), | ||||
|         } for variant in variants.findall("variant")] | ||||
|         thumbnails.sort(key=lambda x: x["width"] * x["height"], reverse=True) | ||||
|         return thumbnails | ||||
| @@ -3,9 +3,6 @@ from __future__ import unicode_literals | ||||
| import re | ||||
|  | ||||
| from .common import InfoExtractor | ||||
| from ..utils import ( | ||||
|     ExtractorError, | ||||
| ) | ||||
|  | ||||
|  | ||||
| class TruTubeIE(InfoExtractor): | ||||
|   | ||||
							
								
								
									
										80
									
								
								youtube_dl/extractor/videobam.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										80
									
								
								youtube_dl/extractor/videobam.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,80 @@ | ||||
| from __future__ import unicode_literals | ||||
|  | ||||
| import re | ||||
| import json | ||||
|  | ||||
| from .common import InfoExtractor | ||||
| from ..utils import int_or_none | ||||
|  | ||||
|  | ||||
| class VideoBamIE(InfoExtractor): | ||||
|     _VALID_URL = r'http://(?:www\.)?videobam\.com/(?:videos/download/)?(?P<id>[a-zA-Z]+)' | ||||
|  | ||||
|     _TESTS = [ | ||||
|         { | ||||
|             'url': 'http://videobam.com/OiJQM', | ||||
|             'md5': 'db471f27763a531f10416a0c58b5a1e0', | ||||
|             'info_dict': { | ||||
|                 'id': 'OiJQM', | ||||
|                 'ext': 'mp4', | ||||
|                 'title': 'Is Alcohol Worse Than Ecstasy?', | ||||
|                 'description': 'md5:d25b96151515c91debc42bfbb3eb2683', | ||||
|                 'uploader': 'frihetsvinge', | ||||
|             }, | ||||
|         }, | ||||
|         { | ||||
|             'url': 'http://videobam.com/pqLvq', | ||||
|             'md5': 'd9a565b5379a99126ef94e1d7f9a383e', | ||||
|             'note': 'HD video', | ||||
|             'info_dict': { | ||||
|                 'id': 'pqLvq', | ||||
|                 'ext': 'mp4', | ||||
|             } | ||||
|         }, | ||||
|     ] | ||||
|  | ||||
|     def _real_extract(self, url): | ||||
|         mobj = re.match(self._VALID_URL, url) | ||||
|         video_id = mobj.group('id') | ||||
|  | ||||
|         page = self._download_webpage('http://videobam.com/%s' % video_id, video_id, 'Downloading page') | ||||
|  | ||||
|         formats = [] | ||||
|  | ||||
|         for preference, format_id in enumerate(['low', 'high']): | ||||
|             mobj = re.search(r"%s: '(?P<url>[^']+)'" % format_id, page) | ||||
|             if not mobj: | ||||
|                 continue | ||||
|             formats.append({ | ||||
|                 'url': mobj.group('url'), | ||||
|                 'ext': 'mp4', | ||||
|                 'format_id': format_id, | ||||
|                 'preference': preference, | ||||
|             }) | ||||
|  | ||||
|         if not formats: | ||||
|             player_config = json.loads(self._html_search_regex(r'var player_config = ({.+?});', page, 'player config')) | ||||
|             formats = [{ | ||||
|                 'url': item['url'], | ||||
|                 'ext': 'mp4', | ||||
|             } for item in player_config['playlist'] if 'autoPlay' in item] | ||||
|  | ||||
|         self._sort_formats(formats) | ||||
|  | ||||
|         title = self._og_search_title(page, default='VideoBam', fatal=False) | ||||
|         description = self._og_search_description(page, default=None) | ||||
|         thumbnail = self._og_search_thumbnail(page) | ||||
|         uploader = self._html_search_regex(r'Upload by ([^<]+)</a>', page, 'uploader', fatal=False, default=None) | ||||
|         view_count = int_or_none( | ||||
|             self._html_search_regex(r'<strong>Views:</strong> (\d+) ', page, 'view count', fatal=False)) | ||||
|  | ||||
|         return { | ||||
|             'id': video_id, | ||||
|             'title': title, | ||||
|             'description': description, | ||||
|             'thumbnail': thumbnail, | ||||
|             'uploader': uploader, | ||||
|             'view_count': view_count, | ||||
|             'formats': formats, | ||||
|             'age_limit': 18, | ||||
|         } | ||||
| @@ -29,7 +29,6 @@ from ..utils import ( | ||||
|     ExtractorError, | ||||
|     int_or_none, | ||||
|     PagedList, | ||||
|     RegexNotFoundError, | ||||
|     unescapeHTML, | ||||
|     unified_strdate, | ||||
|     orderedSet, | ||||
|   | ||||
| @@ -1,2 +1,2 @@ | ||||
|  | ||||
| __version__ = '2014.02.22' | ||||
| __version__ = '2014.02.22.1' | ||||
|   | ||||
		Reference in New Issue
	
	Block a user