mirror of
https://github.com/yt-dlp/yt-dlp.git
synced 2025-03-09 12:50:23 -05:00
fix
This commit is contained in:
parent
010a938835
commit
cf44d850ac
1 changed files with 32 additions and 23 deletions
|
@ -28,7 +28,6 @@
|
|||
|
||||
class NicoChannelCommonBaseIE(InfoExtractor):
|
||||
_SITE_SETTINGS = {}
|
||||
_DOMAIN_SITE_ID = {}
|
||||
|
||||
def _get_jwt_token(self, url):
|
||||
pass
|
||||
|
@ -64,30 +63,19 @@ def _download_api_json(self, site_url, path, video_id, headers={}, **kwargs):
|
|||
f'{settings["api_base_url"]}{path}', video_id, headers=headers, expected_status=403, **kwargs)
|
||||
if handle.status == 403:
|
||||
if not self._get_jwt_token(site_url):
|
||||
self.raise_login_required(expected=True)
|
||||
self.raise_login_required()
|
||||
raise ExtractorError('You may have no access to this video')
|
||||
return data
|
||||
|
||||
def _get_fanclub_site_id(self, url):
|
||||
settings = self._get_settings(url)
|
||||
if settings['platform_id'] == 'SHTA':
|
||||
return str(settings['fanclub_site_id'])
|
||||
else:
|
||||
parsed = urllib.parse.urlparse(url)
|
||||
# parsed.path starts with '/', so index 0 is empty string
|
||||
domain_url = f'{parsed.scheme}://{parsed.netloc}/{parsed.path.split("/")[1].lower()}'
|
||||
if domain_url not in self._DOMAIN_SITE_ID:
|
||||
self._DOMAIN_SITE_ID[domain_url] = str(self._download_api_json(
|
||||
url, '/content_providers/channel_domain', domain_url,
|
||||
query={'current_site_domain': domain_url})['data']['content_providers']['id'])
|
||||
return self._DOMAIN_SITE_ID[domain_url]
|
||||
|
||||
|
||||
class NicoChannelAuthBaseIE(NicoChannelCommonBaseIE):
|
||||
_AUTH_SETTINGS = {}
|
||||
_AUTH_TOKENS = {}
|
||||
_netrc_domain: str
|
||||
|
||||
def supports_login(self):
|
||||
return True
|
||||
|
||||
def _get_auth(self, url) -> dict:
|
||||
return self._AUTH_TOKENS.get(urljoin(url, '/'), {})
|
||||
|
||||
|
@ -98,16 +86,15 @@ def _set_auth(self, url, auth):
|
|||
def has_attempted_login(self):
|
||||
return getattr(self, '_netrc_domain', None) is not None
|
||||
|
||||
def _login_hint(self, **kwargs):
|
||||
def _login_hint(self, *args, **kwargs):
|
||||
return super()._login_hint('password', netrc=getattr(self, '_netrc_domain', None))
|
||||
|
||||
def _get_auth_settings(self, url):
|
||||
fanclub_site_id = self._get_fanclub_site_id(url)
|
||||
fanclub_site_id = self._get_settings(url)['fanclub_site_id']
|
||||
if fanclub_site_id not in self._AUTH_SETTINGS:
|
||||
self._AUTH_SETTINGS[fanclub_site_id] = traverse_obj(self._download_api_json(
|
||||
url, f'/fanclub_sites/{fanclub_site_id}/login', fanclub_site_id,
|
||||
note='Downloading auth settings'), ('data', 'fanclub_site', {
|
||||
'auth0_app_client': ('auth0_app_client_id', {str}),
|
||||
'auth0_web_client': ('auth0_web_client_id', {str}),
|
||||
'auth0_domain': ('fanclub_group', 'auth0_domain', {str}),
|
||||
}))
|
||||
|
@ -115,11 +102,18 @@ def _get_auth_settings(self, url):
|
|||
|
||||
def _get_jwt_token(self, url):
|
||||
if not self.has_attempted_login:
|
||||
self._perform_sheeta_login(url)
|
||||
try:
|
||||
self._perform_sheeta_login(url)
|
||||
except Exception as e:
|
||||
self.report_warning(f'Failed to login, continuing without login: {e}')
|
||||
|
||||
if access_token := self._get_auth(url).get('access_token'):
|
||||
if jwt_decode_hs256(access_token)['exp'] < time.time() + 15:
|
||||
self._refresh_sheeta_token(url)
|
||||
try:
|
||||
self._refresh_sheeta_token(url)
|
||||
except Exception as e:
|
||||
self.report_warning(f'Failed to refresh token: {e}')
|
||||
self._perform_sheeta_login(url)
|
||||
return self._get_auth(url)['access_token']
|
||||
|
||||
if jwt_args := self._configuration_arg('jwt_token', ie_key='niconicochannelplus', casesense=True):
|
||||
|
@ -172,11 +166,11 @@ def _random_string():
|
|||
'auth0Client': self._auth0_client,
|
||||
}
|
||||
|
||||
webpage, handler = self._download_webpage_handle(
|
||||
_, handler = self._download_webpage_handle(
|
||||
f'https://{auth_settings["auth0_domain"]}/authorize', 'preauth', query=preauth_query)
|
||||
|
||||
_, handler = self._download_webpage_handle(handler.url, 'login', data=urlencode_postdata({
|
||||
**self._hidden_inputs(webpage),
|
||||
'state': parse_qs(handler.url)['state'][0],
|
||||
'username': username,
|
||||
'password': password,
|
||||
'action': 'default',
|
||||
|
@ -234,6 +228,7 @@ def _refresh_sheeta_token(self, url):
|
|||
class NiconicoChannelPlusBaseIE(NicoChannelAuthBaseIE):
|
||||
_CHANNEL_NAMES = {}
|
||||
_CHANNEL_AGE_LIMIT = {}
|
||||
_DOMAIN_SITE_ID = {}
|
||||
|
||||
def _get_channel_id(self, url):
|
||||
parsed = urllib.parse.urlparse(url)
|
||||
|
@ -244,6 +239,20 @@ def _get_channel_id(self, url):
|
|||
else:
|
||||
return f'{parsed.hostname.replace(".", "_")}_{parsed.path.split("/")[1]}'
|
||||
|
||||
def _get_fanclub_site_id(self, url):
|
||||
settings = self._get_settings(url)
|
||||
if settings['platform_id'] == 'SHTA':
|
||||
return str(settings['fanclub_site_id'])
|
||||
else:
|
||||
parsed = urllib.parse.urlparse(url)
|
||||
# parsed.path starts with '/', so index 0 is empty string
|
||||
domain_url = f'{parsed.scheme}://{parsed.netloc}/{parsed.path.split("/")[1].lower()}'
|
||||
if domain_url not in self._DOMAIN_SITE_ID:
|
||||
self._DOMAIN_SITE_ID[domain_url] = str(self._download_api_json(
|
||||
url, '/content_providers/channel_domain', domain_url,
|
||||
query={'current_site_domain': domain_url})['data']['content_providers']['id'])
|
||||
return self._DOMAIN_SITE_ID[domain_url]
|
||||
|
||||
def _get_channel_url(self, url):
|
||||
parsed = urllib.parse.urlparse(url)
|
||||
if self._get_settings(url)['platform_id'] == 'SHTA':
|
||||
|
|
Loading…
Reference in a new issue