1 from .common
import InfoExtractor
2 from ..utils
import determine_ext
5 class ElonetIE(InfoExtractor
):
6 _VALID_URL
= r
'https?://elonet\.finna\.fi/Record/kavi\.elonet_elokuva_(?P<id>[0-9]+)'
8 'url': 'https://elonet.finna.fi/Record/kavi.elonet_elokuva_107867',
12 'title': 'Valkoinen peura',
13 'thumbnail': r
're:^https?://elonet\.finna\.fi/Cover/Show\?id=kavi\.elonet_elokuva_107867.+',
14 'description': 'md5:bded4201c9677fab10854884fe8f7312',
16 'params': {'skip_download': 'dash'},
19 'url': 'https://elonet.finna.fi/Record/kavi.elonet_elokuva_116539',
23 'title': 'Minulla on tiikeri',
24 'thumbnail': r
're:^https?://elonet\.finna\.fi/Cover/Show\?id=kavi\.elonet_elokuva_116539.+',
25 'description': 'md5:5ab72b3fe76d3414e46cc8f277104419',
27 'params': {'skip_download': 'dash'},
29 # Page with multiple videos, download the main one
30 'url': 'https://elonet.finna.fi/Record/kavi.elonet_elokuva_117396',
35 'thumbnail': r
're:^https?://elonet\.finna\.fi/Cover/Show\?id=kavi\.elonet_elokuva_117396.+',
36 'description': 'md5:ec69572a5b054d0ecafe8086b1fa96f7',
38 'params': {'skip_download': 'dash'},
41 def _real_extract(self
, url
):
42 video_id
= self
._match
_id
(url
)
43 webpage
= self
._download
_webpage
(url
, video_id
)
45 src
= self
._parse
_json
(self
._html
_search
_regex
(
46 r
'id=\'video
-data
\'[^
>]+data
-video
-sources
="([^"]+)"', webpage, 'json'), video_id)[0]['src']
47 ext = determine_ext(src)
50 formats, subtitles = self._extract_m3u8_formats_and_subtitles(src, video_id, fatal=False)
52 formats, subtitles = self._extract_mpd_formats_and_subtitles(src, video_id, fatal=False)
54 formats, subtitles = [], {}
55 self.raise_no_formats(f'Unknown streaming format {ext}')
59 'title': self._og_search_title(webpage),
60 'description': self._og_search_description(webpage),
61 'thumbnail': self._og_search_thumbnail(webpage),
63 'subtitles': subtitles,