aboutsummaryrefslogtreecommitdiffstats
path: root/yt_dlp/extractor/npr.py
diff options
context:
space:
mode:
Diffstat (limited to 'yt_dlp/extractor/npr.py')
-rw-r--r--yt_dlp/extractor/npr.py16
1 files changed, 5 insertions, 11 deletions
diff --git a/yt_dlp/extractor/npr.py b/yt_dlp/extractor/npr.py
index e4ff8d6c2..e677e862d 100644
--- a/yt_dlp/extractor/npr.py
+++ b/yt_dlp/extractor/npr.py
@@ -1,9 +1,5 @@
from .common import InfoExtractor
-from ..utils import (
- int_or_none,
- qualities,
- url_or_none,
-)
+from ..utils import int_or_none, qualities, traverse_obj, url_or_none
class NprIE(InfoExtractor):
@@ -74,10 +70,6 @@ class NprIE(InfoExtractor):
})['list']['story'][0]
playlist_title = story.get('title', {}).get('$text')
- # Fetch the JSON-LD from the npr page.
- json_ld = self._search_json_ld(
- self._download_webpage(url, playlist_id), playlist_id, 'NewsArticle', fatal=False)
-
KNOWN_FORMATS = ('threegp', 'm3u8', 'smil', 'mp4', 'mp3')
quality = qualities(KNOWN_FORMATS)
@@ -124,8 +116,10 @@ class NprIE(InfoExtractor):
stream_url, stream_id, 'mp4', 'm3u8_native',
m3u8_id='hls', fatal=False))
- if not formats and json_ld.get('url'):
- formats.extend(self._extract_m3u8_formats(json_ld['url'], media_id, 'mp4', m3u8_id='hls', fatal=False))
+ if not formats:
+ raw_json_ld = self._yield_json_ld(self._download_webpage(url, playlist_id), playlist_id, fatal=False)
+ m3u8_url = traverse_obj(list(raw_json_ld), (..., 'subjectOf', ..., 'embedUrl'), get_all=False)
+ formats = self._extract_m3u8_formats(m3u8_url, media_id, 'mp4', m3u8_id='hls', fatal=False)
self._sort_formats(formats)