|
|
@ -1036,20 +1036,30 @@ class MetacafeIE(InfoExtractor): |
|
|
|
# Extract URL, uploader and title from webpage |
|
|
|
self.report_extraction(video_id) |
|
|
|
mobj = re.search(r'(?m)&mediaURL=([^&]+)', webpage) |
|
|
|
if mobj is None: |
|
|
|
self._downloader.trouble(u'ERROR: unable to extract media URL') |
|
|
|
return |
|
|
|
mediaURL = urllib.unquote(mobj.group(1)) |
|
|
|
|
|
|
|
# Extract gdaKey if available |
|
|
|
mobj = re.search(r'(?m)&gdaKey=(.*?)&', webpage) |
|
|
|
if mobj is None: |
|
|
|
video_url = mediaURL |
|
|
|
#self._downloader.trouble(u'ERROR: unable to extract gdaKey') |
|
|
|
#return |
|
|
|
if mobj is not None: |
|
|
|
mediaURL = urllib.unquote(mobj.group(1)) |
|
|
|
|
|
|
|
# Extract gdaKey if available |
|
|
|
mobj = re.search(r'(?m)&gdaKey=(.*?)&', webpage) |
|
|
|
if mobj is None: |
|
|
|
video_url = mediaURL |
|
|
|
else: |
|
|
|
gdaKey = mobj.group(1) |
|
|
|
video_url = '%s?__gda__=%s' % (mediaURL, gdaKey) |
|
|
|
else: |
|
|
|
gdaKey = mobj.group(1) |
|
|
|
video_url = '%s?__gda__=%s' % (mediaURL, gdaKey) |
|
|
|
mobj = re.search(r' name="flashvars" value="(.*?)"', webpage) |
|
|
|
if mobj is None: |
|
|
|
self._downloader.trouble(u'ERROR: unable to extract media URL') |
|
|
|
return |
|
|
|
vardict = parse_qs(mobj.group(1)) |
|
|
|
if 'mediaData' not in vardict: |
|
|
|
self._downloader.trouble(u'ERROR: unable to extract media URL') |
|
|
|
return |
|
|
|
mobj = re.search(r'"mediaURL":"(http.*?)","key":"(.*?)"', vardict['mediaData'][0]) |
|
|
|
if mobj is None: |
|
|
|
self._downloader.trouble(u'ERROR: unable to extract media URL') |
|
|
|
return |
|
|
|
video_url = '%s?__gda__=%s' % (mobj.group(1).replace('\\/', '/'), mobj.group(2)) |
|
|
|
|
|
|
|
mobj = re.search(r'(?im)<title>(.*) - Video</title>', webpage) |
|
|
|
if mobj is None: |
|
|
|