]> Raphaƫl G. Git Repositories - youtubedl/blob - youtube_dl/extractor/bellmedia.py
485173774d9f9c2534f9b18f1668a8d5fb204dc9
[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(?:bloomberg)?|
16 thecomedynetwork|
17 discovery|
18 discoveryvelocity|
19 sciencechannel|
20 investigationdiscovery|
21 animalplanet|
22 bravo|
23 mtv|
24 space|
25 etalk|
26 marilyn
27 )\.ca|
28 much\.com
29 )/.*?(?:\bvid(?:eoid)?=|-vid|~|%7E|/(?:episode)?)(?P<id>[0-9]{6,})'''
30 _TESTS = [{
31 'url': 'https://www.bnnbloomberg.ca/video/david-cockfield-s-top-picks~1403070',
32 'md5': '36d3ef559cfe8af8efe15922cd3ce950',
33 'info_dict': {
34 'id': '1403070',
35 'ext': 'flv',
36 'title': 'David Cockfield\'s Top Picks',
37 'description': 'md5:810f7f8c6a83ad5b48677c3f8e5bb2c3',
38 'upload_date': '20180525',
39 'timestamp': 1527288600,
40 },
41 }, {
42 'url': 'http://www.thecomedynetwork.ca/video/player?vid=923582',
43 'only_matching': True,
44 }, {
45 'url': 'http://www.tsn.ca/video/expectations-high-for-milos-raonic-at-us-open~939549',
46 'only_matching': True,
47 }, {
48 'url': 'http://www.bnn.ca/video/berman-s-call-part-two-viewer-questions~939654',
49 'only_matching': True,
50 }, {
51 'url': 'http://www.ctv.ca/YourMorning/Video/S1E6-Monday-August-29-2016-vid938009',
52 'only_matching': True,
53 }, {
54 'url': 'http://www.much.com/shows/atmidnight/episode948007/tuesday-september-13-2016',
55 'only_matching': True,
56 }, {
57 'url': 'http://www.much.com/shows/the-almost-impossible-gameshow/928979/episode-6',
58 'only_matching': True,
59 }, {
60 'url': 'http://www.ctv.ca/DCs-Legends-of-Tomorrow/Video/S2E11-Turncoat-vid1051430',
61 'only_matching': True,
62 }, {
63 'url': 'http://www.etalk.ca/video?videoid=663455',
64 'only_matching': True,
65 }]
66 _DOMAINS = {
67 'thecomedynetwork': 'comedy',
68 'discoveryvelocity': 'discvel',
69 'sciencechannel': 'discsci',
70 'investigationdiscovery': 'invdisc',
71 'animalplanet': 'aniplan',
72 'etalk': 'ctv',
73 'bnnbloomberg': 'bnn',
74 'marilyn': 'ctv_marilyn',
75 }
76
77 def _real_extract(self, url):
78 domain, video_id = re.match(self._VALID_URL, url).groups()
79 domain = domain.split('.')[0]
80 return {
81 '_type': 'url_transparent',
82 'id': video_id,
83 'url': '9c9media:%s_web:%s' % (self._DOMAINS.get(domain, domain), video_id),
84 'ie_key': 'NineCNineMedia',
85 }