2017-02-28 23:37:33 +07:00
|
|
|
# coding: utf-8
|
2017-01-22 02:15:20 +07:00
|
|
|
from __future__ import unicode_literals
|
|
|
|
|
2018-10-02 14:49:01 +02:00
|
|
|
import json
|
2017-01-22 02:15:20 +07:00
|
|
|
import re
|
|
|
|
|
|
|
|
from .common import InfoExtractor
|
|
|
|
from .kaltura import KalturaIE
|
|
|
|
|
|
|
|
|
2018-11-03 01:32:29 +07:00
|
|
|
class AZMedienIE(InfoExtractor):
|
2017-01-22 02:15:20 +07:00
|
|
|
IE_DESC = 'AZ Medien videos'
|
|
|
|
_VALID_URL = r'''(?x)
|
|
|
|
https?://
|
|
|
|
(?:www\.)?
|
2018-10-02 14:49:01 +02:00
|
|
|
(?P<host>
|
2017-01-22 02:15:20 +07:00
|
|
|
telezueri\.ch|
|
|
|
|
telebaern\.tv|
|
|
|
|
telem1\.ch
|
|
|
|
)/
|
2018-10-02 14:49:01 +02:00
|
|
|
[^/]+/
|
|
|
|
(?P<id>
|
|
|
|
[^/]+-(?P<article_id>\d+)
|
2017-01-22 02:15:20 +07:00
|
|
|
)
|
2018-10-02 14:49:01 +02:00
|
|
|
(?:
|
|
|
|
\#video=
|
|
|
|
(?P<kaltura_id>
|
|
|
|
[_0-9a-z]+
|
|
|
|
)
|
|
|
|
)?
|
2017-01-22 02:15:20 +07:00
|
|
|
'''
|
|
|
|
|
|
|
|
_TESTS = [{
|
2018-10-02 14:49:01 +02:00
|
|
|
'url': 'https://www.telezueri.ch/sonntalk/bundesrats-vakanzen-eu-rahmenabkommen-133214569',
|
2017-01-22 02:15:20 +07:00
|
|
|
'info_dict': {
|
2018-10-02 14:49:01 +02:00
|
|
|
'id': '1_anruz3wy',
|
2017-10-20 20:10:56 +02:00
|
|
|
'ext': 'mp4',
|
2018-10-02 14:49:01 +02:00
|
|
|
'title': 'Bundesrats-Vakanzen / EU-Rahmenabkommen',
|
|
|
|
'description': 'md5:dd9f96751ec9c35e409a698a328402f3',
|
|
|
|
'uploader_id': 'TVOnline',
|
|
|
|
'upload_date': '20180930',
|
|
|
|
'timestamp': 1538328802,
|
2017-01-22 02:15:20 +07:00
|
|
|
},
|
|
|
|
'params': {
|
|
|
|
'skip_download': True,
|
|
|
|
},
|
|
|
|
}, {
|
2018-10-02 14:49:01 +02:00
|
|
|
'url': 'https://www.telebaern.tv/telebaern-news/montag-1-oktober-2018-ganze-sendung-133531189#video=0_7xjo9lf1',
|
2017-01-22 02:15:20 +07:00
|
|
|
'only_matching': True
|
|
|
|
}]
|
|
|
|
|
2018-11-03 01:32:29 +07:00
|
|
|
_PARTNER_ID = '1719221'
|
|
|
|
|
2017-01-22 02:15:20 +07:00
|
|
|
def _real_extract(self, url):
|
2018-10-02 14:49:01 +02:00
|
|
|
mobj = re.match(self._VALID_URL, url)
|
2018-11-03 01:32:29 +07:00
|
|
|
video_id = mobj.group('id')
|
2018-10-02 14:49:01 +02:00
|
|
|
entry_id = mobj.group('kaltura_id')
|
|
|
|
|
|
|
|
if not entry_id:
|
|
|
|
webpage = self._download_webpage(url, video_id)
|
|
|
|
api_path = self._search_regex(
|
|
|
|
r'["\']apiPath["\']\s*:\s*["\']([^"^\']+)["\']',
|
|
|
|
webpage, 'api path')
|
|
|
|
api_url = 'https://www.%s%s' % (mobj.group('host'), api_path)
|
|
|
|
payload = {
|
|
|
|
'query': '''query VideoContext($articleId: ID!) {
|
|
|
|
article: node(id: $articleId) {
|
|
|
|
... on Article {
|
|
|
|
mainAssetRelation {
|
|
|
|
asset {
|
|
|
|
... on VideoAsset {
|
|
|
|
kalturaId
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}''',
|
|
|
|
'variables': {'articleId': 'Article:%s' % mobj.group('article_id')},
|
|
|
|
}
|
|
|
|
json_data = self._download_json(
|
|
|
|
api_url, video_id, headers={
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
},
|
|
|
|
data=json.dumps(payload).encode())
|
|
|
|
entry_id = json_data['data']['article']['mainAssetRelation']['asset']['kalturaId']
|
|
|
|
|
2018-11-03 01:32:29 +07:00
|
|
|
return self.url_result(
|
|
|
|
'kaltura:%s:%s' % (self._PARTNER_ID, entry_id),
|
|
|
|
ie=KalturaIE.ie_key(), video_id=entry_id)
|