|
|
@ -10,6 +10,7 @@ from ..compat import (
|
|
|
|
compat_urllib_request,
|
|
|
|
compat_urllib_request,
|
|
|
|
)
|
|
|
|
)
|
|
|
|
from ..utils import (
|
|
|
|
from ..utils import (
|
|
|
|
|
|
|
|
ExtractorError,
|
|
|
|
str_to_int,
|
|
|
|
str_to_int,
|
|
|
|
)
|
|
|
|
)
|
|
|
|
from ..aes import (
|
|
|
|
from ..aes import (
|
|
|
@ -44,6 +45,15 @@ class PornHubIE(InfoExtractor):
|
|
|
|
req.add_header('Cookie', 'age_verified=1')
|
|
|
|
req.add_header('Cookie', 'age_verified=1')
|
|
|
|
webpage = self._download_webpage(req, video_id)
|
|
|
|
webpage = self._download_webpage(req, video_id)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
error_msg = self._html_search_regex(
|
|
|
|
|
|
|
|
r'(?s)<div class="userMessageSection[^"]*".*?>(.*?)</div>',
|
|
|
|
|
|
|
|
webpage, 'error message', default=None)
|
|
|
|
|
|
|
|
if error_msg:
|
|
|
|
|
|
|
|
error_msg = re.sub(r'\s+', ' ', error_msg)
|
|
|
|
|
|
|
|
raise ExtractorError(
|
|
|
|
|
|
|
|
'PornHub said: %s' % error_msg,
|
|
|
|
|
|
|
|
expected=True, video_id=video_id)
|
|
|
|
|
|
|
|
|
|
|
|
video_title = self._html_search_regex(r'<h1 [^>]+>([^<]+)', webpage, 'title')
|
|
|
|
video_title = self._html_search_regex(r'<h1 [^>]+>([^<]+)', webpage, 'title')
|
|
|
|
video_uploader = self._html_search_regex(
|
|
|
|
video_uploader = self._html_search_regex(
|
|
|
|
r'(?s)From: .+?<(?:a href="/users/|a href="/channels/|<span class="username)[^>]+>(.+?)<',
|
|
|
|
r'(?s)From: .+?<(?:a href="/users/|a href="/channels/|<span class="username)[^>]+>(.+?)<',
|
|
|
|