Compare commits

..

No commits in common. "f3f5d080bdff666c535f39e4ab0a1fea9095d5bd" and "8f03e0301bb176f2ddda9adaf2598b67e4713777" have entirely different histories.

View File

@ -2,28 +2,21 @@ import json
from .brightcove import BrightcoveNewIE
from .common import InfoExtractor
from ..utils import ExtractorError
from ..utils.traversal import traverse_obj
class LaXarxaMesIE(InfoExtractor):
_VALID_URL = r'https?://(?:www\.)?laxarxames\.cat/(?:[^/?#]+/)*?(player|movie-details)/(?P<id>\d+)'
_VALID_URL = r'https?://(?:www\.)?laxarxames\.cat/(?:[^/]+/)*?(player|movie-details)/(?P<id>[0-9]+)'
_NETRC_MACHINE = 'laxarxames'
_TOKEN = None
_LOGIN_URL = 'https://www.laxarxames.cat/login'
_TESTS = [{
'url': 'https://www.laxarxames.cat/player/3459421',
'md5': '0966f46c34275934c19af78f3df6e2bc',
'info_dict': {
'id': '6339612436112',
'id': '3459421',
'ext': 'mp4',
'title': 'Resum | UA Horta — UD Viladecans',
'timestamp': 1697905186,
'thumbnail': r're:https?://.*\.jpg',
'description': '',
'upload_date': '20231021',
'duration': 129.44,
'tags': ['ott', 'esports', '23-24', ' futbol', ' futbol-partits', 'elit', 'resum'],
'uploader_id': '5779379807001',
'type': 'video/mp4',
},
'skip': 'Requires login',
}]
@ -35,6 +28,8 @@ class LaXarxaMesIE(InfoExtractor):
'https://api.laxarxames.cat/Authorization/SignIn', None, note='Logging in', headers={
'X-Tenantorigin': 'https://laxarxames.cat',
'Content-Type': 'application/json',
'Accept': 'application/json, text/plain, */*',
'Origin': 'https://www.laxarxames.cat',
}, data=json.dumps({
'Username': username,
'Password': password,
@ -42,30 +37,38 @@ class LaXarxaMesIE(InfoExtractor):
'PlatformCode': 'WEB',
'Name': 'Mac OS ()',
},
}).encode('utf-8'), expected_status=401)
}).encode('utf-8')
)
if not traverse_obj(login, ('AuthorizationToken', 'Token', {str})):
raise ExtractorError('Login failed', expected=True)
self._TOKEN = login['AuthorizationToken']['Token']
if not login['AuthorizationToken']:
raise Exception('Login failed')
else:
self._TOKEN = login['AuthorizationToken']['Token']
def _real_extract(self, url):
video_id = self._match_id(url)
if not self._TOKEN:
self.raise_login_required()
media_play_info = self._download_json(
'https://api.laxarxames.cat/Media/GetMediaPlayInfo', video_id,
mediaplayinfo = self._download_json(
'https://api.laxarxames.cat/Media/GetMediaPlayInfo',
video_id,
data=json.dumps({
'MediaId': int(video_id),
'StreamType': 'MAIN'
}).encode('utf-8'), headers={
'Authorization': f'Bearer {self._TOKEN}',
}).encode('utf-8'),
headers={
'Authorization': 'Bearer ' + self._TOKEN,
'X-Tenantorigin': 'https://laxarxames.cat',
'Content-Type': 'application/json',
})
'Accept': 'application/json, text/plain, */*',
'Origin': 'https://www.laxarxames.cat',
}
)
content_url = mediaplayinfo['ContentUrl']
video_title = mediaplayinfo['Title']
if not traverse_obj(media_play_info, ('ContentUrl', {str})):
self.raise_no_formats('No video found', expected=True)
return self.url_result(
f'https://players.brightcove.net/5779379807001/default_default/index.html?videoId={media_play_info["ContentUrl"]}',
BrightcoveNewIE, video_id, media_play_info.get('Title'))
f'http://players.brightcove.net/5779379807001/default_default/index.html?videoId={content_url}',
BrightcoveNewIE, video_id, video_title)