diff options
| author | Sergey M․ <dstftw@gmail.com> | 2021-05-30 06:14:59 +0700 | 
|---|---|---|
| committer | Sergey M․ <dstftw@gmail.com> | 2021-05-30 06:14:59 +0700 | 
| commit | d495292852b6c2f1bd58bc2141ff2b0265c952cf (patch) | |
| tree | cb871a8e203beb9fe7d9a0056151f878101c66df | |
| parent | 2ee6c7f11074917c08253af4c47f9258aa1e0dad (diff) | |
[ard] Relax _VALID_URL and fix video ids (closes #22724, closes #29091)
| -rw-r--r-- | youtube_dl/extractor/ard.py | 21 | 
1 files changed, 15 insertions, 6 deletions
| diff --git a/youtube_dl/extractor/ard.py b/youtube_dl/extractor/ard.py index d57c5ba0f..d45a9fe52 100644 --- a/youtube_dl/extractor/ard.py +++ b/youtube_dl/extractor/ard.py @@ -249,14 +249,14 @@ class ARDMediathekIE(ARDMediathekBaseIE):  class ARDIE(InfoExtractor): -    _VALID_URL = r'(?P<mainurl>https?://(?:www\.)?daserste\.de/[^?#]+/videos(?:extern)?/(?P<display_id>[^/?#]+)-(?:video-?)?(?P<id>[0-9]+))\.html' +    _VALID_URL = r'(?P<mainurl>https?://(?:www\.)?daserste\.de/(?:[^/?#&]+/)+(?P<id>[^/?#&]+))\.html'      _TESTS = [{          # available till 7.01.2022          'url': 'https://www.daserste.de/information/talk/maischberger/videos/maischberger-die-woche-video100.html',          'md5': '867d8aa39eeaf6d76407c5ad1bb0d4c1',          'info_dict': { -            'display_id': 'maischberger-die-woche', -            'id': '100', +            'id': 'maischberger-die-woche-video100', +            'display_id': 'maischberger-die-woche-video100',              'ext': 'mp4',              'duration': 3687.0,              'title': 'maischberger. die woche vom 7. Januar 2021', @@ -264,16 +264,25 @@ class ARDIE(InfoExtractor):              'thumbnail': r're:^https?://.*\.jpg$',          },      }, { -        'url': 'https://www.daserste.de/information/reportage-dokumentation/erlebnis-erde/videosextern/woelfe-und-herdenschutzhunde-ungleiche-brueder-102.html', +        'url': 'https://www.daserste.de/information/politik-weltgeschehen/morgenmagazin/videosextern/dominik-kahun-aus-der-nhl-direkt-zur-weltmeisterschaft-100.html', +        'only_matching': True, +    }, { +        'url': 'https://www.daserste.de/information/nachrichten-wetter/tagesthemen/videosextern/tagesthemen-17736.html',          'only_matching': True,      }, {          'url': 'http://www.daserste.de/information/reportage-dokumentation/dokus/videos/die-story-im-ersten-mission-unter-falscher-flagge-100.html',          'only_matching': True, +    }, { +        'url': 'https://www.daserste.de/unterhaltung/serie/in-aller-freundschaft-die-jungen-aerzte/Drehpause-100.html', +        'only_matching': True, +    }, { +        'url': 'https://www.daserste.de/unterhaltung/film/filmmittwoch-im-ersten/videos/making-ofwendezeit-video-100.html', +        'only_matching': True,      }]      def _real_extract(self, url):          mobj = re.match(self._VALID_URL, url) -        display_id = mobj.group('display_id') +        display_id = mobj.group('id')          player_url = mobj.group('mainurl') + '~playerXml.xml'          doc = self._download_xml(player_url, display_id) @@ -324,7 +333,7 @@ class ARDIE(InfoExtractor):          self._sort_formats(formats)          return { -            'id': mobj.group('id'), +            'id': xpath_text(video_node, './videoId', default=display_id),              'formats': formats,              'display_id': display_id,              'title': video_node.find('./title').text, | 
