diff options
| -rw-r--r-- | test/test_all_urls.py | 1 | ||||
| -rw-r--r-- | youtube_dl/extractor/__init__.py | 1 | ||||
| -rw-r--r-- | youtube_dl/extractor/youtube.py | 14 | 
3 files changed, 16 insertions, 0 deletions
| diff --git a/test/test_all_urls.py b/test/test_all_urls.py index 56e5f80e1..42813da1a 100644 --- a/test/test_all_urls.py +++ b/test/test_all_urls.py @@ -100,6 +100,7 @@ class TestAllURLsMatching(unittest.TestCase):      def test_keywords(self):          self.assertMatch(':ytsubs', ['youtube:subscriptions'])          self.assertMatch(':ytsubscriptions', ['youtube:subscriptions']) +        self.assertMatch(':ythistory', ['youtube:history'])          self.assertMatch(':thedailyshow', ['ComedyCentral'])          self.assertMatch(':tds', ['ComedyCentral'])          self.assertMatch(':colbertreport', ['ComedyCentral']) diff --git a/youtube_dl/extractor/__init__.py b/youtube_dl/extractor/__init__.py index 4c280fa5e..1fbd10bc5 100644 --- a/youtube_dl/extractor/__init__.py +++ b/youtube_dl/extractor/__init__.py @@ -186,6 +186,7 @@ from .youtube import (      YoutubeTruncatedURLIE,      YoutubeWatchLaterIE,      YoutubeFavouritesIE, +    YoutubeHistoryIE,  )  from .zdf import ZDFIE diff --git a/youtube_dl/extractor/youtube.py b/youtube_dl/extractor/youtube.py index 07a457f4d..64d4c2445 100644 --- a/youtube_dl/extractor/youtube.py +++ b/youtube_dl/extractor/youtube.py @@ -1826,6 +1826,20 @@ class YoutubeWatchLaterIE(YoutubeFeedsInfoExtractor):      _PAGING_STEP = 100      _PERSONAL_FEED = True +class YoutubeHistoryIE(YoutubeFeedsInfoExtractor): +    IE_DESC = u'Youtube watch history, "ythistory" keyword (requires authentication)' +    _VALID_URL = u'https?://www\.youtube\.com/feed/history|:ythistory' +    _FEED_NAME = 'history' +    _PERSONAL_FEED = True +    _PLAYLIST_TITLE = u'Youtube Watch History' + +    def _real_extract(self, url): +        webpage = self._download_webpage('https://www.youtube.com/feed/history', u'History') +        data_paging = self._search_regex(r'data-paging="(\d+)"', webpage, u'data-paging') +        # The step is actually a ridiculously big number (like 1374343569725646) +        self._PAGING_STEP = int(data_paging) +        return super(YoutubeHistoryIE, self)._real_extract(url) +  class YoutubeFavouritesIE(YoutubeBaseInfoExtractor):      IE_NAME = u'youtube:favorites'      IE_DESC = u'YouTube.com favourite videos, "ytfav" keyword (requires authentication)' | 
