You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
56 lines
1.8 KiB
56 lines
1.8 KiB
# coding: utf-8 |
|
from __future__ import unicode_literals |
|
|
|
from .common import InfoExtractor |
|
from .streamable import StreamableIE |
|
|
|
|
|
class FootyRoomIE(InfoExtractor): |
|
_VALID_URL = r'https?://footyroom\.com/matches/(?P<id>\d+)' |
|
_TESTS = [{ |
|
'url': 'http://footyroom.com/matches/79922154/hull-city-vs-chelsea/review', |
|
'info_dict': { |
|
'id': '79922154', |
|
'title': 'VIDEO Hull City 0 - 2 Chelsea', |
|
}, |
|
'playlist_count': 2, |
|
'add_ie': [StreamableIE.ie_key()], |
|
}, { |
|
'url': 'http://footyroom.com/matches/75817984/georgia-vs-germany/review', |
|
'info_dict': { |
|
'id': '75817984', |
|
'title': 'VIDEO Georgia 0 - 2 Germany', |
|
}, |
|
'playlist_count': 1, |
|
'add_ie': ['Playwire'] |
|
}] |
|
|
|
def _real_extract(self, url): |
|
playlist_id = self._match_id(url) |
|
|
|
webpage = self._download_webpage(url, playlist_id) |
|
|
|
playlist = self._parse_json(self._search_regex( |
|
r'DataStore\.media\s*=\s*([^;]+)', webpage, 'media data'), |
|
playlist_id) |
|
|
|
playlist_title = self._og_search_title(webpage) |
|
|
|
entries = [] |
|
for video in playlist: |
|
payload = video.get('payload') |
|
if not payload: |
|
continue |
|
playwire_url = self._html_search_regex( |
|
r'data-config="([^"]+)"', payload, |
|
'playwire url', default=None) |
|
if playwire_url: |
|
entries.append(self.url_result(self._proto_relative_url( |
|
playwire_url, 'http:'), 'Playwire')) |
|
|
|
streamable_url = StreamableIE._extract_url(payload) |
|
if streamable_url: |
|
entries.append(self.url_result( |
|
streamable_url, StreamableIE.ie_key())) |
|
|
|
return self.playlist_result(entries, playlist_id, playlist_title)
|
|
|