| 
									
										
										
										
											2013-11-20 06:13:19 +01:00
										 |  |  | # coding: utf-8 | 
					
						
							| 
									
										
										
										
											2014-02-05 19:02:03 +07:00
										 |  |  | from __future__ import unicode_literals | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-06 09:20:27 +01:00
										 |  |  | import json | 
					
						
							| 
									
										
										
										
											2017-12-02 20:22:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-06 13:59:12 +01:00
										 |  |  | from .radiocanada import RadioCanadaIE | 
					
						
							| 
									
										
										
										
											2019-03-06 09:28:14 +01:00
										 |  |  | from ..compat import compat_HTTPError | 
					
						
							| 
									
										
										
										
											2016-09-16 17:36:22 +01:00
										 |  |  | from ..utils import ( | 
					
						
							| 
									
										
										
										
											2019-03-06 09:28:14 +01:00
										 |  |  |     ExtractorError, | 
					
						
							| 
									
										
										
										
											2016-09-16 17:36:22 +01:00
										 |  |  |     int_or_none, | 
					
						
							| 
									
										
										
										
											2019-02-06 13:59:12 +01:00
										 |  |  |     merge_dicts, | 
					
						
							| 
									
										
										
										
											2016-09-16 17:36:22 +01:00
										 |  |  | ) | 
					
						
							| 
									
										
										
										
											2013-11-20 06:13:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-06 13:59:12 +01:00
										 |  |  | class TouTvIE(RadioCanadaIE): | 
					
						
							| 
									
										
										
										
											2016-09-16 17:36:22 +01:00
										 |  |  |     _NETRC_MACHINE = 'toutv' | 
					
						
							| 
									
										
										
										
											2014-02-05 19:02:03 +07:00
										 |  |  |     IE_NAME = 'tou.tv' | 
					
						
							| 
									
										
										
										
											2017-12-12 11:11:44 +01:00
										 |  |  |     _VALID_URL = r'https?://ici\.tou\.tv/(?P<id>[a-zA-Z0-9_-]+(?:/S[0-9]+[EC][0-9]+)?)' | 
					
						
							| 
									
										
										
										
											2013-11-20 06:13:19 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-05 03:24:42 +07:00
										 |  |  |     _TESTS = [{ | 
					
						
							| 
									
										
										
										
											2016-05-24 16:06:02 +01:00
										 |  |  |         'url': 'http://ici.tou.tv/garfield-tout-court/S2015E17', | 
					
						
							| 
									
										
										
										
											2014-02-05 19:02:03 +07:00
										 |  |  |         'info_dict': { | 
					
						
							| 
									
										
										
										
											2016-05-24 16:06:02 +01:00
										 |  |  |             'id': '122017', | 
					
						
							| 
									
										
										
										
											2015-02-01 15:01:33 +01:00
										 |  |  |             'ext': 'mp4', | 
					
						
							| 
									
										
										
										
											2016-05-24 16:06:02 +01:00
										 |  |  |             'title': 'Saison 2015 Épisode 17', | 
					
						
							|  |  |  |             'description': 'La photo de famille 2', | 
					
						
							|  |  |  |             'upload_date': '20100717', | 
					
						
							| 
									
										
										
										
											2013-11-20 06:13:19 +01:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2014-02-05 19:02:03 +07:00
										 |  |  |         'params': { | 
					
						
							| 
									
										
										
										
											2016-05-24 16:06:02 +01:00
										 |  |  |             # m3u8 download | 
					
						
							|  |  |  |             'skip_download': True, | 
					
						
							| 
									
										
										
										
											2013-11-20 06:13:19 +01:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2016-09-16 17:36:22 +01:00
										 |  |  |         'skip': '404 Not Found', | 
					
						
							| 
									
										
										
										
											2016-11-05 03:24:42 +07:00
										 |  |  |     }, { | 
					
						
							|  |  |  |         'url': 'http://ici.tou.tv/hackers', | 
					
						
							|  |  |  |         'only_matching': True, | 
					
						
							| 
									
										
										
										
											2017-12-12 11:11:44 +01:00
										 |  |  |     }, { | 
					
						
							|  |  |  |         'url': 'https://ici.tou.tv/l-age-adulte/S01C501', | 
					
						
							|  |  |  |         'only_matching': True, | 
					
						
							| 
									
										
										
										
											2016-11-05 03:24:42 +07:00
										 |  |  |     }] | 
					
						
							| 
									
										
										
										
											2019-03-06 09:20:27 +01:00
										 |  |  |     _CLIENT_KEY = '4dd36440-09d5-4468-8923-b6d91174ad36' | 
					
						
							| 
									
										
										
										
											2013-11-20 06:13:19 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-16 17:36:22 +01:00
										 |  |  |     def _real_initialize(self): | 
					
						
							|  |  |  |         email, password = self._get_login_info() | 
					
						
							|  |  |  |         if email is None: | 
					
						
							|  |  |  |             return | 
					
						
							| 
									
										
										
										
											2019-03-06 09:28:14 +01:00
										 |  |  |         try: | 
					
						
							|  |  |  |             self._access_token = self._download_json( | 
					
						
							|  |  |  |                 'https://services.radio-canada.ca/toutv/profiling/accounts/login', | 
					
						
							|  |  |  |                 None, 'Logging in', data=json.dumps({ | 
					
						
							|  |  |  |                     'ClientId': self._CLIENT_KEY, | 
					
						
							|  |  |  |                     'ClientSecret': '34026772-244b-49b6-8b06-317b30ac9a20', | 
					
						
							|  |  |  |                     'Email': email, | 
					
						
							|  |  |  |                     'Password': password, | 
					
						
							|  |  |  |                     'Scope': 'id.write media-validation.read', | 
					
						
							|  |  |  |                 }).encode(), headers={ | 
					
						
							|  |  |  |                     'Authorization': 'client-key ' + self._CLIENT_KEY, | 
					
						
							|  |  |  |                     'Content-Type': 'application/json;charset=utf-8', | 
					
						
							|  |  |  |                 })['access_token'] | 
					
						
							|  |  |  |         except ExtractorError as e: | 
					
						
							|  |  |  |             if isinstance(e.cause, compat_HTTPError) and e.cause.code == 401: | 
					
						
							|  |  |  |                 error = self._parse_json(e.cause.read().decode(), None)['Message'] | 
					
						
							|  |  |  |                 raise ExtractorError(error, expected=True) | 
					
						
							|  |  |  |             raise | 
					
						
							| 
									
										
										
										
											2019-02-06 13:59:12 +01:00
										 |  |  |         self._claims = self._call_api('validation/v2/getClaims')['claims'] | 
					
						
							| 
									
										
										
										
											2016-09-16 17:36:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-20 06:13:19 +01:00
										 |  |  |     def _real_extract(self, url): | 
					
						
							| 
									
										
										
										
											2016-05-24 16:06:02 +01:00
										 |  |  |         path = self._match_id(url) | 
					
						
							|  |  |  |         metadata = self._download_json('http://ici.tou.tv/presentation/%s' % path, path) | 
					
						
							| 
									
										
										
										
											2017-08-23 22:28:09 +07:00
										 |  |  |         # IsDrm does not necessarily mean the video is DRM protected (see | 
					
						
							| 
									
										
										
										
											2019-03-09 19:14:41 +07:00
										 |  |  |         # https://github.com/ytdl-org/youtube-dl/issues/13994). | 
					
						
							| 
									
										
										
										
											2016-09-16 17:36:22 +01:00
										 |  |  |         if metadata.get('IsDrm'): | 
					
						
							| 
									
										
										
										
											2017-08-23 22:28:09 +07:00
										 |  |  |             self.report_warning('This video is probably DRM protected.', path) | 
					
						
							| 
									
										
										
										
											2016-05-24 16:06:02 +01:00
										 |  |  |         video_id = metadata['IdMedia'] | 
					
						
							|  |  |  |         details = metadata['Details'] | 
					
						
							| 
									
										
										
										
											2013-11-20 06:13:19 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-06 13:59:12 +01:00
										 |  |  |         return merge_dicts({ | 
					
						
							| 
									
										
										
										
											2013-11-20 06:13:19 +01:00
										 |  |  |             'id': video_id, | 
					
						
							| 
									
										
										
										
											2019-02-06 13:59:12 +01:00
										 |  |  |             'title': details.get('OriginalTitle'), | 
					
						
							| 
									
										
										
										
											2016-05-24 16:06:02 +01:00
										 |  |  |             'thumbnail': details.get('ImageUrl'), | 
					
						
							|  |  |  |             'duration': int_or_none(details.get('LengthInSeconds')), | 
					
						
							| 
									
										
										
										
											2019-02-06 13:59:12 +01:00
										 |  |  |         }, self._extract_info(metadata.get('AppCode', 'toutv'), video_id)) |