mirror of
https://github.com/yt-dlp/yt-dlp.git
synced 2026-05-10 01:16:22 +00:00
Compare commits
No commits in common. "20be1c0fffc75a9c25eff622877c053cd0e9080a" and "9df297ca910311d60e21549b06aa42ca059d3c94" have entirely different histories.
20be1c0fff
...
9df297ca91
@ -41,22 +41,18 @@ class NiconicoBaseIE(InfoExtractor):
|
|||||||
_LOGIN_BASE = 'https://account.nicovideo.jp'
|
_LOGIN_BASE = 'https://account.nicovideo.jp'
|
||||||
_NETRC_MACHINE = 'niconico'
|
_NETRC_MACHINE = 'niconico'
|
||||||
|
|
||||||
@property
|
def raise_login_error(self, error, default, expected=True):
|
||||||
def is_logged_in(self):
|
|
||||||
return bool(self._get_cookies('https://www.nicovideo.jp').get('user_session'))
|
|
||||||
|
|
||||||
def _raise_login_error(self, error, default, expected=True):
|
|
||||||
raise ExtractorError(f'Unable to login: {error or default}', expected=expected)
|
raise ExtractorError(f'Unable to login: {error or default}', expected=expected)
|
||||||
|
|
||||||
def _perform_login(self, username, password):
|
def _perform_login(self, username, password):
|
||||||
if self.is_logged_in:
|
if self._get_cookies('https://www.nicovideo.jp').get('user_session'):
|
||||||
return
|
return
|
||||||
|
|
||||||
self._request_webpage(
|
self._request_webpage(
|
||||||
f'{self._LOGIN_BASE}/login', None, 'Requesting session cookies')
|
f'{self._LOGIN_BASE}/login', None, 'Requesting session cookies')
|
||||||
webpage = self._download_webpage(
|
webpage = self._download_webpage(
|
||||||
f'{self._LOGIN_BASE}/login/redirector', None,
|
f'{self._LOGIN_BASE}/login/redirector', None,
|
||||||
'Logging in', 'Unable to log in', headers={
|
'Logging in', headers={
|
||||||
'Content-Type': 'application/x-www-form-urlencoded',
|
'Content-Type': 'application/x-www-form-urlencoded',
|
||||||
'Referer': f'{self._LOGIN_BASE}/login',
|
'Referer': f'{self._LOGIN_BASE}/login',
|
||||||
}, data=urlencode_postdata({
|
}, data=urlencode_postdata({
|
||||||
@ -64,13 +60,17 @@ class NiconicoBaseIE(InfoExtractor):
|
|||||||
'password': password,
|
'password': password,
|
||||||
}),
|
}),
|
||||||
)
|
)
|
||||||
if self.is_logged_in:
|
|
||||||
|
if traverse_obj(self._search_json(
|
||||||
|
r'NicoGoogleTagManagerDataLayer\s*=\s*\[',
|
||||||
|
webpage, 'data layer', None, fatal=False,
|
||||||
|
), ('user', 'login_status', {lambda x: x == 'login'})):
|
||||||
return
|
return
|
||||||
|
|
||||||
if err_msg := traverse_obj(webpage, (
|
if err_msg := traverse_obj(webpage, (
|
||||||
{find_element(cls='notice error')}, {find_element(cls='notice__text')}, {clean_html},
|
{find_element(cls='notice error')}, {find_element(cls='notice__text')}, {clean_html},
|
||||||
)):
|
)):
|
||||||
self._raise_login_error(err_msg, 'Invalid username or password')
|
self.raise_login_error(err_msg, 'Invalid username or password')
|
||||||
elif 'oneTimePw' in webpage:
|
elif 'oneTimePw' in webpage:
|
||||||
post_url = self._search_regex(
|
post_url = self._search_regex(
|
||||||
r'<form[^>]+action=(["\'])(?P<url>.+?)\1', webpage, 'post url', group='url')
|
r'<form[^>]+action=(["\'])(?P<url>.+?)\1', webpage, 'post url', group='url')
|
||||||
@ -84,14 +84,15 @@ class NiconicoBaseIE(InfoExtractor):
|
|||||||
)
|
)
|
||||||
|
|
||||||
if 'error-code' in parse_qs(urlh.url):
|
if 'error-code' in parse_qs(urlh.url):
|
||||||
err_msg = traverse_obj(mfa, ({find_element(cls='pageMainMsg')}, {clean_html}))
|
err_msg = traverse_obj(self._download_webpage(urlh.url, None), (
|
||||||
self._raise_login_error(err_msg, 'MFA session expired')
|
{find_element(cls='pageMainMsg')}, {clean_html}))
|
||||||
|
self.raise_login_error(err_msg, 'MFA session expired')
|
||||||
if 'formError' in mfa:
|
if 'formError' in mfa:
|
||||||
err_msg = traverse_obj(mfa, (
|
err_msg = traverse_obj(mfa, (
|
||||||
{find_element(cls='formError')}, {find_element(tag='div')}, {clean_html}))
|
{find_element(cls='formError')}, {find_element(tag='div')}, {clean_html}))
|
||||||
self._raise_login_error(err_msg, 'MFA challenge failed')
|
self.raise_login_error(err_msg, 'MFA challenge failed')
|
||||||
else:
|
else:
|
||||||
self._raise_login_error(None, 'Unexpected login error', expected=False)
|
self.raise_login_error(None, 'Unexpected login error', expected=False)
|
||||||
|
|
||||||
|
|
||||||
class NiconicoIE(NiconicoBaseIE):
|
class NiconicoIE(NiconicoBaseIE):
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user