mirror of
https://github.com/l1ving/youtube-dl
synced 2024-12-30 22:32:50 +08:00
[udemy] Generalize download json and fix login
This commit is contained in:
parent
81a7a521c5
commit
61c0663c1e
@ -40,12 +40,7 @@ class UdemyIE(InfoExtractor):
|
|||||||
error_str += ' - %s' % error_data.get('formErrors')
|
error_str += ' - %s' % error_data.get('formErrors')
|
||||||
raise ExtractorError(error_str, expected=True)
|
raise ExtractorError(error_str, expected=True)
|
||||||
|
|
||||||
def _download_json(self, url, video_id, note='Downloading JSON metadata'):
|
def _download_json(self, url_or_request, video_id, note='Downloading JSON metadata'):
|
||||||
response = super(UdemyIE, self)._download_json(url, video_id, note)
|
|
||||||
self._handle_error(response)
|
|
||||||
return response
|
|
||||||
|
|
||||||
def _download_json_cookies(self, url, video_id, note):
|
|
||||||
headers = {
|
headers = {
|
||||||
'X-Udemy-Snail-Case': 'true',
|
'X-Udemy-Snail-Case': 'true',
|
||||||
'X-Requested-With': 'XMLHttpRequest',
|
'X-Requested-With': 'XMLHttpRequest',
|
||||||
@ -55,8 +50,16 @@ class UdemyIE(InfoExtractor):
|
|||||||
headers['X-Udemy-Client-Id'] = cookie.value
|
headers['X-Udemy-Client-Id'] = cookie.value
|
||||||
elif cookie.name == 'access_token':
|
elif cookie.name == 'access_token':
|
||||||
headers['X-Udemy-Bearer-Token'] = cookie.value
|
headers['X-Udemy-Bearer-Token'] = cookie.value
|
||||||
request = compat_urllib_request.Request(url, headers=headers)
|
|
||||||
return self._download_json(request, video_id, note)
|
if isinstance(url_or_request, compat_urllib_request.Request):
|
||||||
|
for header, value in headers.items():
|
||||||
|
url_or_request.add_header(header, value)
|
||||||
|
else:
|
||||||
|
url_or_request = compat_urllib_request.Request(url_or_request, headers=headers)
|
||||||
|
|
||||||
|
response = super(UdemyIE, self)._download_json(url_or_request, video_id, note)
|
||||||
|
self._handle_error(response)
|
||||||
|
return response
|
||||||
|
|
||||||
def _real_initialize(self):
|
def _real_initialize(self):
|
||||||
self._login()
|
self._login()
|
||||||
@ -87,7 +90,7 @@ class UdemyIE(InfoExtractor):
|
|||||||
'isSubmitted': '1',
|
'isSubmitted': '1',
|
||||||
}
|
}
|
||||||
request = compat_urllib_request.Request(
|
request = compat_urllib_request.Request(
|
||||||
self._LOGIN_URL, compat_urllib_parse.urlencode(login_form))
|
self._LOGIN_URL, compat_urllib_parse.urlencode(login_form).encode('utf-8'))
|
||||||
response = self._download_json(
|
response = self._download_json(
|
||||||
request, None, 'Logging in as %s' % username)
|
request, None, 'Logging in as %s' % username)
|
||||||
|
|
||||||
@ -100,7 +103,7 @@ class UdemyIE(InfoExtractor):
|
|||||||
mobj = re.match(self._VALID_URL, url)
|
mobj = re.match(self._VALID_URL, url)
|
||||||
lecture_id = mobj.group('id')
|
lecture_id = mobj.group('id')
|
||||||
|
|
||||||
lecture = self._download_json_cookies(
|
lecture = self._download_json(
|
||||||
'https://www.udemy.com/api-1.1/lectures/%s' % lecture_id,
|
'https://www.udemy.com/api-1.1/lectures/%s' % lecture_id,
|
||||||
lecture_id, 'Downloading lecture JSON')
|
lecture_id, 'Downloading lecture JSON')
|
||||||
|
|
||||||
@ -164,7 +167,7 @@ class UdemyCourseIE(UdemyIE):
|
|||||||
mobj = re.match(self._VALID_URL, url)
|
mobj = re.match(self._VALID_URL, url)
|
||||||
course_path = mobj.group('coursepath')
|
course_path = mobj.group('coursepath')
|
||||||
|
|
||||||
response = self._download_json_cookies(
|
response = self._download_json(
|
||||||
'https://www.udemy.com/api-1.1/courses/%s' % course_path,
|
'https://www.udemy.com/api-1.1/courses/%s' % course_path,
|
||||||
course_path, 'Downloading course JSON')
|
course_path, 'Downloading course JSON')
|
||||||
|
|
||||||
@ -180,7 +183,7 @@ class UdemyCourseIE(UdemyIE):
|
|||||||
elif self._ALREADY_ENROLLED in webpage:
|
elif self._ALREADY_ENROLLED in webpage:
|
||||||
self.to_screen('%s: Already enrolled in' % course_id)
|
self.to_screen('%s: Already enrolled in' % course_id)
|
||||||
|
|
||||||
response = self._download_json_cookies(
|
response = self._download_json(
|
||||||
'https://www.udemy.com/api-1.1/courses/%s/curriculum' % course_id,
|
'https://www.udemy.com/api-1.1/courses/%s/curriculum' % course_id,
|
||||||
course_id, 'Downloading course curriculum')
|
course_id, 'Downloading course curriculum')
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user