breitbart.py 1.3 KB

12345678910111213141516171819202122232425262728293031323334
  1. from .common import InfoExtractor
  2. class BreitBartIE(InfoExtractor):
  3. _VALID_URL = r'https?://(?:www\.)?breitbart\.com/videos/v/(?P<id>[^/?#]+)'
  4. _TESTS = [{
  5. 'url': 'https://www.breitbart.com/videos/v/5cOz1yup/?pl=Ij6NDOji',
  6. 'md5': '0aa6d1d6e183ac5ca09207fe49f17ade',
  7. 'info_dict': {
  8. 'id': '5cOz1yup',
  9. 'ext': 'mp4',
  10. 'title': 'Watch \u2013 Clyburn: Statues in Congress Have to Go Because they Are Honoring Slavery',
  11. 'description': 'md5:bac35eb0256d1cb17f517f54c79404d5',
  12. 'thumbnail': 'https://cdn.jwplayer.com/thumbs/5cOz1yup-1920.jpg',
  13. 'age_limit': 0,
  14. },
  15. }, {
  16. 'url': 'https://www.breitbart.com/videos/v/eaiZjVOn/',
  17. 'only_matching': True,
  18. }]
  19. def _real_extract(self, url):
  20. video_id = self._match_id(url)
  21. webpage = self._download_webpage(url, video_id)
  22. formats = self._extract_m3u8_formats(f'https://cdn.jwplayer.com/manifests/{video_id}.m3u8', video_id, ext='mp4')
  23. return {
  24. 'id': video_id,
  25. 'title': self._generic_title('', webpage),
  26. 'description': self._og_search_description(webpage),
  27. 'thumbnail': self._og_search_thumbnail(webpage),
  28. 'age_limit': self._rta_search(webpage),
  29. 'formats': formats,
  30. }