- 'skip_download': 'f4m fails with --test atm'
- }
- }
-
- def _real_extract(self, url):
- item_id = self._match_id(url)
- feeds_url = 'http://www.rte.ie/rteavgen/getplaylist/?type=web&format=json&id=' + item_id
- json_string = self._download_json(feeds_url, item_id)
-
- # NB the string values in the JSON are stored using XML escaping(!)
- show = json_string['shows'][0]
- title = unescapeHTML(show['title'])
- description = unescapeHTML(show.get('description'))
- thumbnail = show.get('thumbnail')
- duration = float_or_none(show.get('duration'), 1000)
-
- mg = show['media:group'][0]
-
- formats = []
-
- if mg.get('url') and not mg['url'].startswith('rtmpe:'):
- formats.append({'url': mg.get('url')})
-
- if mg.get('hls_server') and mg.get('hls_url'):
- hls_url = mg['hls_server'] + mg['hls_url']
- hls_formats = self._extract_m3u8_formats(
- hls_url, item_id, 'mp4', m3u8_id='hls', fatal=False)
- formats.extend(hls_formats)
-
- if mg.get('hds_server') and mg.get('hds_url'):
- f4m_url = mg['hds_server'] + mg['hds_url']
- f4m_formats = self._extract_f4m_formats(
- f4m_url, item_id, f4m_id='hds', fatal=False)
- formats.extend(f4m_formats)
-
- return {
- 'id': item_id,
- 'title': title,
- 'formats': formats,
- 'description': description,
- 'thumbnail': thumbnail,
- 'duration': duration,
- }