mirror of
https://github.com/yt-dlp/yt-dlp.git
synced 2024-11-16 01:25:06 +00:00
[kanalplay] Add extractor (Closes #5188)
This commit is contained in:
parent
486dd09e0b
commit
fb7e68833c
2 changed files with 73 additions and 0 deletions
|
@ -231,6 +231,7 @@
|
||||||
from .jukebox import JukeboxIE
|
from .jukebox import JukeboxIE
|
||||||
from .jpopsukitv import JpopsukiIE
|
from .jpopsukitv import JpopsukiIE
|
||||||
from .kaltura import KalturaIE
|
from .kaltura import KalturaIE
|
||||||
|
from .kanalplay import KanalPlayIE
|
||||||
from .kankan import KankanIE
|
from .kankan import KankanIE
|
||||||
from .karaoketv import KaraoketvIE
|
from .karaoketv import KaraoketvIE
|
||||||
from .keezmovies import KeezMoviesIE
|
from .keezmovies import KeezMoviesIE
|
||||||
|
|
72
youtube_dl/extractor/kanalplay.py
Normal file
72
youtube_dl/extractor/kanalplay.py
Normal file
|
@ -0,0 +1,72 @@
|
||||||
|
# coding: utf-8
|
||||||
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
|
import re
|
||||||
|
|
||||||
|
from .common import InfoExtractor
|
||||||
|
from ..utils import (
|
||||||
|
ExtractorError,
|
||||||
|
float_or_none,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
class KanalPlayIE(InfoExtractor):
|
||||||
|
IE_DESC = 'Kanal 5/9/11 Play'
|
||||||
|
_VALID_URL = r'https?://(?:www\.)?kanal(?P<channel_id>5|9|11)play\.se/(?:#!/)?(?:play/)?program/\d+/video/(?P<id>\d+)'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'http://www.kanal5play.se/#!/play/program/3060212363/video/3270012277',
|
||||||
|
'md5': '',
|
||||||
|
'info_dict': {
|
||||||
|
'id': '2609989',
|
||||||
|
'ext': 'flv',
|
||||||
|
'title': 'Saknar både dusch och avlopp',
|
||||||
|
'description': 'md5:',
|
||||||
|
'duration': 2636.36,
|
||||||
|
},
|
||||||
|
}, {
|
||||||
|
'url': 'http://www.kanal9play.se/#!/play/program/335032/video/246042',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'http://www.kanal11play.se/#!/play/program/232835958/video/367135199',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
def _real_extract(self, url):
|
||||||
|
mobj = re.match(self._VALID_URL, url)
|
||||||
|
video_id = mobj.group('id')
|
||||||
|
channel_id = mobj.group('channel_id')
|
||||||
|
|
||||||
|
video = self._download_json(
|
||||||
|
'http://www.kanal%splay.se/api/getVideo?format=FLASH&videoId=%s' % (channel_id, video_id),
|
||||||
|
video_id)
|
||||||
|
|
||||||
|
reasons_for_no_streams = video.get('reasonsForNoStreams')
|
||||||
|
if reasons_for_no_streams:
|
||||||
|
raise ExtractorError(
|
||||||
|
'%s returned error: %s' % (self.IE_NAME, '\n'.join(reasons_for_no_streams)),
|
||||||
|
expected=True)
|
||||||
|
|
||||||
|
title = video['title']
|
||||||
|
description = video.get('description')
|
||||||
|
duration = float_or_none(video.get('length'), 1000)
|
||||||
|
thumbnail = video.get('posterUrl')
|
||||||
|
|
||||||
|
stream_base_url = video['streamBaseUrl']
|
||||||
|
|
||||||
|
formats = [{
|
||||||
|
'url': stream_base_url,
|
||||||
|
'play_path': stream['source'],
|
||||||
|
'ext': 'flv',
|
||||||
|
'tbr': float_or_none(stream.get('bitrate'), 1000),
|
||||||
|
'rtmp_real_time': True,
|
||||||
|
} for stream in video['streams']]
|
||||||
|
self._sort_formats(formats)
|
||||||
|
|
||||||
|
return {
|
||||||
|
'id': video_id,
|
||||||
|
'title': title,
|
||||||
|
'description': description,
|
||||||
|
'thumbnail': thumbnail,
|
||||||
|
'duration': duration,
|
||||||
|
'formats': formats,
|
||||||
|
}
|
Loading…
Reference in a new issue