diff options
Diffstat (limited to 'youtube_dl/extractor/nick.py')
| -rw-r--r-- | youtube_dl/extractor/nick.py | 29 | 
1 files changed, 28 insertions, 1 deletions
diff --git a/youtube_dl/extractor/nick.py b/youtube_dl/extractor/nick.py index ce065f2b0..4935002d0 100644 --- a/youtube_dl/extractor/nick.py +++ b/youtube_dl/extractor/nick.py @@ -3,11 +3,12 @@ from __future__ import unicode_literals  from .mtv import MTVServicesInfoExtractor  from ..compat import compat_urllib_parse_urlencode +from ..utils import update_url_query  class NickIE(MTVServicesInfoExtractor):      IE_NAME = 'nick.com' -    _VALID_URL = r'https?://(?:www\.)?nick\.com/videos/clip/(?P<id>[^/?#.]+)' +    _VALID_URL = r'https?://(?:www\.)?nick(?:jr)?\.com/(?:videos/clip|[^/]+/videos)/(?P<id>[^/?#.]+)'      _FEED_URL = 'http://udat.mtvnservices.com/service1/dispatch.htm'      _TESTS = [{          'url': 'http://www.nick.com/videos/clip/alvinnn-and-the-chipmunks-112-full-episode.html', @@ -51,6 +52,9 @@ class NickIE(MTVServicesInfoExtractor):                  }              },          ], +    }, { +        'url': 'http://www.nickjr.com/paw-patrol/videos/pups-save-a-goldrush-s3-ep302-full-episode/', +        'only_matching': True,      }]      def _get_feed_query(self, uri): @@ -61,3 +65,26 @@ class NickIE(MTVServicesInfoExtractor):      def _extract_mgid(self, webpage):          return self._search_regex(r'data-contenturi="([^"]+)', webpage, 'mgid') + + +class NickDeIE(MTVServicesInfoExtractor): +    IE_NAME = 'nick.de' +    _VALID_URL = r'https?://(?:www\.)?nick\.de/(?:playlist|shows)/(?:[^/]+/)*(?P<id>[^/?#&]+)' +    _TESTS = [{ +        'url': 'http://www.nick.de/playlist/3773-top-videos/videos/episode/17306-zu-wasser-und-zu-land-rauchende-erdnusse', +        'only_matching': True, +    }, { +        'url': 'http://www.nick.de/shows/342-icarly', +        'only_matching': True, +    }] + +    def _real_extract(self, url): +        video_id = self._match_id(url) + +        webpage = self._download_webpage(url, video_id) + +        mrss_url = update_url_query(self._search_regex( +            r'data-mrss=(["\'])(?P<url>http.+?)\1', webpage, 'mrss url', group='url'), +            {'siteKey': 'nick.de'}) + +        return self._get_videos_info_from_url(mrss_url, video_id)  | 
