Compare commits

..

No commits in common. "2e0576378c08819d4966799dc6457a0b06894b03" and "a06d4283df4f5197640b6562be11c5c66c332478" have entirely different histories.

View File

@ -1,14 +1,7 @@
import json
from .common import InfoExtractor
from ..utils import (
ExtractorError,
int_or_none,
parse_qs,
traverse_obj,
update_url_query,
urlencode_postdata,
)
from ..utils import int_or_none, traverse_obj, urlencode_postdata, parse_qs, ExtractorError, update_url_query
class PlaySuisseIE(InfoExtractor):
@ -142,8 +135,6 @@ class PlaySuisseIE(InfoExtractor):
id
url
}'''
_LOGIN_BASE_URL = 'https://login.srgssr.ch/srgssrlogin.onmicrosoft.com'
_LOGIN_PATH = 'B2C_1A__SignInV2'
_ID_TOKEN = None
def _perform_login(self, username, password):
@ -152,31 +143,21 @@ class PlaySuisseIE(InfoExtractor):
query={'x': 'x', 'locale': 'de', 'redirectUrl': 'https://www.playsuisse.ch/'})
settings = self._search_json(r'var\s+SETTINGS\s*=', login_page, 'settings', None)
csrf_token = settings['csrf']
query = {'tx': settings['transId'], 'p': self._LOGIN_PATH}
webpage, urlh = self._download_webpage_handle(
'https://login.srgssr.ch/srgssrlogin.onmicrosoft.com/B2C_1A__SignInV2/SelfAsserted',
None, note='Logging in', headers={'X-CSRF-TOKEN': settings['csrf']},
data=urlencode_postdata({'request_type': 'RESPONSE', 'signInName': username, 'password': password}),
query={'tx': settings['transId'], 'p': 'B2C_1A__SignInV2'})
status = traverse_obj(self._download_json(
f'{self._LOGIN_BASE_URL}/{self._LOGIN_PATH}/SelfAsserted', None, 'Logging in',
query=query, headers={'X-CSRF-TOKEN': csrf_token}, data=urlencode_postdata({
'request_type': 'RESPONSE',
'signInName': username,
'password': password
}), expected_status=400), ('status', {int_or_none}))
if status == 400:
raise ExtractorError('Invalid username or password', expected=True)
webpage, urlh = self._download_webpage_handle(
'https://login.srgssr.ch/srgssrlogin.onmicrosoft.com/B2C_1A__SignInV2/api/CombinedSigninAndSignup/confirmed',
None, note='Downloading ID token',
query={'rememberMe': 'false', 'csrf_token': settings['csrf'], 'tx': settings['transId'], 'p': 'B2C_1A__SignInV2', 'diags': ''})
urlh = self._request_webpage(
f'{self._LOGIN_BASE_URL}/{self._LOGIN_PATH}/api/CombinedSigninAndSignup/confirmed',
None, 'Downloading ID token', query={
'rememberMe': 'false',
'csrf_token': csrf_token,
**query,
'diags': '',
})
self._ID_TOKEN = traverse_obj(parse_qs(urlh.url), ('id_token', 0))
if not self._ID_TOKEN:
raise ExtractorError('Login failed')
query = parse_qs(urlh.url)
if 'id_token' not in query:
raise ExtractorError("Login failed")
self._ID_TOKEN = query['id_token'][0]
def _get_media_data(self, media_id):
# NOTE In the web app, the "locale" header is used to switch between languages,
@ -194,7 +175,7 @@ class PlaySuisseIE(InfoExtractor):
def _real_extract(self, url):
if not self._ID_TOKEN:
self.raise_login_required(method='password')
self.raise_login_required()
media_id = self._match_id(url)
media_data = self._get_media_data(media_id)