2018-04-20 19:56:26 +02:00
|
|
|
# coding: utf-8
|
|
|
|
from __future__ import unicode_literals
|
|
|
|
|
|
|
|
from .common import InfoExtractor
|
|
|
|
|
2018-04-20 20:39:51 +02:00
|
|
|
try:
|
|
|
|
from urllib import urlencode
|
|
|
|
from urlparse import urlparse, urlunparse, urljoin
|
|
|
|
except ImportError:
|
|
|
|
from urllib.parse import urlencode, urlparse, urlunparse, urljoin
|
2018-04-20 19:56:26 +02:00
|
|
|
|
|
|
|
|
|
|
|
class MakoTVIE(InfoExtractor):
|
|
|
|
_VALID_URL = r'https?://(?:www\.)?mako\.co\.il/mako-vod-.+/VOD-(?P<id>[0-9a-f]{18})\.htm'
|
|
|
|
_TEST = {
|
|
|
|
'url': 'https://www.mako.co.il/mako-vod-keshet/parliament-s1/VOD-5df5a86c1966831006.htm',
|
|
|
|
'md5': 'cd8cdff75390f8521831ec5049841764',
|
|
|
|
'info_dict': {
|
|
|
|
'id': '5df5a86c1966831006',
|
|
|
|
'ext': 'm3u8',
|
|
|
|
'title': 'הפרלמנט | פרק 1 לצפייה ישירה | makoTV ',
|
|
|
|
'thumbnail': r're:^https?://img\.mako\.co\.il/\d{4}/\d{2}/\d{2}/.*\.jpg$',
|
|
|
|
'description': 'שאולי, אמציה, הקטור, קרקו ואבי מקבלים סדרה משלהם. כל הפרקים של הפרלמנט לצפייה ישירה | makoTV ',
|
|
|
|
'upload_date': '20120708',
|
|
|
|
'timestamp': 1341751140
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
def _real_extract(self, url):
|
|
|
|
video_id = self._match_id(url)
|
|
|
|
webpage = self._download_webpage(url, video_id)
|
|
|
|
|
|
|
|
parsed_url = list(urlparse(url))
|
|
|
|
parsed_url[4] = urlencode({'type': 'service'})
|
|
|
|
service = self._download_json(urlunparse(parsed_url), video_id)
|
|
|
|
video = service['root']['video']
|
|
|
|
|
|
|
|
config_new = self._download_xml('https://rcs.mako.co.il/flash_swf/players/makoPlayer/configNew.xml', video_id)
|
|
|
|
playlist_url = config_new.findtext('./PlaylistUrl')
|
|
|
|
playlist_url = playlist_url.replace('$$vcmid$$', video['guid'])
|
|
|
|
playlist_url = playlist_url.replace('$$videoChannelId$$', video['chId'])
|
|
|
|
playlist_url = playlist_url.replace('$$galleryChannelId$$', video['galleryChId'])
|
|
|
|
playlist = self._download_json('https://www.mako.co.il' + playlist_url, video_id)
|
|
|
|
|
|
|
|
formats = []
|
|
|
|
for media in playlist['media']:
|
|
|
|
tickets = self._download_json('https://mass.mako.co.il/ClicksStatistics/entitlementsServicesV2.jsp?et=gt&lp={}&rv={}'.format(media['url'], media['cdn']), video_id)
|
|
|
|
assert tickets['status'] == 'success'
|
|
|
|
for ticket in tickets['tickets']:
|
|
|
|
ticket_url = urljoin('https://makostore-hd.ctedgecdn.net', '{}?{}'.format(ticket['url'], ticket['ticket']))
|
|
|
|
formats.extend(self._extract_m3u8_formats(ticket_url, video_id))
|
|
|
|
|
|
|
|
self._sort_formats(formats)
|
|
|
|
|
|
|
|
info = self._search_json_ld(webpage, video_id)
|
|
|
|
info.update({
|
|
|
|
'id': video_id,
|
|
|
|
'title': self._og_search_title(webpage),
|
|
|
|
'thumbnail': self._og_search_thumbnail(webpage),
|
|
|
|
'description': self._og_search_description(webpage),
|
|
|
|
'formats': formats
|
|
|
|
})
|
|
|
|
|
|
|
|
return info
|