aboutsummaryrefslogtreecommitdiff
path: root/youtube_dl/extractor/hentaistigma.py
blob: 4f2d30599df71c98585cf45e4c8f096f74276724 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
import re

from .common import InfoExtractor

class HentaiStigmaIE(InfoExtractor):
    _VALID_URL = r'^https?://hentai\.animestigma\.com/(?P<videoid>[^/]+)'
    _TEST = {
        u'url': u'http://hentai.animestigma.com/inyouchuu-etsu-bonus/',
        u'file': u'inyouchuu-etsu-bonus.mp4',
        u'md5': u'4e3d07422a68a4cc363d8f57c8bf0d23',
        u'info_dict': {
            u"title": u"Inyouchuu Etsu Bonus",
            u"age_limit": 18,
        }
    }

    def _real_extract(self, url):
        mobj = re.match(self._VALID_URL, url)

        video_id = mobj.group('videoid')

        # Get webpage content
        webpage = self._download_webpage(url, video_id)

        # Get the video title
        video_title = self._html_search_regex(r'<h2 class="posttitle"><a[^>]*>([^<]+)</a>',
            webpage, u'title').strip()

        # Get the wrapper url
        wrap_url = self._html_search_regex(r'<iframe src="([^"]+mp4)"', webpage, u'wrapper url')

        # Get wrapper content
        wrap_webpage = self._download_webpage(wrap_url, video_id)

        video_url = self._html_search_regex(r'clip:\s*{\s*url: "([^"]*)"', wrap_webpage, u'video url')

        info = {'id': video_id,
                'url': video_url,
                'title': video_title,
                'format': 'mp4',
                'age_limit': 18}

        return [info]