diff options
Diffstat (limited to 'youtube_dl/extractor')
| -rw-r--r-- | youtube_dl/extractor/extractors.py | 1 | ||||
| -rw-r--r-- | youtube_dl/extractor/funk.py | 43 | ||||
| -rw-r--r-- | youtube_dl/extractor/generic.py | 16 | 
3 files changed, 44 insertions, 16 deletions
| diff --git a/youtube_dl/extractor/extractors.py b/youtube_dl/extractor/extractors.py index 5629c7623..ecb33bc9e 100644 --- a/youtube_dl/extractor/extractors.py +++ b/youtube_dl/extractor/extractors.py @@ -381,6 +381,7 @@ from .freesound import FreesoundIE  from .freespeech import FreespeechIE  from .freshlive import FreshLiveIE  from .funimation import FunimationIE +from .funk import FunkIE  from .funnyordie import FunnyOrDieIE  from .fusion import FusionIE  from .fxnetworks import FXNetworksIE diff --git a/youtube_dl/extractor/funk.py b/youtube_dl/extractor/funk.py new file mode 100644 index 000000000..ce5c67fbb --- /dev/null +++ b/youtube_dl/extractor/funk.py @@ -0,0 +1,43 @@ +# coding: utf-8 +from __future__ import unicode_literals + +from .common import InfoExtractor +from .nexx import NexxIE +from ..utils import extract_attributes + + +class FunkIE(InfoExtractor): +    _VALID_URL = r'https?://(?:www\.)?funk\.net/(?:mix|channel)/(?:[^/]+/)*(?P<id>[^?/#]+)' +    _TESTS = [{ +        'url': 'https://www.funk.net/mix/59d65d935f8b160001828b5b/0/59d517e741dca10001252574/', +        'md5': '4d40974481fa3475f8bccfd20c5361f8', +        'info_dict': { +            'id': '716599', +            'ext': 'mp4', +            'title': 'Neue Rechte Welle', +            'description': 'md5:a30a53f740ffb6bfd535314c2cc5fb69', +            'timestamp': 1501337639, +            'upload_date': '20170729', +        }, +        'params': { +            'format': 'bestvideo', +            'skip_download': True, +        }, +    }, { +        'url': 'https://www.funk.net/channel/59d5149841dca100012511e3/0/59d52049999264000182e79d/', +        'only_matching': True, +    }] + +    def _real_extract(self, url): +        video_id = self._match_id(url) + +        webpage = self._download_webpage(url, video_id) + +        domain_id = NexxIE._extract_domain_id(webpage) or '741' +        nexx_id = extract_attributes(self._search_regex( +            r'(<div[^>]id=["\']mediaplayer-funk[^>]+>)', +            webpage, 'media player'))['data-id'] + +        return self.url_result( +            'nexx:%s:%s' % (domain_id, nexx_id), ie=NexxIE.ie_key(), +            video_id=nexx_id) diff --git a/youtube_dl/extractor/generic.py b/youtube_dl/extractor/generic.py index 6dab4c7f4..39630b6f6 100644 --- a/youtube_dl/extractor/generic.py +++ b/youtube_dl/extractor/generic.py @@ -1613,22 +1613,6 @@ class GenericIE(InfoExtractor):              },              'add_ie': ['BrightcoveLegacy'],          }, -        # Nexx embed -        { -            'url': 'https://www.funk.net/serien/5940e15073f6120001657956/items/593efbb173f6120001657503', -            'info_dict': { -                'id': '247746', -                'ext': 'mp4', -                'title': "Yesterday's Jam (OV)", -                'description': 'md5:09bc0984723fed34e2581624a84e05f0', -                'timestamp': 1492594816, -                'upload_date': '20170419', -            }, -            'params': { -                'format': 'bestvideo', -                'skip_download': True, -            }, -        },          # Facebook <iframe> embed          {              'url': 'https://www.hostblogger.de/blog/archives/6181-Auto-jagt-Betonmischer.html', | 
