from __future__ import unicode_literals
-import re
-
from .common import InfoExtractor
-from ..utils import (
+from ..compat import (
compat_str,
compat_urllib_parse,
)
+from ..utils import (
+ ExtractorError,
+)
class FiveMinIE(InfoExtractor):
IE_NAME = '5min'
_VALID_URL = r'''(?x)
- (?:https?://[^/]*?5min\.com/Scripts/PlayerSeed\.js\?(.*?&)?playList=|
+ (?:https?://[^/]*?5min\.com/Scripts/PlayerSeed\.js\?(?:.*?&)?playList=|
+ https?://(?:(?:massively|www)\.)?joystiq\.com/video/|
5min:)
(?P<id>\d+)
'''
},
]
- @classmethod
- def _build_result(cls, video_id):
- return cls.url_result('5min:%s' % video_id, cls.ie_key())
-
def _real_extract(self, url):
- mobj = re.match(self._VALID_URL, url)
- video_id = mobj.group('id')
+ video_id = self._match_id(url)
embed_url = 'https://embed.5min.com/playerseed/?playList=%s' % video_id
embed_page = self._download_webpage(embed_url, video_id,
- 'Downloading embed page')
+ 'Downloading embed page')
sid = self._search_regex(r'sid=(\d+)', embed_page, 'sid')
query = compat_urllib_parse.urlencode({
'func': 'GetResults',
'isPlayerSeed': 'true',
'url': embed_url,
})
- info = self._download_json(
+ response = self._download_json(
'https://syn.5min.com/handlers/SenseHandler.ashx?' + query,
- video_id)['binding'][0]
+ video_id)
+ if not response['success']:
+ err_msg = response['errorMessage']
+ if err_msg == 'ErrorVideoUserNotGeo':
+ msg = 'Video not available from your location'
+ else:
+ msg = 'Aol said: %s' % err_msg
+ raise ExtractorError(msg, expected=True, video_id=video_id)
+ info = response['binding'][0]
second_id = compat_str(int(video_id[:-2]) + 1)
formats = []