1
0
mirror of https://github.com/l1ving/youtube-dl synced 2025-01-28 03:42:51 +08:00

Add MTV81 extractor

Support for videos from http://www.mtv81.com/ .
This commit is contained in:
desseim 2015-11-23 22:14:47 +01:00
parent 7689413e42
commit 5feef03206
6 changed files with 62 additions and 19 deletions

View File

@ -353,6 +353,7 @@ from .movshare import MovShareIE
from .mtv import ( from .mtv import (
MTVIE, MTVIE,
MTVServicesEmbeddedIE, MTVServicesEmbeddedIE,
MTV81IE,
MTVIggyIE, MTVIggyIE,
MTVDEIE, MTVDEIE,
) )

View File

@ -18,7 +18,7 @@ class ComedyCentralIE(MTVServicesInfoExtractor):
_VALID_URL = r'''(?x)https?://(?:www\.)?cc\.com/ _VALID_URL = r'''(?x)https?://(?:www\.)?cc\.com/
(video-clips|episodes|cc-studios|video-collections|full-episodes) (video-clips|episodes|cc-studios|video-collections|full-episodes)
/(?P<title>.*)''' /(?P<title>.*)'''
_FEED_URL = 'http://comedycentral.com/feeds/mrss/' _FEED_BASE_URL = 'http://comedycentral.com/feeds/mrss/'
_TEST = { _TEST = {
'url': 'http://www.cc.com/video-clips/kllhuv/stand-up-greg-fitzsimmons--uncensored---too-good-of-a-mother', 'url': 'http://www.cc.com/video-clips/kllhuv/stand-up-greg-fitzsimmons--uncensored---too-good-of-a-mother',

View File

@ -16,4 +16,4 @@ class GametrailersIE(MTVServicesInfoExtractor):
}, },
} }
_FEED_URL = 'http://www.gametrailers.com/feeds/mrss' _FEED_BASE_URL = 'http://www.gametrailers.com/feeds/mrss'

View File

@ -4,10 +4,13 @@ import re
from .common import InfoExtractor from .common import InfoExtractor
from ..compat import ( from ..compat import (
compat_urllib_parse,
compat_str, compat_str,
) )
from ..utils import ( from ..utils import (
compat_urlparse,
compat_urllib_parse,
compat_urllib_parse_urlparse,
compat_parse_qs,
ExtractorError, ExtractorError,
find_xpath_attr, find_xpath_attr,
fix_xml_ampersands, fix_xml_ampersands,
@ -40,8 +43,16 @@ class MTVServicesInfoExtractor(InfoExtractor):
base = 'http://viacommtvstrmfs.fplive.net/' base = 'http://viacommtvstrmfs.fplive.net/'
return base + m.group('finalid') return base + m.group('finalid')
def _get_feed_base_url(self, uri):
return self._FEED_BASE_URL
def _get_feed_url(self, uri): def _get_feed_url(self, uri):
return self._FEED_URL data = compat_urllib_parse.urlencode({'uri': uri})
feed_url = self._get_feed_base_url(uri) + '?'
if self._LANG:
feed_url += 'lang=%s&' % self._LANG
feed_url += data
return feed_url
def _get_thumbnail_url(self, uri, itemdoc): def _get_thumbnail_url(self, uri, itemdoc):
search_path = '%s/%s' % (_media_xml_tag('group'), _media_xml_tag('thumbnail')) search_path = '%s/%s' % (_media_xml_tag('group'), _media_xml_tag('thumbnail'))
@ -170,12 +181,7 @@ class MTVServicesInfoExtractor(InfoExtractor):
def _get_videos_info(self, uri): def _get_videos_info(self, uri):
video_id = self._id_from_uri(uri) video_id = self._id_from_uri(uri)
feed_url = self._get_feed_url(uri) feed_url = self._get_feed_url(uri)
data = compat_urllib_parse.urlencode({'uri': uri}) return self._get_videos_info_from_url(feed_url, video_id)
info_url = feed_url + '?'
if self._LANG:
info_url += 'lang=%s&' % self._LANG
info_url += data
return self._get_videos_info_from_url(info_url, video_id)
def _get_videos_info_from_url(self, url, video_id): def _get_videos_info_from_url(self, url, video_id):
idoc = self._download_xml( idoc = self._download_xml(
@ -199,7 +205,7 @@ class MTVServicesInfoExtractor(InfoExtractor):
if mgid is None or ':' not in mgid: if mgid is None or ':' not in mgid:
mgid = self._search_regex( mgid = self._search_regex(
[r'data-mgid="(.*?)"', r'swfobject.embedSWF\(".*?(mgid:.*?)"'], [r'data-mgid="(.*?)"', r'(?:swfobject.embedSWF)|(?:getTheVideo)\(".*?(mgid:.*?)"'],
webpage, 'mgid', default=None) webpage, 'mgid', default=None)
if not mgid: if not mgid:
@ -235,7 +241,7 @@ class MTVServicesEmbeddedIE(MTVServicesInfoExtractor):
if mobj: if mobj:
return mobj.group('url') return mobj.group('url')
def _get_feed_url(self, uri): def _get_feed_base_url(self, uri):
video_id = self._id_from_uri(uri) video_id = self._id_from_uri(uri)
site_id = uri.replace(video_id, '') site_id = uri.replace(video_id, '')
config_url = ('http://media.mtvnservices.com/pmt/e1/players/{0}/' config_url = ('http://media.mtvnservices.com/pmt/e1/players/{0}/'
@ -251,12 +257,48 @@ class MTVServicesEmbeddedIE(MTVServicesInfoExtractor):
return self._get_videos_info(mgid) return self._get_videos_info(mgid)
class MTV81IE(MTVServicesInfoExtractor):
IE_NAME = 'mtv81.com'
_VALID_URL = r'https?://www.mtv81.com/videos/'
_TEST = {
'url': 'http://www.mtv81.com/videos/artist-to-watch/the-godfather-of-japanese-hip-hop-segment-1/',
'md5': 'a253c454fa662955b95d47d998ab1119',
'info_dict': {
'id': '1105285',
'ext': 'mp4',
'title': 'Artist to Watch - KRUSH - Segment 1',
'description': '<i>Artist to Watch - KRUSH - Segment 1</i><br/><br/>'
},
}
def _get_feed_url(self, uri):
video_id = self._id_from_uri(uri)
site_id = uri.replace(video_id, '')
config_url = ('http://media.mtvnservices.com/pmt/e1/players/{0}/'
'config.xml'.format(site_id))
config_doc = self._download_xml(config_url, video_id)
feed_node = config_doc.find('.//feed')
feed_original_url = feed_node.text.strip()
# we need to keep 'version' query parameter and add 'uri' one
feed_original_url_parts = compat_urllib_parse_urlparse(feed_original_url)
feed_original_query_parts = compat_parse_qs(feed_original_url_parts.query)
try:
feed_query_parts = {'version': feed_original_query_parts['version']}
except KeyError:
feed_query_parts = {}
feed_query_parts['uri'] = uri
feed_query = compat_urllib_parse.urlencode(feed_query_parts, doseq=True)
feed_url = compat_urlparse.urlunparse((feed_original_url_parts.scheme, feed_original_url_parts.netloc, feed_original_url_parts.path, feed_original_url_parts.params, feed_query, feed_original_url_parts.fragment))
return feed_url
class MTVIE(MTVServicesInfoExtractor): class MTVIE(MTVServicesInfoExtractor):
_VALID_URL = r'''(?x)^https?:// _VALID_URL = r'''(?x)^https?://
(?:(?:www\.)?mtv\.com/videos/.+?/(?P<videoid>[0-9]+)/[^/]+$| (?:(?:www\.)?mtv\.com/videos/.+?/(?P<videoid>[0-9]+)/[^/]+$|
m\.mtv\.com/videos/video\.rbml\?.*?id=(?P<mgid>[^&]+))''' m\.mtv\.com/videos/video\.rbml\?.*?id=(?P<mgid>[^&]+))'''
_FEED_URL = 'http://www.mtv.com/player/embed/AS3/rss/' _FEED_BASE_URL = 'http://www.mtv.com/player/embed/AS3/rss/'
_TESTS = [ _TESTS = [
{ {
@ -304,7 +346,7 @@ class MTVIggyIE(MTVServicesInfoExtractor):
'title': 'Arcade Fire: Behind the Scenes at the Biggest Music Experiment Yet', 'title': 'Arcade Fire: Behind the Scenes at the Biggest Music Experiment Yet',
} }
} }
_FEED_URL = 'http://all.mtvworldverticals.com/feed-xml/' _FEED_BASE_URL = 'http://all.mtvworldverticals.com/feed-xml/'
class MTVDEIE(MTVServicesInfoExtractor): class MTVDEIE(MTVServicesInfoExtractor):

View File

@ -8,7 +8,7 @@ class SouthParkIE(MTVServicesInfoExtractor):
IE_NAME = 'southpark.cc.com' IE_NAME = 'southpark.cc.com'
_VALID_URL = r'https?://(?:www\.)?(?P<url>southpark\.cc\.com/(?:clips|full-episodes)/(?P<id>.+?)(\?|#|$))' _VALID_URL = r'https?://(?:www\.)?(?P<url>southpark\.cc\.com/(?:clips|full-episodes)/(?P<id>.+?)(\?|#|$))'
_FEED_URL = 'http://www.southparkstudios.com/feeds/video-player/mrss' _FEED_BASE_URL = 'http://www.southparkstudios.com/feeds/video-player/mrss'
_TESTS = [{ _TESTS = [{
'url': 'http://southpark.cc.com/clips/104437/bat-daded#tab=featured', 'url': 'http://southpark.cc.com/clips/104437/bat-daded#tab=featured',
@ -35,7 +35,7 @@ class SouthParkEsIE(SouthParkIE):
class SouthParkDeIE(SouthParkIE): class SouthParkDeIE(SouthParkIE):
IE_NAME = 'southpark.de' IE_NAME = 'southpark.de'
_VALID_URL = r'https?://(?:www\.)?(?P<url>southpark\.de/(?:clips|alle-episoden)/(?P<id>.+?)(\?|#|$))' _VALID_URL = r'https?://(?:www\.)?(?P<url>southpark\.de/(?:clips|alle-episoden)/(?P<id>.+?)(\?|#|$))'
_FEED_URL = 'http://www.southpark.de/feeds/video-player/mrss/' _FEED_BASE_URL = 'http://www.southpark.de/feeds/video-player/mrss/'
_TESTS = [{ _TESTS = [{
'url': 'http://www.southpark.de/clips/uygssh/the-government-wont-respect-my-privacy#tab=featured', 'url': 'http://www.southpark.de/clips/uygssh/the-government-wont-respect-my-privacy#tab=featured',
@ -59,7 +59,7 @@ class SouthParkDeIE(SouthParkIE):
class SouthParkNlIE(SouthParkIE): class SouthParkNlIE(SouthParkIE):
IE_NAME = 'southpark.nl' IE_NAME = 'southpark.nl'
_VALID_URL = r'https?://(?:www\.)?(?P<url>southpark\.nl/(?:clips|full-episodes)/(?P<id>.+?)(\?|#|$))' _VALID_URL = r'https?://(?:www\.)?(?P<url>southpark\.nl/(?:clips|full-episodes)/(?P<id>.+?)(\?|#|$))'
_FEED_URL = 'http://www.southpark.nl/feeds/video-player/mrss/' _FEED_BASE_URL = 'http://www.southpark.nl/feeds/video-player/mrss/'
_TESTS = [{ _TESTS = [{
'url': 'http://www.southpark.nl/full-episodes/s18e06-freemium-isnt-free', 'url': 'http://www.southpark.nl/full-episodes/s18e06-freemium-isnt-free',
@ -70,7 +70,7 @@ class SouthParkNlIE(SouthParkIE):
class SouthParkDkIE(SouthParkIE): class SouthParkDkIE(SouthParkIE):
IE_NAME = 'southparkstudios.dk' IE_NAME = 'southparkstudios.dk'
_VALID_URL = r'https?://(?:www\.)?(?P<url>southparkstudios\.dk/(?:clips|full-episodes)/(?P<id>.+?)(\?|#|$))' _VALID_URL = r'https?://(?:www\.)?(?P<url>southparkstudios\.dk/(?:clips|full-episodes)/(?P<id>.+?)(\?|#|$))'
_FEED_URL = 'http://www.southparkstudios.dk/feeds/video-player/mrss/' _FEED_BASE_URL = 'http://www.southparkstudios.dk/feeds/video-player/mrss/'
_TESTS = [{ _TESTS = [{
'url': 'http://www.southparkstudios.dk/full-episodes/s18e07-grounded-vindaloop', 'url': 'http://www.southparkstudios.dk/full-episodes/s18e07-grounded-vindaloop',

View File

@ -19,7 +19,7 @@ class SpikeIE(MTVServicesInfoExtractor):
}, },
} }
_FEED_URL = 'http://www.spike.com/feeds/mrss/' _FEED_BASE_URL = 'http://www.spike.com/feeds/mrss/'
_MOBILE_TEMPLATE = 'http://m.spike.com/videos/video.rbml?id=%s' _MOBILE_TEMPLATE = 'http://m.spike.com/videos/video.rbml?id=%s'
def _real_extract(self, url): def _real_extract(self, url):