youtube-dl/youtube_dl/extractor/auengine.py

51 lines
1.6 KiB
Python
Raw Normal View History

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
class AUEngineIE(InfoExtractor):
2013-07-03 16:36:36 +02:00
_TEST = {
u'url': u'http://auengine.com/embed.php?file=lfvlytY6&w=650&h=370',
u'file': u'lfvlytY6.mp4',
u'md5': u'48972bdbcf1a3a2f5533e62425b41d4f',
u'info_dict': {
u"title": u"[Commie]The Legend of the Legendary Heroes - 03 - Replication Eye (Alpha Stigma)[F9410F5A]"
}
}
2013-06-27 13:58:09 +02:00
_VALID_URL = r'(?:http://)?(?:www\.)?auengine\.com/embed.php\?.*?file=([^&]+).*?'
def _real_extract(self, url):
mobj = re.match(self._VALID_URL, url)
video_id = mobj.group(1)
webpage = self._download_webpage(url, video_id)
title = self._html_search_regex(r'<title>(?P<title>.+?)</title>',
webpage, u'title')
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:
raise ExtractorError(u'Could not find video URL')
ext = u'.' + 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 {
2013-06-27 13:58:09 +02:00
'id': video_id,
2013-11-18 13:56:45 +01:00
'url': video_url,
2013-06-27 13:58:09 +02:00
'ext': ext,
'title': title,
'thumbnail': thumbnail,
2013-11-18 13:56:45 +01:00
}