| 
									
										
										
										
											2014-03-24 17:12:15 +01:00
										 |  |  | from __future__ import unicode_literals | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import re | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | from .common import InfoExtractor | 
					
						
							| 
									
										
										
										
											2014-04-10 19:37:55 +07:00
										 |  |  | from ..utils import ExtractorError | 
					
						
							| 
									
										
										
										
											2014-03-24 17:12:15 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class BYUtvIE(InfoExtractor): | 
					
						
							| 
									
										
										
										
											2016-10-02 00:50:07 +07:00
										 |  |  |     _VALID_URL = r'https?://(?:www\.)?byutv\.org/watch/(?!event/)(?P<id>[0-9a-f-]+)(?:/(?P<display_id>[^/?#&]+))?' | 
					
						
							| 
									
										
										
										
											2016-10-02 00:44:54 +07:00
										 |  |  |     _TESTS = [{ | 
					
						
							| 
									
										
										
										
											2014-11-05 15:43:53 +01:00
										 |  |  |         'url': 'http://www.byutv.org/watch/6587b9a3-89d2-42a6-a7f7-fd2f81840a7d/studio-c-season-5-episode-5', | 
					
						
							| 
									
										
										
										
											2014-03-24 17:12:15 +01:00
										 |  |  |         'info_dict': { | 
					
						
							| 
									
										
										
										
											2016-10-02 00:44:54 +07:00
										 |  |  |             'id': '6587b9a3-89d2-42a6-a7f7-fd2f81840a7d', | 
					
						
							|  |  |  |             'display_id': 'studio-c-season-5-episode-5', | 
					
						
							| 
									
										
										
										
											2014-03-24 17:12:15 +01:00
										 |  |  |             'ext': 'mp4', | 
					
						
							| 
									
										
										
										
											2014-11-05 15:43:53 +01:00
										 |  |  |             'title': 'Season 5 Episode 5', | 
					
						
							| 
									
										
										
										
											2016-10-02 00:44:54 +07:00
										 |  |  |             'description': 'md5:e07269172baff037f8e8bf9956bc9747', | 
					
						
							| 
									
										
										
										
											2017-01-02 20:08:07 +08:00
										 |  |  |             'thumbnail': r're:^https?://.*\.jpg$', | 
					
						
							| 
									
										
										
										
											2015-12-04 16:18:02 +01:00
										 |  |  |             'duration': 1486.486, | 
					
						
							| 
									
										
										
										
											2014-03-24 17:12:15 +01:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2016-05-24 16:42:22 +01:00
										 |  |  |         'params': { | 
					
						
							|  |  |  |             'skip_download': True, | 
					
						
							|  |  |  |         }, | 
					
						
							| 
									
										
										
										
											2016-05-24 11:24:29 +01:00
										 |  |  |         'add_ie': ['Ooyala'], | 
					
						
							| 
									
										
										
										
											2016-10-02 00:44:54 +07:00
										 |  |  |     }, { | 
					
						
							|  |  |  |         'url': 'http://www.byutv.org/watch/6587b9a3-89d2-42a6-a7f7-fd2f81840a7d', | 
					
						
							|  |  |  |         'only_matching': True, | 
					
						
							|  |  |  |     }] | 
					
						
							| 
									
										
										
										
											2014-03-24 17:12:15 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def _real_extract(self, url): | 
					
						
							| 
									
										
										
										
											2016-10-02 00:44:54 +07:00
										 |  |  |         mobj = re.match(self._VALID_URL, url) | 
					
						
							|  |  |  |         video_id = mobj.group('id') | 
					
						
							|  |  |  |         display_id = mobj.group('display_id') or video_id | 
					
						
							| 
									
										
										
										
											2014-03-24 17:12:15 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-02 00:44:54 +07:00
										 |  |  |         webpage = self._download_webpage(url, display_id) | 
					
						
							| 
									
										
										
										
											2014-03-24 17:12:15 +01:00
										 |  |  |         episode_code = self._search_regex( | 
					
						
							|  |  |  |             r'(?s)episode:(.*?\}),\s*\n', webpage, 'episode information') | 
					
						
							| 
									
										
										
										
											2016-09-30 19:59:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         ep = self._parse_json( | 
					
						
							| 
									
										
										
										
											2016-10-02 00:44:54 +07:00
										 |  |  |             episode_code, display_id, transform_source=lambda s: | 
					
						
							| 
									
										
										
										
											2016-09-30 19:59:08 +02:00
										 |  |  |             re.sub(r'(\n\s+)([a-zA-Z]+):\s+\'(.*?)\'', r'\1"\2": "\3"', s)) | 
					
						
							| 
									
										
										
										
											2014-03-24 17:12:15 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-02 00:44:54 +07:00
										 |  |  |         if ep['providerType'] != 'Ooyala': | 
					
						
							| 
									
										
										
										
											2014-03-24 17:12:15 +01:00
										 |  |  |             raise ExtractorError('Unsupported provider %s' % ep['provider']) | 
					
						
							| 
									
										
										
										
											2016-10-02 00:44:54 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return { | 
					
						
							|  |  |  |             '_type': 'url_transparent', | 
					
						
							|  |  |  |             'ie_key': 'Ooyala', | 
					
						
							|  |  |  |             'url': 'ooyala:%s' % ep['providerId'], | 
					
						
							|  |  |  |             'id': video_id, | 
					
						
							|  |  |  |             'display_id': display_id, | 
					
						
							|  |  |  |             'title': ep['title'], | 
					
						
							|  |  |  |             'description': ep.get('description'), | 
					
						
							|  |  |  |             'thumbnail': ep.get('imageThumbnail'), | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-10-02 00:50:07 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class BYUtvEventIE(InfoExtractor): | 
					
						
							|  |  |  |     _VALID_URL = r'https?://(?:www\.)?byutv\.org/watch/event/(?P<id>[0-9a-f-]+)' | 
					
						
							|  |  |  |     _TEST = { | 
					
						
							|  |  |  |         'url': 'http://www.byutv.org/watch/event/29941b9b-8bf6-48d2-aebf-7a87add9e34b', | 
					
						
							|  |  |  |         'info_dict': { | 
					
						
							|  |  |  |             'id': '29941b9b-8bf6-48d2-aebf-7a87add9e34b', | 
					
						
							|  |  |  |             'ext': 'mp4', | 
					
						
							|  |  |  |             'title': 'Toledo vs. BYU (9/30/16)', | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         'params': { | 
					
						
							|  |  |  |             'skip_download': True, | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         'add_ie': ['Ooyala'], | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def _real_extract(self, url): | 
					
						
							|  |  |  |         video_id = self._match_id(url) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         webpage = self._download_webpage(url, video_id) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         ooyala_id = self._search_regex( | 
					
						
							|  |  |  |             r'providerId\s*:\s*(["\'])(?P<id>(?:(?!\1).)+)\1', | 
					
						
							|  |  |  |             webpage, 'ooyala id', group='id') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         title = self._search_regex( | 
					
						
							|  |  |  |             r'class=["\']description["\'][^>]*>\s*<h1>([^<]+)</h1>', webpage, | 
					
						
							|  |  |  |             'title').strip() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return { | 
					
						
							|  |  |  |             '_type': 'url_transparent', | 
					
						
							|  |  |  |             'ie_key': 'Ooyala', | 
					
						
							|  |  |  |             'url': 'ooyala:%s' % ooyala_id, | 
					
						
							|  |  |  |             'id': video_id, | 
					
						
							|  |  |  |             'title': title, | 
					
						
							|  |  |  |         } |