from __future__ import unicode_literals from .common import InfoExtractor from ..utils import xpath_text class TruTubeIE(InfoExtractor): _VALID_URL = r'https?://(?:www\.)?trutube\.tv/(?:video/|nuevo/player/embed\.php\?v=)(?P[0-9]+)' _TESTS = [{ 'url': 'http://trutube.tv/video/14880/Ramses-II-Proven-To-Be-A-Red-Headed-Caucasoid-', 'md5': 'c5b6e301b0a2040b074746cbeaa26ca1', 'info_dict': { 'id': '14880', 'ext': 'flv', 'title': 'Ramses II - Proven To Be A Red Headed Caucasoid', 'thumbnail': 're:^http:.*\.jpg$', } }, { 'url': 'https://trutube.tv/nuevo/player/embed.php?v=14880', 'only_matching': True, }] def _real_extract(self, url): video_id = self._match_id(url) config = self._download_xml( 'https://trutube.tv/nuevo/player/config.php?v=%s' % video_id, video_id, transform_source=lambda s: s.strip()) # filehd is always 404 video_url = xpath_text(config, './file', 'video URL', fatal=True) title = xpath_text(config, './title', 'title') thumbnail = xpath_text(config, './image', ' thumbnail') return { 'id': video_id, 'url': video_url, 'title': title, 'thumbnail': thumbnail, }