]> Raphaël G. Git Repositories - youtubedl/blob - youtube_dl/extractor/bellmedia.py
Update changelog
[youtubedl] / youtube_dl / extractor / bellmedia.py
1 # coding: utf-8
2 from __future__ import unicode_literals
3
4 import re
5
6 from .common import InfoExtractor
7
8
9 class BellMediaIE(InfoExtractor):
10 _VALID_URL = r'''(?x)https?://(?:www\.)?
11 (?P<domain>
12 (?:
13 ctv|
14 tsn|
15 bnn|
16 thecomedynetwork|
17 discovery|
18 discoveryvelocity|
19 sciencechannel|
20 investigationdiscovery|
21 animalplanet|
22 bravo|
23 mtv|
24 space
25 )\.ca|
26 much\.com
27 )/.*?(?:\bvid=|-vid|~|%7E|/(?:episode)?)(?P<id>[0-9]{6,})'''
28 _TESTS = [{
29 'url': 'http://www.ctv.ca/video/player?vid=706966',
30 'md5': 'ff2ebbeae0aa2dcc32a830c3fd69b7b0',
31 'info_dict': {
32 'id': '706966',
33 'ext': 'mp4',
34 'title': 'Larry Day and Richard Jutras on the TIFF red carpet of \'Stonewall\'',
35 'description': 'etalk catches up with Larry Day and Richard Jutras on the TIFF red carpet of "Stonewall”.',
36 'upload_date': '20150919',
37 'timestamp': 1442624700,
38 },
39 'expected_warnings': ['HTTP Error 404'],
40 }, {
41 'url': 'http://www.thecomedynetwork.ca/video/player?vid=923582',
42 'only_matching': True,
43 }, {
44 'url': 'http://www.tsn.ca/video/expectations-high-for-milos-raonic-at-us-open~939549',
45 'only_matching': True,
46 }, {
47 'url': 'http://www.bnn.ca/video/berman-s-call-part-two-viewer-questions~939654',
48 'only_matching': True,
49 }, {
50 'url': 'http://www.ctv.ca/YourMorning/Video/S1E6-Monday-August-29-2016-vid938009',
51 'only_matching': True,
52 }, {
53 'url': 'http://www.much.com/shows/atmidnight/episode948007/tuesday-september-13-2016',
54 'only_matching': True,
55 }, {
56 'url': 'http://www.much.com/shows/the-almost-impossible-gameshow/928979/episode-6',
57 'only_matching': True,
58 }, {
59 'url': 'http://www.ctv.ca/DCs-Legends-of-Tomorrow/Video/S2E11-Turncoat-vid1051430',
60 'only_matching': True,
61 }]
62 _DOMAINS = {
63 'thecomedynetwork': 'comedy',
64 'discoveryvelocity': 'discvel',
65 'sciencechannel': 'discsci',
66 'investigationdiscovery': 'invdisc',
67 'animalplanet': 'aniplan',
68 }
69
70 def _real_extract(self, url):
71 domain, video_id = re.match(self._VALID_URL, url).groups()
72 domain = domain.split('.')[0]
73 return {
74 '_type': 'url_transparent',
75 'id': video_id,
76 'url': '9c9media:%s_web:%s' % (self._DOMAINS.get(domain, domain), video_id),
77 'ie_key': 'NineCNineMedia',
78 }