mirror of
https://github.com/ytdl-org/youtube-dl
synced 2025-01-19 01:40:09 +09:00
Comply with coding conventions a bit more
This commit is contained in:
parent
21eb4513e0
commit
0dc7d954cb
@ -65,30 +65,29 @@ class NPOIE(InfoExtractor):
|
|||||||
url = url[:-9]
|
url = url[:-9]
|
||||||
elif url.endswith('/afspelen/'):
|
elif url.endswith('/afspelen/'):
|
||||||
url = url[:-10]
|
url = url[:-10]
|
||||||
if url.endswith('/'):
|
url = url.rstrip('/')
|
||||||
url = url[:-1]
|
|
||||||
slug = url.split('/')[-1]
|
slug = url.split('/')[-1]
|
||||||
page = self._download_webpage(url, slug, 'Finding productId using slug: %s' % slug)
|
page = self._download_webpage(url, slug, 'Finding productId using slug: %s' % slug)
|
||||||
# TODO find out what proper HTML parsing utilities are available in youtube-dl
|
# TODO find out what proper HTML parsing utilities are available in youtube-dl
|
||||||
next_data = page.split('<script id="__NEXT_DATA__" type="application/json">')[1].split('</script>')[0]
|
next_data = page.split('<script id="__NEXT_DATA__" type="application/json">')[1].split('</script>')[0]
|
||||||
next_data = json.loads(next_data)
|
next_data = json.loads(next_data)
|
||||||
product_id, description, thumbnail, title = None, None, None, None
|
product_id, title, description, thumbnail = None, None, None, None
|
||||||
for query in next_data['props']['pageProps']['dehydratedState']['queries']:
|
for query in next_data['props']['pageProps']['dehydratedState']['queries']:
|
||||||
if isinstance(query['state']['data'], list):
|
if isinstance(query['state']['data'], list):
|
||||||
for entry in query['state']['data']:
|
for entry in query['state']['data']:
|
||||||
print(entry)
|
|
||||||
try:
|
|
||||||
if entry['slug'] == slug:
|
if entry['slug'] == slug:
|
||||||
product_id = entry['productId']
|
product_id = entry.get('productId')
|
||||||
title = entry['title']
|
title = entry.get('title')
|
||||||
synopsis = entry['synopsis']
|
synopsis = entry.get('synopsis', {})
|
||||||
description = synopsis.get('long', synopsis.get('short', synopsis.get('brief', '')))
|
description = (
|
||||||
thumbnail = entry['images'][0]['url']
|
synopsis.get('long')
|
||||||
break
|
or synopsis.get('short')
|
||||||
except KeyError:
|
or synopsis.get('brief')
|
||||||
continue
|
)
|
||||||
except IndexError:
|
thumbnails = entry.get('images')
|
||||||
continue
|
for thumbnail_entry in thumbnails:
|
||||||
|
if 'url' in thumbnail_entry:
|
||||||
|
thumbnail = thumbnail_entry.get('url')
|
||||||
if not product_id:
|
if not product_id:
|
||||||
raise ExtractorError('No productId found for slug: %s' % slug)
|
raise ExtractorError('No productId found for slug: %s' % slug)
|
||||||
|
|
||||||
@ -97,19 +96,18 @@ class NPOIE(InfoExtractor):
|
|||||||
stream_link = self._download_json(
|
stream_link = self._download_json(
|
||||||
'https://prod.npoplayer.nl/stream-link', video_id=slug,
|
'https://prod.npoplayer.nl/stream-link', video_id=slug,
|
||||||
data=json.dumps({
|
data=json.dumps({
|
||||||
"profileName": "dash",
|
'profileName': 'dash',
|
||||||
"drmType": "widevine",
|
'drmType': 'widevine',
|
||||||
"referrerUrl": url,
|
'referrerUrl': url,
|
||||||
}).encode('utf8'),
|
}).encode('utf8'),
|
||||||
headers={
|
headers={
|
||||||
"Authorization": token,
|
'Authorization': token,
|
||||||
"Content-Type": "application/json",
|
'Content-Type': 'application/json',
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
stream_url = stream_link['stream']['streamURL']
|
|
||||||
|
|
||||||
# TODO other formats than dash / mpd
|
# TODO other formats than dash / mpd
|
||||||
|
stream_url = stream_link.get('stream', {}).get('streamURL')
|
||||||
mpd = self._extract_mpd_formats(stream_url, slug, mpd_id='dash', fatal=False)
|
mpd = self._extract_mpd_formats(stream_url, slug, mpd_id='dash', fatal=False)
|
||||||
|
|
||||||
return {
|
return {
|
||||||
|
Loading…
Reference in New Issue
Block a user