germanupa.py (4051B)
- from .common import InfoExtractor
- from .vimeo import VimeoIE
- from ..utils import (
- parse_qs,
- traverse_obj,
- url_or_none,
- )
- class GermanupaIE(InfoExtractor):
- IE_DESC = 'germanupa.de'
- _VALID_URL = r'https?://germanupa\.de/mediathek/(?P<id>[\w-]+)'
- _TESTS = [{
- 'url': 'https://germanupa.de/mediathek/4-figma-beratung-deine-sprechstunde-fuer-figma-fragen',
- 'info_dict': {
- 'id': '909179246',
- 'title': 'Tutorial: #4 Figma Beratung - Deine Sprechstunde für Figma-Fragen',
- 'ext': 'mp4',
- 'uploader': 'German UPA',
- 'uploader_id': 'germanupa',
- 'thumbnail': 'https://i.vimeocdn.com/video/1792564420-7415283ccef8bf8702dab8c6b7515555ceeb7a1c11371ffcc133b8e887dbf70e-d_1280',
- 'uploader_url': 'https://vimeo.com/germanupa',
- 'duration': 3987,
- },
- 'expected_warnings': ['Failed to parse XML: not well-formed'],
- 'params': {'skip_download': 'm3u8'},
- }, {
- 'note': 'audio, uses GenericIE',
- 'url': 'https://germanupa.de/mediathek/live-vom-ux-festival-neuigkeiten-von-figma-jobmarkt-agenturszene-interview-zu-sustainable',
- 'info_dict': {
- 'id': '1867346676',
- 'title': 'Live vom UX Festival: Neuigkeiten von Figma, Jobmarkt, Agenturszene & Interview zu Sustainable UX',
- 'ext': 'opus',
- 'timestamp': 1720545088,
- 'upload_date': '20240709',
- 'duration': 3910.557,
- 'like_count': int,
- 'description': 'md5:db2aed5ff131e177a7b33901e9a8db05',
- 'uploader': 'German UPA',
- 'repost_count': int,
- 'genres': ['Science'],
- 'license': 'all-rights-reserved',
- 'uploader_url': 'https://soundcloud.com/user-80097677',
- 'uploader_id': '471579486',
- 'view_count': int,
- 'comment_count': int,
- 'thumbnail': 'https://i1.sndcdn.com/artworks-oCti2e9GhaZFWBqY-48ybGw-original.jpg',
- },
- }, {
- 'note': 'Nur für Mitglieder/Just for members',
- 'url': 'https://germanupa.de/mediathek/ux-festival-2024-usability-tests-und-ai',
- 'info_dict': {
- 'id': '986994430',
- 'title': 'UX Festival 2024 "Usability Tests und AI" von Lennart Weber',
- 'ext': 'mp4',
- 'release_date': '20240719',
- 'uploader_url': 'https://vimeo.com/germanupa',
- 'timestamp': 1721373980,
- 'license': 'by-sa',
- 'like_count': int,
- 'thumbnail': 'https://i.vimeocdn.com/video/1904187064-2a672630c30f9ad787bd390bff3f51d7506a3e8416763ba6dbf465732b165c5c-d_1280',
- 'duration': 2146,
- 'release_timestamp': 1721373980,
- 'uploader': 'German UPA',
- 'uploader_id': 'germanupa',
- 'upload_date': '20240719',
- 'comment_count': int,
- },
- 'expected_warnings': ['Failed to parse XML: not well-formed'],
- 'skip': 'login required',
- }]
- def _real_extract(self, url):
- video_id = self._match_id(url)
- webpage = self._download_webpage(url, video_id)
- param_url = traverse_obj(
- self._search_regex(
- r'<iframe[^>]+data-src\s*?=\s*?([\'"])(?P<url>https://germanupa\.de/media/oembed\?url=(?:(?!\1).)+)\1',
- webpage, 'embedded video', default=None, group='url'),
- ({parse_qs}, 'url', 0, {url_or_none}))
- if not param_url:
- if self._search_regex(
- r'<div[^>]+class\s*?=\s*?([\'"])(?:(?!\1).)*login-wrapper(?:(?!\1).)*\1',
- webpage, 'login wrapper', default=None):
- self.raise_login_required('This video is only available for members')
- return self.url_result(url, 'Generic') # Fall back to generic to extract audio
- real_url = param_url.replace('https://vimeo.com/', 'https://player.vimeo.com/video/')
- return self.url_result(VimeoIE._smuggle_referrer(real_url, url), VimeoIE, video_id)