|
|
@ -15,6 +15,7 @@ from ..utils import ( |
|
|
|
urlencode_postdata, |
|
|
|
unified_timestamp, |
|
|
|
ExtractorError, |
|
|
|
NO_DEFAULT, |
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
@ -24,6 +25,11 @@ MSO_INFO = { |
|
|
|
'username_field': 'username', |
|
|
|
'password_field': 'password', |
|
|
|
}, |
|
|
|
'ATTOTT': { |
|
|
|
'name': 'DIRECTV NOW', |
|
|
|
'username_field': 'email', |
|
|
|
'password_field': 'loginpassword', |
|
|
|
}, |
|
|
|
'Rogers': { |
|
|
|
'name': 'Rogers', |
|
|
|
'username_field': 'UserName', |
|
|
@ -1316,6 +1322,8 @@ class AdobePassIE(InfoExtractor): |
|
|
|
_USER_AGENT = 'Mozilla/5.0 (X11; Linux i686; rv:47.0) Gecko/20100101 Firefox/47.0' |
|
|
|
_MVPD_CACHE = 'ap-mvpd' |
|
|
|
|
|
|
|
_DOWNLOADING_LOGIN_PAGE = 'Downloading Provider Login Page' |
|
|
|
|
|
|
|
def _download_webpage_handle(self, *args, **kwargs): |
|
|
|
headers = kwargs.get('headers', {}) |
|
|
|
headers.update(self.geo_verification_headers()) |
|
|
@ -1365,6 +1373,21 @@ class AdobePassIE(InfoExtractor): |
|
|
|
'Use --ap-mso to specify Adobe Pass Multiple-system operator Identifier ' |
|
|
|
'and --ap-username and --ap-password or --netrc to provide account credentials.', expected=True) |
|
|
|
|
|
|
|
def extract_redirect_url(html, url=None, fatal=False): |
|
|
|
# TODO: eliminate code duplication with generic extractor and move |
|
|
|
# redirection code into _download_webpage_handle |
|
|
|
REDIRECT_REGEX = r'[0-9]{,2};\s*(?:URL|url)=\'?([^\'"]+)' |
|
|
|
redirect_url = self._search_regex( |
|
|
|
r'(?i)<meta\s+(?=(?:[a-z-]+="[^"]+"\s+)*http-equiv="refresh")' |
|
|
|
r'(?:[a-z-]+="[^"]+"\s+)*?content="%s' % REDIRECT_REGEX, |
|
|
|
html, 'meta refresh redirect', |
|
|
|
default=NO_DEFAULT if fatal else None, fatal=fatal) |
|
|
|
if not redirect_url: |
|
|
|
return None |
|
|
|
if url: |
|
|
|
redirect_url = compat_urlparse.urljoin(url, unescapeHTML(redirect_url)) |
|
|
|
return redirect_url |
|
|
|
|
|
|
|
mvpd_headers = { |
|
|
|
'ap_42': 'anonymous', |
|
|
|
'ap_11': 'Linux i686', |
|
|
@ -1414,16 +1437,15 @@ class AdobePassIE(InfoExtractor): |
|
|
|
if '<form name="signin"' in provider_redirect_page: |
|
|
|
provider_login_page_res = provider_redirect_page_res |
|
|
|
elif 'http-equiv="refresh"' in provider_redirect_page: |
|
|
|
oauth_redirect_url = self._html_search_regex( |
|
|
|
r'content="0;\s*url=([^\'"]+)', |
|
|
|
provider_redirect_page, 'meta refresh redirect') |
|
|
|
oauth_redirect_url = extract_redirect_url( |
|
|
|
provider_redirect_page, fatal=True) |
|
|
|
provider_login_page_res = self._download_webpage_handle( |
|
|
|
oauth_redirect_url, video_id, |
|
|
|
'Downloading Provider Login Page') |
|
|
|
self._DOWNLOADING_LOGIN_PAGE) |
|
|
|
else: |
|
|
|
provider_login_page_res = post_form( |
|
|
|
provider_redirect_page_res, |
|
|
|
'Downloading Provider Login Page') |
|
|
|
self._DOWNLOADING_LOGIN_PAGE) |
|
|
|
|
|
|
|
mvpd_confirm_page_res = post_form( |
|
|
|
provider_login_page_res, 'Logging in', { |
|
|
@ -1470,8 +1492,17 @@ class AdobePassIE(InfoExtractor): |
|
|
|
'Content-Type': 'application/x-www-form-urlencoded' |
|
|
|
}) |
|
|
|
else: |
|
|
|
# Some providers (e.g. DIRECTV NOW) have another meta refresh |
|
|
|
# based redirect that should be followed. |
|
|
|
provider_redirect_page, urlh = provider_redirect_page_res |
|
|
|
provider_refresh_redirect_url = extract_redirect_url( |
|
|
|
provider_redirect_page, url=urlh.geturl()) |
|
|
|
if provider_refresh_redirect_url: |
|
|
|
provider_redirect_page_res = self._download_webpage_handle( |
|
|
|
provider_refresh_redirect_url, video_id, |
|
|
|
'Downloading Provider Redirect Page (meta refresh)') |
|
|
|
provider_login_page_res = post_form( |
|
|
|
provider_redirect_page_res, 'Downloading Provider Login Page') |
|
|
|
provider_redirect_page_res, self._DOWNLOADING_LOGIN_PAGE) |
|
|
|
mvpd_confirm_page_res = post_form(provider_login_page_res, 'Logging in', { |
|
|
|
mso_info.get('username_field', 'username'): username, |
|
|
|
mso_info.get('password_field', 'password'): password, |
|
|
|