Ver Fonte

[brightcove] workaround sonyliv DRM protected videos(closes #16807)

Remita Amine há 7 anos atrás
pai
commit
74caf528bc
1 ficheiros alterados com 10 adições e 1 exclusões
  1. 10 1
      youtube_dl/extractor/brightcove.py

+ 10 - 1
youtube_dl/extractor/brightcove.py

@@ -572,7 +572,8 @@ class BrightcoveNewIE(AdobePassIE):
             container = source.get('container')
             container = source.get('container')
             ext = mimetype2ext(source.get('type'))
             ext = mimetype2ext(source.get('type'))
             src = source.get('src')
             src = source.get('src')
-            if ext == 'ism' or container == 'WVM':
+            # https://support.brightcove.com/playback-api-video-fields-reference#key_systems_object
+            if ext == 'ism' or container == 'WVM' or source.get('key_systems'):
                 continue
                 continue
             elif ext == 'm3u8' or container == 'M2TS':
             elif ext == 'm3u8' or container == 'M2TS':
                 if not src:
                 if not src:
@@ -629,6 +630,14 @@ class BrightcoveNewIE(AdobePassIE):
                         'format_id': build_format_id('rtmp'),
                         'format_id': build_format_id('rtmp'),
                     })
                     })
                 formats.append(f)
                 formats.append(f)
+        if not formats:
+            # for sonyliv.com DRM protected videos
+            s3_source_url = json_data.get('custom_fields', {}).get('s3sourceurl')
+            if s3_source_url:
+                formats.append({
+                    'url': s3_source_url,
+                    'format_id': 'source',
+                })
 
 
         errors = json_data.get('errors')
         errors = json_data.get('errors')
         if not formats and errors:
         if not formats and errors: