You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

27 lines
1.2 KiB

  1. import re
  2. from .mtv import MTVServicesInfoExtractor
  3. class GametrailersIE(MTVServicesInfoExtractor):
  4. _VALID_URL = r'http://www\.gametrailers\.com/(?P<type>videos|reviews|full-episodes)/(?P<id>.*?)/(?P<title>.*)'
  5. _TEST = {
  6. u'url': u'http://www.gametrailers.com/videos/zbvr8i/mirror-s-edge-2-e3-2013--debut-trailer',
  7. u'file': u'70e9a5d7-cf25-4a10-9104-6f3e7342ae0d.mp4',
  8. u'md5': u'4c8e67681a0ea7ec241e8c09b3ea8cf7',
  9. u'info_dict': {
  10. u'title': u'Mirror\'s Edge 2|E3 2013: Debut Trailer',
  11. u'description': u'Faith is back! Check out the World Premiere trailer for Mirror\'s Edge 2 straight from the EA Press Conference at E3 2013!',
  12. },
  13. }
  14. _FEED_URL = 'http://www.gametrailers.com/feeds/mrss'
  15. def _real_extract(self, url):
  16. mobj = re.match(self._VALID_URL, url)
  17. video_id = mobj.group('id')
  18. webpage = self._download_webpage(url, video_id)
  19. mgid = self._search_regex([r'data-video="(?P<mgid>mgid:.*?)"',
  20. r'data-contentId=\'(?P<mgid>mgid:.*?)\''],
  21. webpage, u'mgid')
  22. return self._get_videos_info(mgid)