| 
									
										
										
										
											2013-11-22 17:19:22 +01:00
										 |  |  | # coding: utf-8 | 
					
						
							| 
									
										
										
										
											2014-07-27 02:05:06 +07:00
										 |  |  | from __future__ import unicode_literals | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-22 17:19:22 +01:00
										 |  |  | import re | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | from .common import InfoExtractor | 
					
						
							| 
									
										
										
										
											2016-03-26 02:19:24 +06:00
										 |  |  | from ..utils import ( | 
					
						
							| 
									
										
										
										
											2016-06-12 11:08:39 +07:00
										 |  |  |     ExtractorError, | 
					
						
							| 
									
										
										
										
											2016-03-26 02:19:24 +06:00
										 |  |  |     urlencode_postdata, | 
					
						
							|  |  |  | ) | 
					
						
							| 
									
										
										
										
											2013-11-22 17:19:22 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class StreamcloudIE(InfoExtractor): | 
					
						
							| 
									
										
										
										
											2014-07-27 02:05:06 +07:00
										 |  |  |     IE_NAME = 'streamcloud.eu' | 
					
						
							| 
									
										
										
										
											2014-11-09 22:00:51 +02:00
										 |  |  |     _VALID_URL = r'https?://streamcloud\.eu/(?P<id>[a-zA-Z0-9_-]+)(?:/(?P<fname>[^#?]*)\.html)?' | 
					
						
							| 
									
										
										
										
											2013-11-22 17:19:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-12 11:08:39 +07:00
										 |  |  |     _TESTS = [{ | 
					
						
							| 
									
										
										
										
											2014-07-27 02:05:06 +07:00
										 |  |  |         'url': 'http://streamcloud.eu/skp9j99s4bpz/youtube-dl_test_video_____________-BaW_jenozKc.mp4.html', | 
					
						
							|  |  |  |         'md5': '6bea4c7fa5daaacc2a946b7146286686', | 
					
						
							|  |  |  |         'info_dict': { | 
					
						
							|  |  |  |             'id': 'skp9j99s4bpz', | 
					
						
							|  |  |  |             'ext': 'mp4', | 
					
						
							|  |  |  |             'title': 'youtube-dl test video  \'/\\ ä ↭', | 
					
						
							| 
									
										
										
										
											2013-11-22 17:19:22 +01:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2014-07-27 02:05:06 +07:00
										 |  |  |         'skip': 'Only available from the EU' | 
					
						
							| 
									
										
										
										
											2016-06-12 11:08:39 +07:00
										 |  |  |     }, { | 
					
						
							|  |  |  |         'url': 'http://streamcloud.eu/ua8cmfh1nbe6/NSHIP-148--KUC-NG--H264-.mp4.html', | 
					
						
							|  |  |  |         'only_matching': True, | 
					
						
							|  |  |  |     }] | 
					
						
							| 
									
										
										
										
											2013-11-22 17:19:22 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def _real_extract(self, url): | 
					
						
							| 
									
										
										
										
											2014-11-09 22:00:51 +02:00
										 |  |  |         video_id = self._match_id(url) | 
					
						
							|  |  |  |         url = 'http://streamcloud.eu/%s' % video_id | 
					
						
							| 
									
										
										
										
											2013-11-22 17:19:22 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         orig_webpage = self._download_webpage(url, video_id) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-12 11:08:39 +07:00
										 |  |  |         if '>File Not Found<' in orig_webpage: | 
					
						
							|  |  |  |             raise ExtractorError( | 
					
						
							|  |  |  |                 'Video %s does not exist' % video_id, expected=True) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-22 17:19:22 +01:00
										 |  |  |         fields = re.findall(r'''(?x)<input\s+
 | 
					
						
							|  |  |  |             type="(?:hidden|submit)"\s+ | 
					
						
							|  |  |  |             name="([^"]+)"\s+ | 
					
						
							|  |  |  |             (?:id="[^"]+"\s+)? | 
					
						
							|  |  |  |             value="([^"]*)" | 
					
						
							|  |  |  |             ''', orig_webpage)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-15 03:32:17 +02:00
										 |  |  |         self._sleep(12, video_id) | 
					
						
							| 
									
										
										
										
											2013-11-22 17:19:22 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         webpage = self._download_webpage( | 
					
						
							| 
									
										
										
										
											2016-06-20 22:40:22 +07:00
										 |  |  |             url, video_id, data=urlencode_postdata(fields), headers={ | 
					
						
							|  |  |  |                 b'Content-Type': b'application/x-www-form-urlencoded', | 
					
						
							|  |  |  |             }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         try: | 
					
						
							|  |  |  |             title = self._html_search_regex( | 
					
						
							|  |  |  |                 r'<h1[^>]*>([^<]+)<', webpage, 'title') | 
					
						
							|  |  |  |             video_url = self._search_regex( | 
					
						
							|  |  |  |                 r'file:\s*"([^"]+)"', webpage, 'video URL') | 
					
						
							|  |  |  |         except ExtractorError: | 
					
						
							|  |  |  |             message = self._html_search_regex( | 
					
						
							|  |  |  |                 r'(?s)<div[^>]+class=(["\']).*?msgboxinfo.*?\1[^>]*>(?P<message>.+?)</div>', | 
					
						
							|  |  |  |                 webpage, 'message', default=None, group='message') | 
					
						
							|  |  |  |             if message: | 
					
						
							|  |  |  |                 raise ExtractorError('%s said: %s' % (self.IE_NAME, message), expected=True) | 
					
						
							|  |  |  |             raise | 
					
						
							| 
									
										
										
										
											2013-11-22 17:19:22 +01:00
										 |  |  |         thumbnail = self._search_regex( | 
					
						
							| 
									
										
										
										
											2014-07-27 02:05:06 +07:00
										 |  |  |             r'image:\s*"([^"]+)"', webpage, 'thumbnail URL', fatal=False) | 
					
						
							| 
									
										
										
										
											2013-11-22 17:19:22 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return { | 
					
						
							|  |  |  |             'id': video_id, | 
					
						
							|  |  |  |             'title': title, | 
					
						
							|  |  |  |             'url': video_url, | 
					
						
							|  |  |  |             'thumbnail': thumbnail, | 
					
						
							| 
									
										
										
										
											2018-07-25 23:07:12 +07:00
										 |  |  |             'http_headers': { | 
					
						
							|  |  |  |                 'Referer': url, | 
					
						
							|  |  |  |             }, | 
					
						
							| 
									
										
										
										
											2013-11-22 17:19:22 +01:00
										 |  |  |         } |