|  | @@ -6,6 +6,7 @@ from ..utils import (
 | 
	
		
			
				|  |  |      int_or_none,
 | 
	
		
			
				|  |  |      parse_iso8601,
 | 
	
		
			
				|  |  |      try_get,
 | 
	
		
			
				|  |  | +    url_or_none,
 | 
	
		
			
				|  |  |  )
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -30,16 +31,7 @@ class CCCIE(InfoExtractor):
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |      }, {
 | 
	
		
			
				|  |  |          'url': 'https://media.ccc.de/v/32c3-7368-shopshifting#download',
 | 
	
		
			
				|  |  | -        'info_dict': {
 | 
	
		
			
				|  |  | -            'id': '2835',
 | 
	
		
			
				|  |  | -            'ext': 'mp4',
 | 
	
		
			
				|  |  | -            'title': 'Shopshifting',
 | 
	
		
			
				|  |  | -            'creator': 'Karsten Nohl, Fabian Bräunlein, dexter',
 | 
	
		
			
				|  |  | -            'description': 'md5:0fade0535e9dc3076d0cbda4958a18eb',
 | 
	
		
			
				|  |  | -            'upload_date': '20151227',
 | 
	
		
			
				|  |  | -            'timestamp': 1451249100,
 | 
	
		
			
				|  |  | -            'tags': list,
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | +        'only_matching': True,
 | 
	
		
			
				|  |  |      }]
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      def _real_extract(self, url):
 | 
	
	
		
			
				|  | @@ -104,12 +96,16 @@ class CCCPlaylistIE(InfoExtractor):
 | 
	
		
			
				|  |  |      }]
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      def _real_extract(self, url):
 | 
	
		
			
				|  |  | -        acronym = self._match_id(url).lower()
 | 
	
		
			
				|  |  | +        playlist_id = self._match_id(url).lower()
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        conf = self._download_json(
 | 
	
		
			
				|  |  | +            'https://media.ccc.de/public/conferences/' + playlist_id,
 | 
	
		
			
				|  |  | +            playlist_id)
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -        conf = self._download_json('https://media.ccc.de/public/conferences/' + acronym, acronym)
 | 
	
		
			
				|  |  | +        entries = []
 | 
	
		
			
				|  |  | +        for e in conf['events']:
 | 
	
		
			
				|  |  | +            event_url = url_or_none(e.get('frontend_link'))
 | 
	
		
			
				|  |  | +            if event_url:
 | 
	
		
			
				|  |  | +                entries.append(self.url_result(event_url, ie=CCCIE.ie_key()))
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -        return self.playlist_result(
 | 
	
		
			
				|  |  | -            [self.url_result(event['frontend_link']) for event in conf['events']],
 | 
	
		
			
				|  |  | -            acronym,
 | 
	
		
			
				|  |  | -            conf['title'],
 | 
	
		
			
				|  |  | -        )
 | 
	
		
			
				|  |  | +        return self.playlist_result(entries, playlist_id, conf.get('title'))
 |