3 from .common import InfoExtractor
8 compat_urllib_parse_urlparse,
15 class AddAnimeIE(InfoExtractor):
17 _VALID_URL = r'^http://(?:\w+\.)?add-anime\.net/watch_video.php\?(?:.*?)v=(?P<video_id>[\w_]+)(?:.*)'
20 u'url': u'http://www.add-anime.net/watch_video.php?v=24MR3YO5SAS9',
21 u'file': u'24MR3YO5SAS9.mp4',
22 u'md5': u'72954ea10bc979ab5e2eb288b21425a0',
24 u"description": u"One Piece 606",
25 u"title": u"One Piece 606"
29 def _real_extract(self, url):
31 mobj = re.match(self._VALID_URL, url)
32 video_id = mobj.group('video_id')
33 webpage = self._download_webpage(url, video_id)
34 except ExtractorError as ee:
35 if not isinstance(ee.cause, compat_HTTPError):
38 redir_webpage = ee.cause.read().decode('utf-8')
39 action = self._search_regex(
40 r'<form id="challenge-form" action="([^"]+)"',
41 redir_webpage, u'Redirect form')
42 vc = self._search_regex(
43 r'<input type="hidden" name="jschl_vc" value="([^"]+)"/>',
44 redir_webpage, u'redirect vc value')
46 r'a\.value = ([0-9]+)[+]([0-9]+)[*]([0-9]+);',
49 raise ExtractorError(u'Cannot find redirect math task')
50 av_res = int(av.group(1)) + int(av.group(2)) * int(av.group(3))
52 parsed_url = compat_urllib_parse_urlparse(url)
53 av_val = av_res + len(parsed_url.netloc)
55 parsed_url.scheme + u'://' + parsed_url.netloc +
57 compat_urllib_parse.urlencode({
58 'jschl_vc': vc, 'jschl_answer': compat_str(av_val)}))
59 self._download_webpage(
60 confirm_url, video_id,
61 note=u'Confirming after redirect')
62 webpage = self._download_webpage(url, video_id)
65 video_url = self._search_regex(r"var hq_video_file = '(.*?)';",
66 webpage, u'video file URL')
67 except RegexNotFoundError:
68 video_url = self._search_regex(r"var normal_video_file = '(.*?)';",
69 webpage, u'video file URL')
71 video_extension = video_url[-3:] # mp4 or flv ?
72 video_title = self._og_search_title(webpage)
73 video_description = self._og_search_description(webpage)
79 'ext': video_extension,
81 'description': video_description