commit
ef66b0c6ef
25 changed files with 325 additions and 133 deletions
@ -0,0 +1,37 @@ |
||||
import re |
||||
|
||||
from .common import InfoExtractor |
||||
|
||||
|
||||
class KickStarterIE(InfoExtractor): |
||||
_VALID_URL = r'https?://www\.kickstarter\.com/projects/(?P<id>\d*)/.*' |
||||
_TEST = { |
||||
u"url": u"https://www.kickstarter.com/projects/1404461844/intersection-the-story-of-josh-grant?ref=home_location", |
||||
u"file": u"1404461844.mp4", |
||||
u"md5": u"c81addca81327ffa66c642b5d8b08cab", |
||||
u"info_dict": { |
||||
u"title": u"Intersection: The Story of Josh Grant by Kyle Cowling", |
||||
}, |
||||
} |
||||
|
||||
def _real_extract(self, url): |
||||
m = re.match(self._VALID_URL, url) |
||||
video_id = m.group('id') |
||||
webpage_src = self._download_webpage(url, video_id) |
||||
|
||||
video_url = self._search_regex(r'data-video="(.*?)">', |
||||
webpage_src, u'video URL') |
||||
if 'mp4' in video_url: |
||||
ext = 'mp4' |
||||
else: |
||||
ext = 'flv' |
||||
video_title = self._html_search_regex(r"<title>(.*?)</title>", |
||||
webpage_src, u'title').rpartition(u'\u2014 Kickstarter')[0].strip() |
||||
|
||||
results = [{ |
||||
'id': video_id, |
||||
'url': video_url, |
||||
'title': video_title, |
||||
'ext': ext, |
||||
}] |
||||
return results |
@ -0,0 +1,34 @@ |
||||
import re |
||||
|
||||
from .mtv import MTVIE, _media_xml_tag |
||||
|
||||
|
||||
class SouthParkStudiosIE(MTVIE): |
||||
IE_NAME = u'southparkstudios.com' |
||||
_VALID_URL = r'https?://www\.southparkstudios\.com/clips/(?P<id>\d+)' |
||||
|
||||
_FEED_URL = 'http://www.southparkstudios.com/feeds/video-player/mrss' |
||||
|
||||
_TEST = { |
||||
u'url': u'http://www.southparkstudios.com/clips/104437/bat-daded#tab=featured', |
||||
u'file': u'a7bff6c2-ed00-11e0-aca6-0026b9414f30.mp4', |
||||
u'info_dict': { |
||||
u'title': u'Bat Daded', |
||||
u'description': u'Randy disqualifies South Park by getting into a fight with Bat Dad.', |
||||
}, |
||||
} |
||||
|
||||
# Overwrite MTVIE properties we don't want |
||||
_TESTS = [] |
||||
|
||||
def _get_thumbnail_url(self, uri, itemdoc): |
||||
search_path = '%s/%s' % (_media_xml_tag('group'), _media_xml_tag('thumbnail')) |
||||
return itemdoc.find(search_path).attrib['url'] |
||||
|
||||
def _real_extract(self, url): |
||||
mobj = re.match(self._VALID_URL, url) |
||||
video_id = mobj.group('id') |
||||
webpage = self._download_webpage(url, video_id) |
||||
mgid = self._search_regex(r'swfobject.embedSWF\(".*?(mgid:.*?)"', |
||||
webpage, u'mgid') |
||||
return self._get_videos_info(mgid) |
Loading…
Reference in new issue