From e2a25b31f32ea5197b531154f3b8aa9d7a9b84ac Mon Sep 17 00:00:00 2001 From: Benjamin Congdon Date: Wed, 9 Mar 2016 21:16:21 -0600 Subject: [PATCH] Added extractor for AudioBoom.com --- youtube_dl/extractor/__init__.py | 1 + youtube_dl/extractor/audioboom.py | 39 +++++++++++++++++++++++++++++++ 2 files changed, 40 insertions(+) create mode 100644 youtube_dl/extractor/audioboom.py diff --git a/youtube_dl/extractor/__init__.py b/youtube_dl/extractor/__init__.py index e07f724bf..16a10bd1b 100644 --- a/youtube_dl/extractor/__init__.py +++ b/youtube_dl/extractor/__init__.py @@ -54,6 +54,7 @@ from .arte import ( from .atresplayer import AtresPlayerIE from .atttechchannel import ATTTechChannelIE from .audimedia import AudiMediaIE +from .audioboom import AudioBoomIE from .audiomack import AudiomackIE, AudiomackAlbumIE from .azubu import AzubuIE, AzubuLiveIE from .baidu import BaiduVideoIE diff --git a/youtube_dl/extractor/audioboom.py b/youtube_dl/extractor/audioboom.py new file mode 100644 index 000000000..84d4755f5 --- /dev/null +++ b/youtube_dl/extractor/audioboom.py @@ -0,0 +1,39 @@ +# coding: utf-8 +from __future__ import unicode_literals + +from .common import InfoExtractor +from ..utils import float_or_none + + +class AudioBoomIE(InfoExtractor): + _VALID_URL = r'https?://(?:www\.)?audioboom\.com/boos/(?P[0-9]+)' + _TEST = { + 'url': 'https://audioboom.com/boos/4279833-3-09-2016-czaban-hour-3?t=0', + 'md5': '63a8d73a055c6ed0f1e51921a10a5a76', + 'info_dict': { + 'id': '4279833', + 'ext': 'mp3', + 'title': '3/09/2016 Czaban Hour 3', + 'description': 'Guest: Nate Davis - NFL free agency, Guest: Stan Gans', + 'duration': 2245.72 + } + } + + def _real_extract(self, url): + video_id = self._match_id(url) + webpage = self._download_webpage(url, video_id) + + title = self._og_search_title(webpage) + + download_url = self._og_search_property('audio', webpage, 'url') + + duration = float_or_none(self._html_search_meta( + 'weibo:audio:duration', webpage, fatal=False)) + + return { + 'id': video_id, + 'title': title, + 'url': download_url, + 'description': self._og_search_description(webpage), + 'duration': duration, + }