[uplynk] Add new extractor
This commit is contained in:
		| @@ -20,6 +20,7 @@ from ..utils import ( | |||||||
|     encodeFilename, |     encodeFilename, | ||||||
|     sanitize_open, |     sanitize_open, | ||||||
|     parse_m3u8_attributes, |     parse_m3u8_attributes, | ||||||
|  |     update_url_query, | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -82,6 +83,7 @@ class HlsFD(FragmentFD): | |||||||
|  |  | ||||||
|         self._prepare_and_start_frag_download(ctx) |         self._prepare_and_start_frag_download(ctx) | ||||||
|  |  | ||||||
|  |         extra_param_to_segment_url = info_dict.get('extra_param_to_segment_url') | ||||||
|         i = 0 |         i = 0 | ||||||
|         media_sequence = 0 |         media_sequence = 0 | ||||||
|         decrypt_info = {'METHOD': 'NONE'} |         decrypt_info = {'METHOD': 'NONE'} | ||||||
| @@ -95,6 +97,8 @@ class HlsFD(FragmentFD): | |||||||
|                         if re.match(r'^https?://', line) |                         if re.match(r'^https?://', line) | ||||||
|                         else compat_urlparse.urljoin(man_url, line)) |                         else compat_urlparse.urljoin(man_url, line)) | ||||||
|                     frag_filename = '%s-Frag%d' % (ctx['tmpfilename'], i) |                     frag_filename = '%s-Frag%d' % (ctx['tmpfilename'], i) | ||||||
|  |                     if extra_param_to_segment_url: | ||||||
|  |                         frag_url = update_url_query(frag_url, extra_param_to_segment_url) | ||||||
|                     success = ctx['dl'].download(frag_filename, {'url': frag_url}) |                     success = ctx['dl'].download(frag_filename, {'url': frag_url}) | ||||||
|                     if not success: |                     if not success: | ||||||
|                         return False |                         return False | ||||||
| @@ -120,6 +124,8 @@ class HlsFD(FragmentFD): | |||||||
|                         if not re.match(r'^https?://', decrypt_info['URI']): |                         if not re.match(r'^https?://', decrypt_info['URI']): | ||||||
|                             decrypt_info['URI'] = compat_urlparse.urljoin( |                             decrypt_info['URI'] = compat_urlparse.urljoin( | ||||||
|                                 man_url, decrypt_info['URI']) |                                 man_url, decrypt_info['URI']) | ||||||
|  |                         if extra_param_to_segment_url: | ||||||
|  |                             decrypt_info['URI'] = update_url_query(decrypt_info['URI'], extra_param_to_segment_url) | ||||||
|                         decrypt_info['KEY'] = self.ydl.urlopen(decrypt_info['URI']).read() |                         decrypt_info['KEY'] = self.ydl.urlopen(decrypt_info['URI']).read() | ||||||
|                 elif line.startswith('#EXT-X-MEDIA-SEQUENCE'): |                 elif line.startswith('#EXT-X-MEDIA-SEQUENCE'): | ||||||
|                     media_sequence = int(line[22:]) |                     media_sequence = int(line[22:]) | ||||||
|   | |||||||
| @@ -926,6 +926,10 @@ from .udn import UDNEmbedIE | |||||||
| from .digiteka import DigitekaIE | from .digiteka import DigitekaIE | ||||||
| from .unistra import UnistraIE | from .unistra import UnistraIE | ||||||
| from .uol import UOLIE | from .uol import UOLIE | ||||||
|  | from .uplynk import ( | ||||||
|  |     UplynkIE, | ||||||
|  |     UplynkPreplayIE, | ||||||
|  | ) | ||||||
| from .urort import UrortIE | from .urort import UrortIE | ||||||
| from .urplay import URPlayIE | from .urplay import URPlayIE | ||||||
| from .usatoday import USATodayIE | from .usatoday import USATodayIE | ||||||
|   | |||||||
							
								
								
									
										64
									
								
								youtube_dl/extractor/uplynk.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								youtube_dl/extractor/uplynk.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,64 @@ | |||||||
|  | # coding: utf-8 | ||||||
|  | from __future__ import unicode_literals | ||||||
|  |  | ||||||
|  | import re | ||||||
|  |  | ||||||
|  | from .common import InfoExtractor | ||||||
|  | from ..utils import ( | ||||||
|  |     float_or_none, | ||||||
|  |     ExtractorError, | ||||||
|  | ) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class UplynkIE(InfoExtractor): | ||||||
|  |     _VALID_URL = r'https?://.*?\.uplynk\.com/(?P<path>ext/[0-9a-f]{32}/(?P<external_id>[^/?&]+)|(?P<id>[0-9a-f]{32}))\.(?:m3u8|json)(?:.*?\bpbs=(?P<session_id>[^&]+))?' | ||||||
|  |     _TEST = { | ||||||
|  |         'url': 'http://content.uplynk.com/e89eaf2ce9054aa89d92ddb2d817a52e.m3u8', | ||||||
|  |         'info_dict': { | ||||||
|  |             'id': 'e89eaf2ce9054aa89d92ddb2d817a52e', | ||||||
|  |             'ext': 'mp4', | ||||||
|  |             'title': '030816-kgo-530pm-solar-eclipse-vid_web.mp4', | ||||||
|  |             'uploader_id': '4413701bf5a1488db55b767f8ae9d4fa', | ||||||
|  |         }, | ||||||
|  |         'params': { | ||||||
|  |             # m3u8 download | ||||||
|  |             'skip_download': True, | ||||||
|  |         }, | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     def _real_extract(self, url): | ||||||
|  |         path, external_id, video_id, session_id = re.match(self._VALID_URL, url).groups() | ||||||
|  |         display_id = video_id or external_id | ||||||
|  |         formats = self._extract_m3u8_formats('http://content.uplynk.com/%s.m3u8' % path, display_id, 'mp4') | ||||||
|  |         if session_id: | ||||||
|  |             for f in formats: | ||||||
|  |                 f['extra_param_to_segment_url'] = { | ||||||
|  |                     'pbs': session_id, | ||||||
|  |                 } | ||||||
|  |         self._sort_formats(formats) | ||||||
|  |         asset = self._download_json('http://content.uplynk.com/player/assetinfo/%s.json' % path, display_id) | ||||||
|  |         if asset.get('error') == 1: | ||||||
|  |             raise ExtractorError('% said: %s' % (self.IE_NAME, asset['msg']), expected=True) | ||||||
|  |  | ||||||
|  |         return { | ||||||
|  |             'id': asset['asset'], | ||||||
|  |             'title': asset['desc'], | ||||||
|  |             'thumbnail': asset.get('default_poster_url'), | ||||||
|  |             'duration': float_or_none(asset.get('duration')), | ||||||
|  |             'uploader_id': asset.get('owner'), | ||||||
|  |             'formats': formats, | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class UplynkPreplayIE(InfoExtractor): | ||||||
|  |     _VALID_URL = r'https?://.*?\.uplynk\.com/preplay2?/(?P<path>ext/[0-9a-f]{32}/(?P<external_id>[^/?&]+)|(?P<id>[0-9a-f]{32}))\.json' | ||||||
|  |  | ||||||
|  |     def _real_extract(self, url): | ||||||
|  |         path, external_id, video_id = re.match(self._VALID_URL, url).groups() | ||||||
|  |         display_id = video_id or external_id | ||||||
|  |         preplay = self._download_json(url, display_id) | ||||||
|  |         content_url = 'http://content.uplynk.com/%s.m3u8' % path | ||||||
|  |         session_id = preplay.get('sid') | ||||||
|  |         if session_id: | ||||||
|  |             content_url += '?pbs=' + session_id | ||||||
|  |         return self.url_result(content_url, 'Uplynk') | ||||||
		Reference in New Issue
	
	Block a user
	 Remita Amine
					Remita Amine