]> jfr.im git - yt-dlp.git/blame - youtube_dlc/extractor/hgtv.py
[skip travis] renaming
[yt-dlp.git] / youtube_dlc / extractor / hgtv.py
CommitLineData
f0d36694
RA
1# coding: utf-8
2from __future__ import unicode_literals
3
4from .common import InfoExtractor
4e9fee10
S
5
6
7class HGTVComShowIE(InfoExtractor):
8 IE_NAME = 'hgtv.com:show'
9 _VALID_URL = r'https?://(?:www\.)?hgtv\.com/shows/[^/]+/(?P<id>[^/?#&]+)'
fa3ea722
S
10 _TESTS = [{
11 # data-module="video"
12 'url': 'http://www.hgtv.com/shows/flip-or-flop/flip-or-flop-full-episodes-season-4-videos',
4e9fee10 13 'info_dict': {
fa3ea722 14 'id': 'flip-or-flop-full-episodes-season-4-videos',
4e9fee10
S
15 'title': 'Flip or Flop Full Episodes',
16 },
17 'playlist_mincount': 15,
fa3ea722
S
18 }, {
19 # data-deferred-module="video"
20 'url': 'http://www.hgtv.com/shows/good-bones/episodes/an-old-victorian-house-gets-a-new-facelift',
21 'only_matching': True,
22 }]
4e9fee10
S
23
24 def _real_extract(self, url):
25 display_id = self._match_id(url)
26
27 webpage = self._download_webpage(url, display_id)
28
29 config = self._parse_json(
30 self._search_regex(
ac7409ee 31 r'(?s)data-(?:deferred-)?module=["\']video["\'][^>]*>.*?<script[^>]+type=["\']text/x-config["\'][^>]*>(.+?)</script',
4e9fee10
S
32 webpage, 'video config'),
33 display_id)['channels'][0]
34
35 entries = [
36 self.url_result(video['releaseUrl'])
37 for video in config['videos'] if video.get('releaseUrl')]
38
39 return self.playlist_result(
40 entries, display_id, config.get('title'), config.get('description'))