]>
Raphaël G. Git Repositories - youtubedl/blob - youtube_dl/extractor/tv4.py
2 from __future__
import unicode_literals
4 from . common
import InfoExtractor
5 from .. compat
import compat_str
14 class TV4IE ( InfoExtractor
):
15 IE_DESC
= 'tv4.se and tv4play.se'
16 _VALID_URL
= r
'''(?x)https?://(?:www\.)?
18 tv4\.se/(?:[^/]+)/klipp/(?:.*)-|
21 (?:program|barn)/(?:[^\?]+)\?video_id=|
29 'url' : 'http://www.tv4.se/kalla-fakta/klipp/kalla-fakta-5-english-subtitles-2491650' ,
30 'md5' : 'cb837212f342d77cec06e6dad190e96d' ,
34 'title' : 'Kalla Fakta 5 (english subtitles)' ,
35 'thumbnail' : r
're:^https?://.*\.jpg$' ,
37 'upload_date' : '20131125' ,
41 'url' : 'http://www.tv4play.se/iframe/video/3054113' ,
42 'md5' : 'cb837212f342d77cec06e6dad190e96d' ,
46 'title' : 'Så här jobbar ficktjuvarna - se avslöjande bilder' ,
47 'thumbnail' : r
're:^https?://.*\.jpg$' ,
48 'description' : 'Unika bilder avslöjar hur turisternas fickor vittjas mitt på Stockholms central. Två experter på ficktjuvarna avslöjar knepen du ska se upp för.' ,
50 'upload_date' : '20150130' ,
54 'url' : 'http://www.tv4play.se/sport/3060959' ,
55 'only_matching' : True ,
58 'url' : 'http://www.tv4play.se/film/2378136' ,
59 'only_matching' : True ,
62 'url' : 'http://www.tv4play.se/barn/looney-tunes?video_id=3062412' ,
63 'only_matching' : True ,
67 def _real_extract ( self
, url
):
68 video_id
= self
._ match
_ id
( url
)
70 info
= self
._ download
_ json
(
71 'http://www.tv4play.se/player/assets/ %s .json' % video_id
,
72 video_id
, 'Downloading video info JSON' )
74 # If is_geo_restricted is true, it doesn't necessarily mean we can't download it
75 if info
. get ( 'is_geo_restricted' ):
76 self
. report_warning ( 'This content might not be available in your country due to licensing restrictions.' )
82 # http formats are linked with unresolvable host
83 for kind
in ( 'hls' , '' ):
84 data
= self
._ download
_ json
(
85 'https://prima.tv4play.se/api/web/asset/ %s /play.json' % video_id
,
86 video_id
, 'Downloading sources JSON' , query
={
88 'videoFormat' : 'MP4+WEBVTT' ,
90 items
= try_get ( data
, lambda x
: x
[ 'playback' ][ 'items' ][ 'item' ])
93 if isinstance ( items
, dict ):
96 manifest_url
= item
. get ( 'url' )
97 if not isinstance ( manifest_url
, compat_str
):
99 ext
= determine_ext ( manifest_url
)
101 formats
. extend ( self
._ extract
_ m
3u8_ formats
(
102 manifest_url
, video_id
, 'mp4' , entry_protocol
= 'm3u8_native' ,
103 m3u8_id
= kind
, fatal
= False ))
105 formats
. extend ( self
._ extract
_ akamai
_ formats
(
106 manifest_url
, video_id
, {
107 'hls' : 'tv4play-i.akamaihd.net' ,
109 elif ext
== 'webvtt' :
110 subtitles
= self
._ merge
_ subtitles
(
116 self
._ sort
_ formats
( formats
)
122 'subtitles' : subtitles
,
123 'description' : info
. get ( 'description' ),
124 'timestamp' : parse_iso8601 ( info
. get ( 'broadcast_date_time' )),
125 'duration' : int_or_none ( info
. get ( 'duration' )),
126 'thumbnail' : info
. get ( 'image' ),
127 'is_live' : info
. get ( 'is_live' ) is True ,