1
0
mirror of https://github.com/yt-dlp/yt-dlp.git synced 2024-12-15 10:05:24 +01:00
yt-dlp/youtube_dl/extractor/auengine.py

56 lines
1.7 KiB
Python
Raw Normal View History

2014-01-07 10:04:48 +01:00
from __future__ import unicode_literals
2013-06-27 13:58:09 +02:00
import re
from .common import InfoExtractor
from ..utils import (
compat_urllib_parse,
2013-11-18 13:56:45 +01:00
determine_ext,
ExtractorError,
)
2013-06-27 13:58:09 +02:00
2014-01-07 10:04:48 +01:00
class AUEngineIE(InfoExtractor):
2014-03-25 15:16:10 +01:00
_VALID_URL = r'http://(?:www\.)?auengine\.com/embed\.php\?.*?file=(?P<id>[^&]+).*?'
2013-07-03 16:36:36 +02:00
_TEST = {
2014-01-07 10:04:48 +01:00
'url': 'http://auengine.com/embed.php?file=lfvlytY6&w=650&h=370',
'md5': '48972bdbcf1a3a2f5533e62425b41d4f',
'info_dict': {
2014-03-25 15:16:10 +01:00
'id': 'lfvlytY6',
'ext': 'mp4',
2014-01-07 10:04:48 +01:00
'title': '[Commie]The Legend of the Legendary Heroes - 03 - Replication Eye (Alpha Stigma)[F9410F5A]'
2013-07-03 16:36:36 +02:00
}
}
2013-06-27 13:58:09 +02:00
def _real_extract(self, url):
mobj = re.match(self._VALID_URL, url)
2014-03-25 15:16:10 +01:00
video_id = mobj.group('id')
2013-06-27 13:58:09 +02:00
webpage = self._download_webpage(url, video_id)
2014-03-25 15:16:10 +01:00
title = self._html_search_regex(r'<title>(?P<title>.+?)</title>', webpage, 'title')
2013-06-27 13:58:09 +02:00
title = title.strip()
2013-11-18 13:56:45 +01:00
links = re.findall(r'\s(?:file|url):\s*["\']([^\'"]+)["\']', webpage)
links = map(compat_urllib_parse.unquote, links)
thumbnail = None
video_url = None
2013-06-27 13:58:09 +02:00
for link in links:
2013-11-18 13:56:45 +01:00
if link.endswith('.png'):
2013-06-27 13:58:09 +02:00
thumbnail = link
2013-11-18 13:56:45 +01:00
elif '/videos/' in link:
video_url = link
if not video_url:
2014-03-25 15:16:10 +01:00
raise ExtractorError('Could not find video URL')
2014-01-07 10:04:48 +01:00
ext = '.' + determine_ext(video_url)
2013-06-27 13:58:09 +02:00
if ext == title[-len(ext):]:
title = title[:-len(ext)]
2013-11-18 13:56:45 +01:00
return {
2014-03-25 15:16:10 +01:00
'id': video_id,
'url': video_url,
'title': title,
2013-06-27 13:58:09 +02:00
'thumbnail': thumbnail,
2014-03-25 15:53:26 +01:00
'http_referer': 'http://www.auengine.com/flowplayer/flowplayer.commercial-3.2.14.swf',
2013-11-18 13:56:45 +01:00
}