1 from .common
import InfoExtractor
2 from ..utils
import remove_end
5 class CrtvgIE(InfoExtractor
):
6 _VALID_URL
= r
'https?://(?:www\.)?crtvg\.es/tvg/a-carta/[^/#?]+-(?P<id>\d+)'
8 'url': 'https://www.crtvg.es/tvg/a-carta/os-caimans-do-tea-5839623',
9 'md5': 'c0958d9ff90e4503a75544358758921d',
12 'title': 'Os caimáns do Tea',
14 'description': 'md5:f71cfba21ae564f0a6f415b31de1f842',
15 'thumbnail': r
're:^https?://.*\.(?:jpg|png)',
17 'params': {'skip_download': 'm3u8'}
20 def _real_extract(self
, url
):
21 video_id
= self
._match
_id
(url
)
22 webpage
= self
._download
_webpage
(url
, video_id
)
23 video_url
= self
._search
_regex
(r
'var\s+url\s*=\s*["\']([^
"\']+)', webpage, 'video url')
24 formats = self._extract_m3u8_formats(video_url + '/playlist.m3u8', video_id, fatal=False)
25 formats.extend(self._extract_mpd_formats(video_url + '/manifest.mpd', video_id, fatal=False))
30 'title': remove_end(self._html_search_meta(
31 ['og:title', 'twitter:title'], webpage, 'title', default=None), ' | CRTVG'),
32 'description': self._html_search_meta('description', webpage, 'description', default=None),
33 'thumbnail': self._html_search_meta(['og:image', 'twitter:image'], webpage, 'thumbnail', default=None),