diff options
| author | Viren Rajput <virendra.rajput567@gmail.com> | 2021-02-01 04:56:33 +0000 | 
|---|---|---|
| committer | Remita Amine <remitamine@gmail.com> | 2021-02-02 19:00:36 +0100 | 
| commit | 0e3a9684795c6c53546dace9e917ed11c4ae72a5 (patch) | |
| tree | 9daf90b5c066433f5bbd3c08bc2ab9857ebce5eb /youtube_dl/extractor/egghead.py | |
| parent | c11f7cf9bd6ef239f25e7fb9c54e092ae1490e2d (diff) | |
[egghead] update API domain(closes #28038)
Diffstat (limited to 'youtube_dl/extractor/egghead.py')
| -rw-r--r-- | youtube_dl/extractor/egghead.py | 29 | 
1 files changed, 17 insertions, 12 deletions
| diff --git a/youtube_dl/extractor/egghead.py b/youtube_dl/extractor/egghead.py index df11dc206..94dd75b9b 100644 --- a/youtube_dl/extractor/egghead.py +++ b/youtube_dl/extractor/egghead.py @@ -12,7 +12,14 @@ from ..utils import (  ) -class EggheadCourseIE(InfoExtractor): +class EggheadBaseIE(InfoExtractor): +    def _call_api(self, path, video_id, resource, fatal=True): +        return self._download_json( +            'https://app.egghead.io/api/v1/' + path, +            video_id, 'Downloading %s JSON' % resource) + + +class EggheadCourseIE(EggheadBaseIE):      IE_DESC = 'egghead.io course'      IE_NAME = 'egghead:course'      _VALID_URL = r'https://egghead\.io/courses/(?P<id>[^/?#&]+)' @@ -28,10 +35,9 @@ class EggheadCourseIE(InfoExtractor):      def _real_extract(self, url):          playlist_id = self._match_id(url) - -        lessons = self._download_json( -            'https://egghead.io/api/v1/series/%s/lessons' % playlist_id, -            playlist_id, 'Downloading course lessons JSON') +        series_path = 'series/' + playlist_id +        lessons = self._call_api( +            series_path + '/lessons', playlist_id, 'course lessons')          entries = []          for lesson in lessons: @@ -44,9 +50,8 @@ class EggheadCourseIE(InfoExtractor):              entries.append(self.url_result(                  lesson_url, ie=EggheadLessonIE.ie_key(), video_id=lesson_id)) -        course = self._download_json( -            'https://egghead.io/api/v1/series/%s' % playlist_id, -            playlist_id, 'Downloading course JSON', fatal=False) or {} +        course = self._call_api( +            series_path, playlist_id, 'course', False) or {}          playlist_id = course.get('id')          if playlist_id: @@ -57,7 +62,7 @@ class EggheadCourseIE(InfoExtractor):              course.get('description')) -class EggheadLessonIE(InfoExtractor): +class EggheadLessonIE(EggheadBaseIE):      IE_DESC = 'egghead.io lesson'      IE_NAME = 'egghead:lesson'      _VALID_URL = r'https://egghead\.io/(?:api/v1/)?lessons/(?P<id>[^/?#&]+)' @@ -74,7 +79,7 @@ class EggheadLessonIE(InfoExtractor):              'upload_date': '20161209',              'duration': 304,              'view_count': 0, -            'tags': ['javascript', 'free'], +            'tags': ['free', 'javascript'],          },          'params': {              'skip_download': True, @@ -88,8 +93,8 @@ class EggheadLessonIE(InfoExtractor):      def _real_extract(self, url):          display_id = self._match_id(url) -        lesson = self._download_json( -            'https://egghead.io/api/v1/lessons/%s' % display_id, display_id) +        lesson = self._call_api( +            'lessons/' + display_id, display_id, 'lesson')          lesson_id = compat_str(lesson['id'])          title = lesson['title'] | 
