|
@ -83,6 +83,21 @@ class AdultSwimIE(InfoExtractor): |
|
|
# m3u8 download |
|
|
# m3u8 download |
|
|
'skip_download': True, |
|
|
'skip_download': True, |
|
|
} |
|
|
} |
|
|
|
|
|
}, { |
|
|
|
|
|
# heroMetadata.trailer |
|
|
|
|
|
'url': 'http://www.adultswim.com/videos/decker/inside-decker-a-new-hero/', |
|
|
|
|
|
'md5': '33e9a5d8f646523ce0868ecfb0eed77d', |
|
|
|
|
|
'info_dict': { |
|
|
|
|
|
'id': 'I0LQFQkaSUaFp8PnAWHhoQ', |
|
|
|
|
|
'ext': 'mp4', |
|
|
|
|
|
'title': 'Decker - Inside Decker: A New Hero', |
|
|
|
|
|
'description': 'md5:c916df071d425d62d70c86d4399d3ee0', |
|
|
|
|
|
'duration': 249.008, |
|
|
|
|
|
}, |
|
|
|
|
|
'params': { |
|
|
|
|
|
# m3u8 download |
|
|
|
|
|
'skip_download': True, |
|
|
|
|
|
} |
|
|
}] |
|
|
}] |
|
|
|
|
|
|
|
|
@staticmethod |
|
|
@staticmethod |
|
@ -133,20 +148,26 @@ class AdultSwimIE(InfoExtractor): |
|
|
if video_info is None: |
|
|
if video_info is None: |
|
|
if bootstrapped_data.get('slugged_video', {}).get('slug') == episode_path: |
|
|
if bootstrapped_data.get('slugged_video', {}).get('slug') == episode_path: |
|
|
video_info = bootstrapped_data['slugged_video'] |
|
|
video_info = bootstrapped_data['slugged_video'] |
|
|
else: |
|
|
|
|
|
raise ExtractorError('Unable to find video info') |
|
|
|
|
|
|
|
|
if not video_info: |
|
|
|
|
|
video_info = bootstrapped_data.get('heroMetadata', {}).get('trailer').get('video') |
|
|
|
|
|
if not video_info: |
|
|
|
|
|
raise ExtractorError('Unable to find video info') |
|
|
|
|
|
|
|
|
show = bootstrapped_data['show'] |
|
|
show = bootstrapped_data['show'] |
|
|
show_title = show['title'] |
|
|
show_title = show['title'] |
|
|
stream = video_info.get('stream') |
|
|
stream = video_info.get('stream') |
|
|
clips = [stream] if stream else video_info.get('clips') |
|
|
|
|
|
if not clips: |
|
|
|
|
|
|
|
|
if stream and stream.get('videoPlaybackID'): |
|
|
|
|
|
segment_ids = [stream['videoPlaybackID']] |
|
|
|
|
|
elif video_info.get('clips'): |
|
|
|
|
|
segment_ids = [clip['videoPlaybackID'] for clip in video_info['clips']] |
|
|
|
|
|
elif video_info.get('videoPlaybackID'): |
|
|
|
|
|
segment_ids = [video_info['videoPlaybackID']] |
|
|
|
|
|
else: |
|
|
raise ExtractorError( |
|
|
raise ExtractorError( |
|
|
'This video is only available via cable service provider subscription that' |
|
|
'This video is only available via cable service provider subscription that' |
|
|
' is not currently supported. You may want to use --cookies.' |
|
|
' is not currently supported. You may want to use --cookies.' |
|
|
if video_info.get('auth') is True else 'Unable to find stream or clips', |
|
|
if video_info.get('auth') is True else 'Unable to find stream or clips', |
|
|
expected=True) |
|
|
expected=True) |
|
|
segment_ids = [clip['videoPlaybackID'] for clip in clips] |
|
|
|
|
|
|
|
|
|
|
|
episode_id = video_info['id'] |
|
|
episode_id = video_info['id'] |
|
|
episode_title = video_info['title'] |
|
|
episode_title = video_info['title'] |
|
|