2014-02-24 14:00:31 +01:00
from __future__ import unicode_literals
2013-08-27 12:38:30 +02:00
import re
from . common import InfoExtractor
2016-03-17 16:07:36 +01:00
from . theplatform import ThePlatformIE
2017-02-08 16:23:42 +01:00
from . adobepass import AdobePassIE
2014-12-13 12:24:42 +01:00
from . . utils import (
2014-07-23 01:47:18 +02:00
find_xpath_attr ,
2015-12-08 16:16:14 +01:00
smuggle_url ,
2015-05-04 15:53:05 +02:00
unescapeHTML ,
2016-12-17 18:11:13 +01:00
update_url_query ,
2017-02-08 16:23:42 +01:00
int_or_none ,
2014-07-23 01:47:18 +02:00
)
2013-08-27 12:38:30 +02:00
2017-02-08 16:23:42 +01:00
class NBCIE ( AdobePassIE ) :
2017-05-07 10:31:14 +02:00
_VALID_URL = r ' (?P<permalink>https?://(?:www \ .)?nbc \ .com/[^/]+/video/[^/]+/(?P<id>n? \ d+)) '
2014-12-12 17:10:32 +01:00
_TESTS = [
{
2017-02-08 16:23:42 +01:00
' url ' : ' http://www.nbc.com/the-tonight-show/video/jimmy-fallon-surprises-fans-at-ben-jerrys/2848237 ' ,
2014-12-12 17:10:32 +01:00
' info_dict ' : {
2017-02-08 16:23:42 +01:00
' id ' : ' 2848237 ' ,
2016-01-30 21:34:46 +01:00
' ext ' : ' mp4 ' ,
2015-02-19 15:00:39 +01:00
' title ' : ' Jimmy Fallon Surprises Fans at Ben & Jerry \' s ' ,
' description ' : ' Jimmy gives out free scoops of his new " Tonight Dough " ice cream flavor by surprising customers at the Ben & Jerry \' s scoop shop. ' ,
2016-04-01 19:06:11 +02:00
' timestamp ' : 1424246400 ,
' upload_date ' : ' 20150218 ' ,
' uploader ' : ' NBCU-COM ' ,
2014-12-12 17:10:32 +01:00
} ,
2016-01-30 21:34:46 +01:00
' params ' : {
# m3u8 download
' skip_download ' : True ,
} ,
2014-02-25 23:57:54 +01:00
} ,
2015-05-04 13:09:18 +02:00
{
' url ' : ' http://www.nbc.com/saturday-night-live/video/star-wars-teaser/2832821 ' ,
' info_dict ' : {
2016-01-30 21:34:46 +01:00
' id ' : ' 2832821 ' ,
' ext ' : ' mp4 ' ,
2015-05-04 13:09:18 +02:00
' title ' : ' Star Wars Teaser ' ,
' description ' : ' md5:0b40f9cbde5b671a7ff62fceccc4f442 ' ,
2016-04-01 19:06:11 +02:00
' timestamp ' : 1417852800 ,
' upload_date ' : ' 20141206 ' ,
' uploader ' : ' NBCU-COM ' ,
2015-05-04 13:09:18 +02:00
} ,
2016-01-30 21:34:46 +01:00
' params ' : {
# m3u8 download
' skip_download ' : True ,
} ,
2015-05-04 13:09:18 +02:00
' skip ' : ' Only works from US ' ,
2015-05-04 15:53:05 +02:00
} ,
2016-06-08 14:50:01 +02:00
{
# HLS streams requires the 'hdnea3' cookie
' url ' : ' http://www.nbc.com/Kings/video/goliath/n1806 ' ,
' info_dict ' : {
2017-02-08 16:23:42 +01:00
' id ' : ' 101528f5a9e8127b107e98c5e6ce4638 ' ,
2016-06-08 14:50:01 +02:00
' ext ' : ' mp4 ' ,
' title ' : ' Goliath ' ,
' description ' : ' When an unknown soldier saves the life of the King \' s son in battle, he \' s thrust into the limelight and politics of the kingdom. ' ,
' timestamp ' : 1237100400 ,
' upload_date ' : ' 20090315 ' ,
' uploader ' : ' NBCU-COM ' ,
} ,
' params ' : {
' skip_download ' : True ,
} ,
' skip ' : ' Only works from US ' ,
2015-05-04 13:09:18 +02:00
}
2014-12-12 17:10:32 +01:00
]
2014-02-25 23:57:54 +01:00
def _real_extract ( self , url ) :
2017-05-07 10:31:14 +02:00
permalink , video_id = re . match ( self . _VALID_URL , url ) . groups ( )
2017-05-07 09:58:34 +02:00
video_data = self . _download_json (
' https://api.nbc.com/v3/videos ' , video_id , query = {
2017-05-07 10:31:14 +02:00
' filter[permalink] ' : permalink ,
2017-05-07 09:58:34 +02:00
} ) [ ' data ' ] [ 0 ] [ ' attributes ' ]
query = {
' mbr ' : ' true ' ,
' manifest ' : ' m3u ' ,
}
video_id = video_data [ ' guid ' ]
title = video_data [ ' title ' ]
if video_data . get ( ' entitlement ' ) == ' auth ' :
resource = self . _get_mvpd_resource (
' nbcentertainment ' , title , video_id ,
video_data . get ( ' vChipRating ' ) )
query [ ' auth ' ] = self . _extract_mvpd_auth (
url , video_id , ' nbcentertainment ' , resource )
theplatform_url = smuggle_url ( update_url_query (
' http://link.theplatform.com/s/NnzsPC/media/guid/2410887629/ ' + video_id ,
query ) , { ' force_smil_url ' : True } )
return {
2016-01-30 21:34:46 +01:00
' _type ' : ' url_transparent ' ,
' id ' : video_id ,
2017-05-07 09:58:34 +02:00
' title ' : title ,
' url ' : theplatform_url ,
' description ' : video_data . get ( ' description ' ) ,
' keywords ' : video_data . get ( ' keywords ' ) ,
' season_number ' : int_or_none ( video_data . get ( ' seasonNumber ' ) ) ,
' episode_number ' : int_or_none ( video_data . get ( ' episodeNumber ' ) ) ,
' series ' : video_data . get ( ' showName ' ) ,
' ie_key ' : ' ThePlatform ' ,
2016-01-30 21:34:46 +01:00
}
2014-02-25 23:57:54 +01:00
2015-03-30 20:47:18 +02:00
class NBCSportsVPlayerIE ( InfoExtractor ) :
2015-03-30 21:36:09 +02:00
_VALID_URL = r ' https?://vplayer \ .nbcsports \ .com/(?:[^/]+/)+(?P<id>[0-9a-zA-Z_]+) '
2015-03-30 20:21:27 +02:00
2015-03-30 21:38:45 +02:00
_TESTS = [ {
2015-03-30 20:21:27 +02:00
' url ' : ' https://vplayer.nbcsports.com/p/BxmELC/nbcsports_share/select/9CsDKds0kvHI ' ,
' info_dict ' : {
' id ' : ' 9CsDKds0kvHI ' ,
' ext ' : ' flv ' ,
' description ' : ' md5:df390f70a9ba7c95ff1daace988f0d8d ' ,
' title ' : ' Tyler Kalinoski hits buzzer-beater to lift Davidson ' ,
2016-04-01 19:06:11 +02:00
' timestamp ' : 1426270238 ,
' upload_date ' : ' 20150313 ' ,
' uploader ' : ' NBCU-SPORTS ' ,
2015-03-30 20:21:27 +02:00
}
2015-03-30 21:38:45 +02:00
} , {
' url ' : ' http://vplayer.nbcsports.com/p/BxmELC/nbc_embedshare/select/_hqLjQ95yx8Z ' ,
' only_matching ' : True ,
} ]
2015-03-30 20:21:27 +02:00
2015-03-30 20:47:18 +02:00
@staticmethod
def _extract_url ( webpage ) :
iframe_m = re . search (
r ' <iframe[^>]+src= " (?P<url>https?://vplayer \ .nbcsports \ .com/[^ " ]+) " ' , webpage )
if iframe_m :
return iframe_m . group ( ' url ' )
2015-03-30 20:21:27 +02:00
def _real_extract ( self , url ) :
video_id = self . _match_id ( url )
webpage = self . _download_webpage ( url , video_id )
theplatform_url = self . _og_search_video_url ( webpage )
return self . url_result ( theplatform_url , ' ThePlatform ' )
2015-03-30 20:47:18 +02:00
class NBCSportsIE ( InfoExtractor ) :
2016-01-10 16:17:47 +01:00
# Does not include https because its certificate is invalid
2016-09-08 13:29:05 +02:00
_VALID_URL = r ' https?://(?:www \ .)?nbcsports \ .com//?(?:[^/]+/)+(?P<id>[0-9a-z-]+) '
2015-03-30 20:47:18 +02:00
_TEST = {
' url ' : ' http://www.nbcsports.com//college-basketball/ncaab/tom-izzo-michigan-st-has-so-much-respect-duke ' ,
' info_dict ' : {
' id ' : ' PHJSaFWbrTY9 ' ,
' ext ' : ' flv ' ,
' title ' : ' Tom Izzo, Michigan St. has \' so much respect \' for Duke ' ,
' description ' : ' md5:ecb459c9d59e0766ac9c7d5d0eda8113 ' ,
2016-04-24 14:44:52 +02:00
' uploader ' : ' NBCU-SPORTS ' ,
' upload_date ' : ' 20150330 ' ,
' timestamp ' : 1427726529 ,
2015-03-30 20:47:18 +02:00
}
}
def _real_extract ( self , url ) :
video_id = self . _match_id ( url )
webpage = self . _download_webpage ( url , video_id )
return self . url_result (
NBCSportsVPlayerIE . _extract_url ( webpage ) , ' NBCSportsVPlayer ' )
2016-03-31 01:26:42 +02:00
class CSNNEIE ( InfoExtractor ) :
2016-09-08 13:29:05 +02:00
_VALID_URL = r ' https?://(?:www \ .)?csnne \ .com/video/(?P<id>[0-9a-z-]+) '
2016-03-31 01:26:42 +02:00
_TEST = {
' url ' : ' http://www.csnne.com/video/snc-evening-update-wright-named-red-sox-no-5-starter ' ,
' info_dict ' : {
' id ' : ' yvBLLUgQ8WU0 ' ,
' ext ' : ' mp4 ' ,
' title ' : ' SNC evening update: Wright named Red Sox \' No. 5 starter. ' ,
' description ' : ' md5:1753cfee40d9352b19b4c9b3e589b9e3 ' ,
2016-04-01 19:06:11 +02:00
' timestamp ' : 1459369979 ,
' upload_date ' : ' 20160330 ' ,
' uploader ' : ' NBCU-SPORTS ' ,
2016-03-31 01:26:42 +02:00
}
}
def _real_extract ( self , url ) :
display_id = self . _match_id ( url )
webpage = self . _download_webpage ( url , display_id )
return {
' _type ' : ' url_transparent ' ,
' ie_key ' : ' ThePlatform ' ,
' url ' : self . _html_search_meta ( ' twitter:player:stream ' , webpage ) ,
' display_id ' : display_id ,
}
2016-03-17 16:07:36 +01:00
class NBCNewsIE ( ThePlatformIE ) :
2016-06-23 02:36:19 +02:00
_VALID_URL = r ''' (?x)https?://(?:www \ .)?(?:nbcnews|today|msnbc) \ .com/
2015-02-14 12:42:12 +01:00
( ? : video / . + ? / ( ? P < id > \d + ) |
2016-06-23 02:36:19 +02:00
( [ ^ / ] + / ) * ( ? : . * - ) ? ( ? P < mpx_id > [ ^ / ? ] + ) )
2014-05-30 00:38:57 +02:00
'''
2013-08-27 12:38:30 +02:00
2014-05-30 00:38:57 +02:00
_TESTS = [
{
' url ' : ' http://www.nbcnews.com/video/nbc-news/52753292 ' ,
' md5 ' : ' 47abaac93c6eaf9ad37ee6c4463a5179 ' ,
' info_dict ' : {
' id ' : ' 52753292 ' ,
' ext ' : ' flv ' ,
' title ' : ' Crew emerges after four-month Mars food study ' ,
' description ' : ' md5:24e632ffac72b35f8b67a12d1b6ddfc1 ' ,
} ,
2013-08-27 12:38:30 +02:00
} ,
2014-05-30 00:38:57 +02:00
{
2016-03-17 16:07:36 +01:00
' url ' : ' http://www.nbcnews.com/watch/nbcnews-com/how-twitter-reacted-to-the-snowden-interview-269389891880 ' ,
' md5 ' : ' af1adfa51312291a017720403826bb64 ' ,
2014-05-30 00:38:57 +02:00
' info_dict ' : {
2016-12-17 18:11:13 +01:00
' id ' : ' p_tweet_snow_140529 ' ,
2014-10-27 01:14:17 +01:00
' ext ' : ' mp4 ' ,
2014-05-30 00:38:57 +02:00
' title ' : ' How Twitter Reacted To The Snowden Interview ' ,
' description ' : ' md5:65a0bd5d76fe114f3c2727aa3a81fe64 ' ,
2016-06-23 02:36:19 +02:00
' uploader ' : ' NBCU-NEWS ' ,
' timestamp ' : 1401363060 ,
' upload_date ' : ' 20140529 ' ,
2014-05-30 00:38:57 +02:00
} ,
} ,
2015-01-20 16:23:51 +01:00
{
' url ' : ' http://www.nbcnews.com/feature/dateline-full-episodes/full-episode-family-business-n285156 ' ,
' md5 ' : ' fdbf39ab73a72df5896b6234ff98518a ' ,
' info_dict ' : {
2016-06-23 02:36:19 +02:00
' id ' : ' 529953347624 ' ,
2015-01-20 16:23:51 +01:00
' ext ' : ' mp4 ' ,
' title ' : ' FULL EPISODE: Family Business ' ,
' description ' : ' md5:757988edbaae9d7be1d585eb5d55cc04 ' ,
} ,
2016-03-17 16:07:36 +01:00
' skip ' : ' This page is unavailable. ' ,
2015-01-20 16:23:51 +01:00
} ,
2015-02-14 11:10:23 +01:00
{
' url ' : ' http://www.nbcnews.com/nightly-news/video/nightly-news-with-brian-williams-full-broadcast-february-4-394064451844 ' ,
2016-03-17 16:07:36 +01:00
' md5 ' : ' 73135a2e0ef819107bbb55a5a9b2a802 ' ,
2015-02-14 11:10:23 +01:00
' info_dict ' : {
2016-12-17 18:11:13 +01:00
' id ' : ' nn_netcast_150204 ' ,
2015-02-14 11:10:23 +01:00
' ext ' : ' mp4 ' ,
' title ' : ' Nightly News with Brian Williams Full Broadcast (February 4) ' ,
' description ' : ' md5:1c10c1eccbe84a26e5debb4381e2d3c5 ' ,
2016-06-23 02:36:19 +02:00
' timestamp ' : 1423104900 ,
' uploader ' : ' NBCU-NEWS ' ,
' upload_date ' : ' 20150205 ' ,
2015-02-14 11:10:23 +01:00
} ,
} ,
2016-03-17 16:07:36 +01:00
{
' url ' : ' http://www.nbcnews.com/business/autos/volkswagen-11-million-vehicles-could-have-suspect-software-emissions-scandal-n431456 ' ,
' md5 ' : ' a49e173825e5fcd15c13fc297fced39d ' ,
' info_dict ' : {
2016-12-17 18:11:13 +01:00
' id ' : ' x_lon_vwhorn_150922 ' ,
2016-03-17 16:07:36 +01:00
' ext ' : ' mp4 ' ,
2016-06-23 02:36:19 +02:00
' title ' : ' Volkswagen U.S. Chief: \xa0 We Have Totally Screwed Up ' ,
' description ' : ' md5:c8be487b2d80ff0594c005add88d8351 ' ,
' upload_date ' : ' 20150922 ' ,
' timestamp ' : 1442917800 ,
' uploader ' : ' NBCU-NEWS ' ,
2016-03-17 16:07:36 +01:00
} ,
} ,
2016-04-22 19:07:40 +02:00
{
' url ' : ' http://www.today.com/video/see-the-aurora-borealis-from-space-in-stunning-new-nasa-video-669831235788 ' ,
' md5 ' : ' 118d7ca3f0bea6534f119c68ef539f71 ' ,
' info_dict ' : {
2016-12-17 18:11:13 +01:00
' id ' : ' tdy_al_space_160420 ' ,
2016-04-22 19:07:40 +02:00
' ext ' : ' mp4 ' ,
' title ' : ' See the aurora borealis from space in stunning new NASA video ' ,
' description ' : ' md5:74752b7358afb99939c5f8bb2d1d04b1 ' ,
' upload_date ' : ' 20160420 ' ,
' timestamp ' : 1461152093 ,
2016-06-23 02:36:19 +02:00
' uploader ' : ' NBCU-NEWS ' ,
} ,
} ,
{
' url ' : ' http://www.msnbc.com/all-in-with-chris-hayes/watch/the-chaotic-gop-immigration-vote-314487875924 ' ,
' md5 ' : ' 6d236bf4f3dddc226633ce6e2c3f814d ' ,
' info_dict ' : {
2016-12-17 18:11:13 +01:00
' id ' : ' n_hayes_Aimm_140801_272214 ' ,
2016-06-23 02:36:19 +02:00
' ext ' : ' mp4 ' ,
' title ' : ' The chaotic GOP immigration vote ' ,
' description ' : ' The Republican House votes on a border bill that has no chance of getting through the Senate or signed by the President and is drawing criticism from all sides. ' ,
2017-01-02 13:08:07 +01:00
' thumbnail ' : r ' re:^https?://.* \ .jpg$ ' ,
2016-06-23 02:36:19 +02:00
' timestamp ' : 1406937606 ,
' upload_date ' : ' 20140802 ' ,
' uploader ' : ' NBCU-NEWS ' ,
2016-04-22 19:07:40 +02:00
} ,
} ,
2015-08-01 17:43:33 +02:00
{
' url ' : ' http://www.nbcnews.com/watch/dateline/full-episode--deadly-betrayal-386250819952 ' ,
' only_matching ' : True ,
} ,
2016-06-10 07:31:55 +02:00
{
# From http://www.vulture.com/2016/06/letterman-couldnt-care-less-about-late-night.html
' url ' : ' http://www.nbcnews.com/widget/video-embed/701714499682 ' ,
' only_matching ' : True ,
} ,
2014-05-30 00:38:57 +02:00
]
2013-08-27 12:38:30 +02:00
def _real_extract ( self , url ) :
mobj = re . match ( self . _VALID_URL , url )
video_id = mobj . group ( ' id ' )
2014-05-30 00:38:57 +02:00
if video_id is not None :
all_info = self . _download_xml ( ' http://www.nbcnews.com/id/ %s /displaymode/1219 ' % video_id , video_id )
info = all_info . find ( ' video ' )
2013-08-27 12:38:30 +02:00
2014-05-30 00:38:57 +02:00
return {
' id ' : video_id ,
' title ' : info . find ( ' headline ' ) . text ,
' ext ' : ' flv ' ,
' url ' : find_xpath_attr ( info , ' media ' , ' type ' , ' flashVideo ' ) . text ,
2015-12-20 01:43:42 +01:00
' description ' : info . find ( ' caption ' ) . text ,
2014-05-30 00:38:57 +02:00
' thumbnail ' : find_xpath_attr ( info , ' media ' , ' type ' , ' thumbnail ' ) . text ,
}
else :
2015-02-14 11:10:23 +01:00
# "feature" and "nightly-news" pages use theplatform.com
2016-06-23 02:36:19 +02:00
video_id = mobj . group ( ' mpx_id ' )
2016-12-17 18:11:13 +01:00
webpage = self . _download_webpage ( url , video_id )
filter_param = ' byId '
bootstrap_json = self . _search_regex (
[ r ' (?m)(?:var \ s+(?:bootstrapJson|playlistData)|NEWS \ .videoObj) \ s*= \ s*( { .+});? \ s*$ ' ,
r ' videoObj \ s*: \ s*( { .+}) ' , r ' data-video= " ([^ " ]+) " ' ,
r ' jQuery \ .extend \ (Drupal \ .settings \ s*, \ s*( { .+?}) \ ); ' ] ,
webpage , ' bootstrap json ' , default = None )
if bootstrap_json :
2016-06-23 02:36:19 +02:00
bootstrap = self . _parse_json (
bootstrap_json , video_id , transform_source = unescapeHTML )
2016-12-17 18:11:13 +01:00
info = None
2016-06-23 02:36:19 +02:00
if ' results ' in bootstrap :
info = bootstrap [ ' results ' ] [ 0 ] [ ' video ' ]
elif ' video ' in bootstrap :
info = bootstrap [ ' video ' ]
2016-12-17 18:11:13 +01:00
elif ' msnbcVideoInfo ' in bootstrap :
info = bootstrap [ ' msnbcVideoInfo ' ] [ ' meta ' ]
elif ' msnbcThePlatform ' in bootstrap :
info = bootstrap [ ' msnbcThePlatform ' ] [ ' videoPlayer ' ] [ ' video ' ]
2016-03-17 16:07:36 +01:00
else :
2016-06-23 02:36:19 +02:00
info = bootstrap
2016-12-17 18:11:13 +01:00
if ' guid ' in info :
video_id = info [ ' guid ' ]
filter_param = ' byGuid '
elif ' mpxId ' in info :
video_id = info [ ' mpxId ' ]
2014-05-30 00:38:57 +02:00
return {
2016-06-23 02:36:19 +02:00
' _type ' : ' url_transparent ' ,
2016-03-17 16:07:36 +01:00
' id ' : video_id ,
2016-06-23 02:36:19 +02:00
# http://feed.theplatform.com/f/2E2eJC/nbcnews also works
2016-12-17 18:11:13 +01:00
' url ' : update_url_query ( ' http://feed.theplatform.com/f/2E2eJC/nnd_NBCNews ' , { filter_param : video_id } ) ,
2016-06-23 02:36:19 +02:00
' ie_key ' : ' ThePlatformFeed ' ,
2014-05-30 00:38:57 +02:00
}
2016-09-11 20:55:15 +02:00
class NBCOlympicsIE ( InfoExtractor ) :
_VALID_URL = r ' https?://www \ .nbcolympics \ .com/video/(?P<id>[a-z-]+) '
_TEST = {
# Geo-restricted to US
' url ' : ' http://www.nbcolympics.com/video/justin-roses-son-leo-was-tears-after-his-dad-won-gold ' ,
' md5 ' : ' 54fecf846d05429fbaa18af557ee523a ' ,
' info_dict ' : {
' id ' : ' WjTBzDXx5AUq ' ,
' display_id ' : ' justin-roses-son-leo-was-tears-after-his-dad-won-gold ' ,
' ext ' : ' mp4 ' ,
' title ' : ' Rose \' s son Leo was in tears after his dad won gold ' ,
' description ' : ' Olympic gold medalist Justin Rose gets emotional talking to the impact his win in men \' s golf has already had on his children. ' ,
' timestamp ' : 1471274964 ,
' upload_date ' : ' 20160815 ' ,
' uploader ' : ' NBCU-SPORTS ' ,
} ,
}
def _real_extract ( self , url ) :
display_id = self . _match_id ( url )
webpage = self . _download_webpage ( url , display_id )
drupal_settings = self . _parse_json ( self . _search_regex (
r ' jQuery \ .extend \ (Drupal \ .settings \ s*, \ s*( { .+?}) \ ); ' ,
webpage , ' drupal settings ' ) , display_id )
iframe_url = drupal_settings [ ' vod ' ] [ ' iframe_url ' ]
theplatform_url = iframe_url . replace (
' vplayer.nbcolympics.com ' , ' player.theplatform.com ' )
return {
' _type ' : ' url_transparent ' ,
' url ' : theplatform_url ,
' ie_key ' : ThePlatformIE . ie_key ( ) ,
' display_id ' : display_id ,
}