|
@@ -8,6 +8,7 @@ import itertools
|
|
|
from .common import InfoExtractor
|
|
|
from ..compat import (
|
|
|
compat_HTTPError,
|
|
|
+ compat_str,
|
|
|
compat_urlparse,
|
|
|
)
|
|
|
from ..utils import (
|
|
@@ -24,6 +25,7 @@ from ..utils import (
|
|
|
urlencode_postdata,
|
|
|
unescapeHTML,
|
|
|
parse_filesize,
|
|
|
+ try_get,
|
|
|
)
|
|
|
|
|
|
|
|
@@ -445,7 +447,18 @@ class VimeoIE(VimeoBaseInfoExtractor):
|
|
|
if config.get('view') == 4:
|
|
|
config = self._verify_player_video_password(url, video_id)
|
|
|
|
|
|
- if '>You rented this title.<' in webpage:
|
|
|
+ def is_rented():
|
|
|
+ if '>You rented this title.<' in webpage:
|
|
|
+ return True
|
|
|
+ if config.get('user', {}).get('purchased'):
|
|
|
+ return True
|
|
|
+ label = try_get(
|
|
|
+ config, lambda x: x['video']['vod']['purchase_options'][0]['label_string'], compat_str)
|
|
|
+ if label and label.startswith('You rented this'):
|
|
|
+ return True
|
|
|
+ return False
|
|
|
+
|
|
|
+ if is_rented():
|
|
|
feature_id = config.get('video', {}).get('vod', {}).get('feature_id')
|
|
|
if feature_id and not data.get('force_feature_id', False):
|
|
|
return self.url_result(smuggle_url(
|