mirror of
https://github.com/ytdl-org/youtube-dl
synced 2024-12-23 04:30:10 +09:00
[toutv] fix authentication(closes #20261)
This commit is contained in:
parent
fca9baf0da
commit
829685b88a
@ -1,14 +1,12 @@
|
|||||||
# coding: utf-8
|
# coding: utf-8
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
import re
|
import json
|
||||||
|
|
||||||
from .radiocanada import RadioCanadaIE
|
from .radiocanada import RadioCanadaIE
|
||||||
from ..utils import (
|
from ..utils import (
|
||||||
extract_attributes,
|
|
||||||
int_or_none,
|
int_or_none,
|
||||||
merge_dicts,
|
merge_dicts,
|
||||||
urlencode_postdata,
|
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
@ -38,47 +36,24 @@ class TouTvIE(RadioCanadaIE):
|
|||||||
'url': 'https://ici.tou.tv/l-age-adulte/S01C501',
|
'url': 'https://ici.tou.tv/l-age-adulte/S01C501',
|
||||||
'only_matching': True,
|
'only_matching': True,
|
||||||
}]
|
}]
|
||||||
|
_CLIENT_KEY = '4dd36440-09d5-4468-8923-b6d91174ad36'
|
||||||
|
|
||||||
def _real_initialize(self):
|
def _real_initialize(self):
|
||||||
email, password = self._get_login_info()
|
email, password = self._get_login_info()
|
||||||
if email is None:
|
if email is None:
|
||||||
return
|
return
|
||||||
login_webpage = self._download_webpage(
|
self._access_token = self._download_json(
|
||||||
'https://services.radio-canada.ca/auth/oauth/v2/authorize',
|
'https://services.radio-canada.ca/toutv/profiling/accounts/login',
|
||||||
None, 'Downloading login page', query={
|
None, 'Logging in', data=json.dumps({
|
||||||
'client_id': '4dd36440-09d5-4468-8923-b6d91174ad36',
|
'ClientId': self._CLIENT_KEY,
|
||||||
'redirect_uri': 'https://ici.tou.tv/logincallback',
|
'ClientSecret': '34026772-244b-49b6-8b06-317b30ac9a20',
|
||||||
'response_type': 'token',
|
'Email': email,
|
||||||
'scope': 'id.write media-validation.read',
|
'Password': password,
|
||||||
'state': '/',
|
'Scope': 'id.write media-validation.read',
|
||||||
})
|
}).encode(), headers={
|
||||||
|
'Authorization': 'client-key ' + self._CLIENT_KEY,
|
||||||
def extract_form_url_and_data(wp, default_form_url, form_spec_re=''):
|
'Content-Type': 'application/json;charset=utf-8',
|
||||||
form, form_elem = re.search(
|
})['access_token']
|
||||||
r'(?s)((<form[^>]+?%s[^>]*?>).+?</form>)' % form_spec_re, wp).groups()
|
|
||||||
form_data = self._hidden_inputs(form)
|
|
||||||
form_url = extract_attributes(form_elem).get('action') or default_form_url
|
|
||||||
return form_url, form_data
|
|
||||||
|
|
||||||
post_url, form_data = extract_form_url_and_data(
|
|
||||||
login_webpage,
|
|
||||||
'https://services.radio-canada.ca/auth/oauth/v2/authorize/login',
|
|
||||||
r'(?:id|name)="Form-login"')
|
|
||||||
form_data.update({
|
|
||||||
'login-email': email,
|
|
||||||
'login-password': password,
|
|
||||||
})
|
|
||||||
consent_webpage = self._download_webpage(
|
|
||||||
post_url, None, 'Logging in', data=urlencode_postdata(form_data))
|
|
||||||
post_url, form_data = extract_form_url_and_data(
|
|
||||||
consent_webpage,
|
|
||||||
'https://services.radio-canada.ca/auth/oauth/v2/authorize/consent')
|
|
||||||
_, urlh = self._download_webpage_handle(
|
|
||||||
post_url, None, 'Following Redirection',
|
|
||||||
data=urlencode_postdata(form_data))
|
|
||||||
self._access_token = self._search_regex(
|
|
||||||
r'access_token=([\da-f]{8}-[\da-f]{4}-[\da-f]{4}-[\da-f]{4}-[\da-f]{12})',
|
|
||||||
urlh.geturl(), 'access token')
|
|
||||||
self._claims = self._call_api('validation/v2/getClaims')['claims']
|
self._claims = self._call_api('validation/v2/getClaims')['claims']
|
||||||
|
|
||||||
def _real_extract(self, url):
|
def _real_extract(self, url):
|
||||||
|
Loading…
Reference in New Issue
Block a user