]>
jfr.im git - yt-dlp.git/blob - yt_dlp/extractor/atresplayer.py
2 from __future__
import unicode_literals
5 from .common
import InfoExtractor
6 from ..compat
import compat_HTTPError
14 class AtresPlayerIE(InfoExtractor
):
15 _VALID_URL
= r
'https?://(?:www\.)?atresplayer\.com/[^/]+/[^/]+/[^/]+/[^/]+/(?P<display_id>.+?)_(?P<id>[0-9a-f]{24})'
16 _NETRC_MACHINE
= 'atresplayer'
19 'url': 'https://www.atresplayer.com/antena3/series/pequenas-coincidencias/temporada-1/capitulo-7-asuntos-pendientes_5d4aa2c57ed1a88fc715a615/',
21 'id': '5d4aa2c57ed1a88fc715a615',
23 'title': 'CapĂtulo 7: Asuntos pendientes',
24 'description': 'md5:7634cdcb4d50d5381bedf93efb537fbc',
27 'skip': 'This video is only available for registered users'
30 'url': 'https://www.atresplayer.com/lasexta/programas/el-club-de-la-comedia/temporada-4/capitulo-10-especial-solidario-nochebuena_5ad08edf986b2855ed47adc4/',
31 'only_matching': True,
34 'url': 'https://www.atresplayer.com/antena3/series/el-secreto-de-puente-viejo/el-chico-de-los-tres-lunares/capitulo-977-29-12-14_5ad51046986b2886722ccdea/',
35 'only_matching': True,
38 _API_BASE
= 'https://api.atresplayer.com/'
40 def _real_initialize(self
):
43 def _handle_error(self
, e
, code
):
44 if isinstance(e
.cause
, compat_HTTPError
) and e
.cause
.code
== code
:
45 error
= self
._parse
_json
(e
.cause
.read(), None)
46 if error
.get('error') == 'required_registered':
47 self
.raise_login_required()
48 raise ExtractorError(error
['error_description'], expected
=True)
52 username
, password
= self
._get
_login
_info
()
56 self
._request
_webpage
(
57 self
._API
_BASE
+ 'login', None, 'Downloading login page')
60 target_url
= self
._download
_json
(
61 'https://account.atresmedia.com/api/login', None,
62 'Logging in', headers
={
63 'Content-Type': 'application/x-www-form-urlencoded'
64 }, data
=urlencode_postdata({
68 except ExtractorError
as e
:
69 self
._handle
_error
(e
, 400)
71 self
._request
_webpage
(target_url
, None, 'Following Target URL')
73 def _real_extract(self
, url
):
74 display_id
, video_id
= self
._match
_valid
_url
(url
).groups()
77 episode
= self
._download
_json
(
78 self
._API
_BASE
+ 'client/v1/player/episode/' + video_id
, video_id
)
79 except ExtractorError
as e
:
80 self
._handle
_error
(e
, 403)
82 title
= episode
['titulo']
86 for source
in episode
.get('sources', []):
87 src
= source
.get('src')
90 src_type
= source
.get('type')
91 if src_type
== 'application/vnd.apple.mpegurl':
92 formats
, subtitles
= self
._extract
_m
3u8_formats
(
93 src
, video_id
, 'mp4', 'm3u8_native',
94 m3u8_id
='hls', fatal
=False)
95 elif src_type
== 'application/dash+xml':
96 formats
, subtitles
= self
._extract
_mpd
_formats
(
97 src
, video_id
, mpd_id
='dash', fatal
=False)
98 self
._sort
_formats
(formats
)
100 heartbeat
= episode
.get('heartbeat') or {}
101 omniture
= episode
.get('omniture') or {}
102 get_meta
= lambda x
: heartbeat
.get(x
) or omniture
.get(x
)
105 'display_id': display_id
,
108 'description': episode
.get('descripcion'),
109 'thumbnail': episode
.get('imgPoster'),
110 'duration': int_or_none(episode
.get('duration')),
112 'channel': get_meta('channel'),
113 'season': get_meta('season'),
114 'episode_number': int_or_none(get_meta('episodeNumber')),
115 'subtitles': subtitles
,