|
@@ -5,7 +5,10 @@ import re
|
|
|
|
|
|
from .common import InfoExtractor
|
|
|
from .nexx import NexxIE
|
|
|
-from ..utils import int_or_none
|
|
|
+from ..utils import (
|
|
|
+ int_or_none,
|
|
|
+ try_get,
|
|
|
+)
|
|
|
|
|
|
|
|
|
class FunkBaseIE(InfoExtractor):
|
|
@@ -77,6 +80,20 @@ class FunkChannelIE(FunkBaseIE):
|
|
|
'params': {
|
|
|
'skip_download': True,
|
|
|
},
|
|
|
+ }, {
|
|
|
+ # only available via byIdList API
|
|
|
+ 'url': 'https://www.funk.net/channel/informr/martin-sonneborn-erklaert-die-eu',
|
|
|
+ 'info_dict': {
|
|
|
+ 'id': '205067',
|
|
|
+ 'ext': 'mp4',
|
|
|
+ 'title': 'Martin Sonneborn erklärt die EU',
|
|
|
+ 'description': 'md5:050f74626e4ed87edf4626d2024210c0',
|
|
|
+ 'timestamp': 1494424042,
|
|
|
+ 'upload_date': '20170510',
|
|
|
+ },
|
|
|
+ 'params': {
|
|
|
+ 'skip_download': True,
|
|
|
+ },
|
|
|
}, {
|
|
|
'url': 'https://www.funk.net/channel/59d5149841dca100012511e3/mein-erster-job-lovemilla-folge-1/lovemilla/',
|
|
|
'only_matching': True,
|
|
@@ -87,16 +104,28 @@ class FunkChannelIE(FunkBaseIE):
|
|
|
channel_id = mobj.group('id')
|
|
|
alias = mobj.group('alias')
|
|
|
|
|
|
- results = self._download_json(
|
|
|
- 'https://www.funk.net/api/v3.0/content/videos/filter', channel_id,
|
|
|
- headers={
|
|
|
- 'authorization': 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJjbGllbnROYW1lIjoiY3VyYXRpb24tdG9vbCIsInNjb3BlIjoic3RhdGljLWNvbnRlbnQtYXBpLGN1cmF0aW9uLWFwaSxzZWFyY2gtYXBpIn0.q4Y2xZG8PFHai24-4Pjx2gym9RmJejtmK6lMXP5wAgc',
|
|
|
- 'Referer': url,
|
|
|
- }, query={
|
|
|
- 'channelId': channel_id,
|
|
|
- 'size': 100,
|
|
|
- })['result']
|
|
|
+ headers = {
|
|
|
+ 'authorization': 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJjbGllbnROYW1lIjoiY3VyYXRpb24tdG9vbCIsInNjb3BlIjoic3RhdGljLWNvbnRlbnQtYXBpLGN1cmF0aW9uLWFwaSxzZWFyY2gtYXBpIn0.q4Y2xZG8PFHai24-4Pjx2gym9RmJejtmK6lMXP5wAgc',
|
|
|
+ 'Referer': url,
|
|
|
+ }
|
|
|
|
|
|
- video = next(r for r in results if r.get('alias') == alias)
|
|
|
+ video = None
|
|
|
+
|
|
|
+ by_id_list = self._download_json(
|
|
|
+ 'https://www.funk.net/api/v3.0/content/videos/byIdList', channel_id,
|
|
|
+ headers=headers, query={
|
|
|
+ 'ids': alias,
|
|
|
+ }, fatal=False)
|
|
|
+ if by_id_list:
|
|
|
+ video = try_get(by_id_list, lambda x: x['result'][0], dict)
|
|
|
+
|
|
|
+ if not video:
|
|
|
+ results = self._download_json(
|
|
|
+ 'https://www.funk.net/api/v3.0/content/videos/filter', channel_id,
|
|
|
+ headers=headers, query={
|
|
|
+ 'channelId': channel_id,
|
|
|
+ 'size': 100,
|
|
|
+ })['result']
|
|
|
+ video = next(r for r in results if r.get('alias') == alias)
|
|
|
|
|
|
return self._make_url_result(video)
|