aboutsummaryrefslogtreecommitdiff
path: root/youtube_dl/extractor/funimation.py
diff options
context:
space:
mode:
authorSergey M․ <dstftw@gmail.com>2015-12-13 07:17:42 +0600
committerSergey M․ <dstftw@gmail.com>2015-12-13 07:17:42 +0600
commit0014ffa829ad0d39d7231f664ea4436d2edd5c6a (patch)
tree3f80d8718f655bb34beac4a393370020c88faf51 /youtube_dl/extractor/funimation.py
parentc03943f39440d80e82239c82958b5d2f48f25410 (diff)
downloadyoutube-dl-0014ffa829ad0d39d7231f664ea4436d2edd5c6a.tar.xz
[funimation] Improve login
Diffstat (limited to 'youtube_dl/extractor/funimation.py')
-rw-r--r--youtube_dl/extractor/funimation.py16
1 files changed, 11 insertions, 5 deletions
diff --git a/youtube_dl/extractor/funimation.py b/youtube_dl/extractor/funimation.py
index 8a65343c5..d1a95d87f 100644
--- a/youtube_dl/extractor/funimation.py
+++ b/youtube_dl/extractor/funimation.py
@@ -1,8 +1,6 @@
# coding: utf-8
from __future__ import unicode_literals
-import re
-
from .common import InfoExtractor
from ..utils import (
clean_html,
@@ -18,6 +16,8 @@ from ..utils import (
class FunimationIE(InfoExtractor):
_VALID_URL = r'https?://(?:www\.)?funimation\.com/shows/[^/]+/videos/(?:official|promotional)/(?P<id>[^/?#&]+)'
+ _NETRC_MACHINE = 'funimation'
+
_TESTS = [{
'url': 'http://www.funimation.com/shows/air/videos/official/breeze',
'info_dict': {
@@ -62,10 +62,16 @@ class FunimationIE(InfoExtractor):
'User-Agent': 'Mozilla/5.0 (Windows NT 5.2; WOW64; rv:42.0) Gecko/20100101 Firefox/42.0',
'Content-Type': 'application/x-www-form-urlencoded'
})
- login = self._download_webpage(
+ login_page = self._download_webpage(
login_request, None, 'Logging in as %s' % username)
- if re.search(r'<meta property="og:url" content="http://www.funimation.com/login"/>', login) is not None:
- raise ExtractorError('Unable to login, wrong username or password.', expected=True)
+ if any(p in login_page for p in ('funimation.com/logout', '>Log Out<')):
+ return
+ error = self._html_search_regex(
+ r'(?s)<div[^>]+id=["\']errorMessages["\'][^>]*>(.+?)</div>',
+ login_page, 'error messages', default=None)
+ if error:
+ raise ExtractorError('Unable to login: %s' % error, expected=True)
+ raise ExtractorError('Unable to log in')
def _real_initialize(self):
self._login()