]>
jfr.im git - yt-dlp.git/blob - yt_dlp/extractor/atresplayer.py
8143eb4d755bc22eacbdf097e57e8440f0d72942
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',
28 'format': 'bestvideo',
30 'skip': 'This video is only available for registered users'
33 'url': 'https://www.atresplayer.com/lasexta/programas/el-club-de-la-comedia/temporada-4/capitulo-10-especial-solidario-nochebuena_5ad08edf986b2855ed47adc4/',
34 'only_matching': True,
37 'url': 'https://www.atresplayer.com/antena3/series/el-secreto-de-puente-viejo/el-chico-de-los-tres-lunares/capitulo-977-29-12-14_5ad51046986b2886722ccdea/',
38 'only_matching': True,
41 _API_BASE
= 'https://api.atresplayer.com/'
43 def _real_initialize(self
):
46 def _handle_error(self
, e
, code
):
47 if isinstance(e
.cause
, compat_HTTPError
) and e
.cause
.code
== code
:
48 error
= self
._parse
_json
(e
.cause
.read(), None)
49 if error
.get('error') == 'required_registered':
50 self
.raise_login_required()
51 raise ExtractorError(error
['error_description'], expected
=True)
55 username
, password
= self
._get
_login
_info
()
59 self
._request
_webpage
(
60 self
._API
_BASE
+ 'login', None, 'Downloading login page')
63 target_url
= self
._download
_json
(
64 'https://account.atresmedia.com/api/login', None,
65 'Logging in', headers
={
66 'Content-Type': 'application/x-www-form-urlencoded'
67 }, data
=urlencode_postdata({
71 except ExtractorError
as e
:
72 self
._handle
_error
(e
, 400)
74 self
._request
_webpage
(target_url
, None, 'Following Target URL')
76 def _real_extract(self
, url
):
77 display_id
, video_id
= self
._match
_valid
_url
(url
).groups()
80 episode
= self
._download
_json
(
81 self
._API
_BASE
+ 'client/v1/player/episode/' + video_id
, video_id
)
82 except ExtractorError
as e
:
83 self
._handle
_error
(e
, 403)
85 title
= episode
['titulo']
89 for source
in episode
.get('sources', []):
90 src
= source
.get('src')
93 src_type
= source
.get('type')
94 if src_type
== 'application/vnd.apple.mpegurl':
95 formats
, subtitles
= self
._extract
_m
3u8_formats
(
96 src
, video_id
, 'mp4', 'm3u8_native',
97 m3u8_id
='hls', fatal
=False)
98 elif src_type
== 'application/dash+xml':
99 formats
, subtitles
= self
._extract
_mpd
_formats
(
100 src
, video_id
, mpd_id
='dash', fatal
=False)
101 self
._sort
_formats
(formats
)
103 heartbeat
= episode
.get('heartbeat') or {}
104 omniture
= episode
.get('omniture') or {}
105 get_meta
= lambda x
: heartbeat
.get(x
) or omniture
.get(x
)
108 'display_id': display_id
,
111 'description': episode
.get('descripcion'),
112 'thumbnail': episode
.get('imgPoster'),
113 'duration': int_or_none(episode
.get('duration')),
115 'channel': get_meta('channel'),
116 'season': get_meta('season'),
117 'episode_number': int_or_none(get_meta('episodeNumber')),
118 'subtitles': subtitles
,