1
0
mirror of https://github.com/l1ving/youtube-dl synced 2025-01-19 03:53:04 +08:00
youtube-dl/youtube_dl/extractor/auengine.py

50 lines
1.6 KiB
Python
Raw Normal View History

2013-06-27 19:58:09 +08:00
import re
from .common import InfoExtractor
from ..utils import (
compat_urllib_parse,
2013-11-18 20:56:45 +08:00
determine_ext,
ExtractorError,
)
2013-06-27 19:58:09 +08:00
class AUEngineIE(InfoExtractor):
2013-07-03 22:36:36 +08: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]"
}
}
_VALID_URL = r'(?:http://)?(?:www\.)?auengine\.com/embed\.php\?.*?file=([^&]+).*?'
2013-06-27 19:58:09 +08:00
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 20:56:45 +08: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 19:58:09 +08:00
for link in links:
2013-11-18 20:56:45 +08:00
if link.endswith('.png'):
2013-06-27 19:58:09 +08:00
thumbnail = link
2013-11-18 20:56:45 +08: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 19:58:09 +08:00
if ext == title[-len(ext):]:
title = title[:-len(ext)]
2013-11-18 20:56:45 +08:00
return {
2013-06-27 19:58:09 +08:00
'id': video_id,
2013-11-18 20:56:45 +08:00
'url': video_url,
2013-06-27 19:58:09 +08:00
'title': title,
'thumbnail': thumbnail,
2013-11-18 20:56:45 +08:00
}