|
|
@ -7,8 +7,8 @@ from .common import InfoExtractor |
|
|
|
|
|
|
|
|
|
|
|
class JWPlatformIE(InfoExtractor): |
|
|
|
_VALID_URL = r'(?:https?://content\.jwplatform\.com/(?:feeds|players|jw6)/|jwplatform:)(?P<id>[a-zA-Z0-9]{8})' |
|
|
|
_TEST = { |
|
|
|
_VALID_URL = r'(?:https?://(?:content\.jwplatform|cdn\.jwplayer)\.com/(?:(?:feed|player|thumb|preview|video|manifest)s|jw6|v2/media)/|jwplatform:)(?P<id>[a-zA-Z0-9]{8})' |
|
|
|
_TESTS = [{ |
|
|
|
'url': 'http://content.jwplatform.com/players/nPripu9l-ALJ3XQCI.js', |
|
|
|
'md5': 'fa8899fa601eb7c83a64e9d568bdf325', |
|
|
|
'info_dict': { |
|
|
@ -19,7 +19,10 @@ class JWPlatformIE(InfoExtractor): |
|
|
|
'upload_date': '20081127', |
|
|
|
'timestamp': 1227796140, |
|
|
|
} |
|
|
|
} |
|
|
|
}, { |
|
|
|
'url': 'https://cdn.jwplayer.com/players/nPripu9l-ALJ3XQCI.js', |
|
|
|
'only_matching': True, |
|
|
|
}] |
|
|
|
|
|
|
|
@staticmethod |
|
|
|
def _extract_url(webpage): |
|
|
@ -34,5 +37,5 @@ class JWPlatformIE(InfoExtractor): |
|
|
|
|
|
|
|
def _real_extract(self, url): |
|
|
|
video_id = self._match_id(url) |
|
|
|
json_data = self._download_json('http://content.jwplatform.com/feeds/%s.json' % video_id, video_id) |
|
|
|
json_data = self._download_json('https://cdn.jwplayer.com/v2/media/' + video_id, video_id) |
|
|
|
return self._parse_jwplayer_data(json_data, video_id) |