mirror of
https://github.com/ytdl-org/youtube-dl.git
synced 2025-08-22 22:34:01 -07:00
[StreamsbIE] Add extractor for streamsb.com (viewsb.com)
This commit is contained in:
parent
384f632e8a
commit
cb1f1571f7
2 changed files with 53 additions and 0 deletions
|
@ -1200,6 +1200,7 @@ from .storyfire import (
|
||||||
from .streamable import StreamableIE
|
from .streamable import StreamableIE
|
||||||
from .streamcloud import StreamcloudIE
|
from .streamcloud import StreamcloudIE
|
||||||
from .streamcz import StreamCZIE
|
from .streamcz import StreamCZIE
|
||||||
|
from .streamsb import StreamsbIE
|
||||||
from .streetvoice import StreetVoiceIE
|
from .streetvoice import StreetVoiceIE
|
||||||
from .stretchinternet import StretchInternetIE
|
from .stretchinternet import StretchInternetIE
|
||||||
from .stv import STVPlayerIE
|
from .stv import STVPlayerIE
|
||||||
|
|
52
youtube_dl/extractor/streamsb.py
Normal file
52
youtube_dl/extractor/streamsb.py
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
# coding: utf-8
|
||||||
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
|
import random
|
||||||
|
import string
|
||||||
|
|
||||||
|
from .common import InfoExtractor
|
||||||
|
|
||||||
|
|
||||||
|
def to_ascii_hex(str1):
|
||||||
|
return ''.join([format(ord(c), 'x') for c in str1])
|
||||||
|
|
||||||
|
|
||||||
|
def generate_random_string(length):
|
||||||
|
return ''.join(random.choice(string.ascii_letters + string.digits) for _ in range(length))
|
||||||
|
|
||||||
|
|
||||||
|
class StreamsbIE(InfoExtractor):
|
||||||
|
domain = 'viewsb.com'
|
||||||
|
_VALID_URL = r'https://' + domain + '/(?P<id>.+)'
|
||||||
|
_TEST = {
|
||||||
|
'url': 'https://viewsb.com/dxfvlu4qanjx',
|
||||||
|
'md5': '488d111a63415369bf90ea83adc8a325',
|
||||||
|
'info_dict': {
|
||||||
|
'id': 'dxfvlu4qanjx',
|
||||||
|
'ext': 'mp4',
|
||||||
|
'title': 'Sintel'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
def _real_extract(self, url):
|
||||||
|
video_id = self._match_id(url)
|
||||||
|
webpage = self._download_webpage(url, video_id)
|
||||||
|
|
||||||
|
iframe_url = self._search_regex(r'IFRAME SRC=\"(.*)\"', webpage, 'iframe')
|
||||||
|
video_code = self._search_regex(r"(\w*).html", iframe_url, 'video_code')
|
||||||
|
|
||||||
|
length = 12
|
||||||
|
req = generate_random_string(length) + '||' + video_code + '||' + generate_random_string(length) + '||streamsb'
|
||||||
|
ereq = 'https://' + self.domain + '/sources50/' + to_ascii_hex(req)
|
||||||
|
|
||||||
|
video_data = self._download_webpage(ereq, video_id, headers={
|
||||||
|
'Referer': iframe_url,
|
||||||
|
'watchsb': 'sbstream'}
|
||||||
|
)
|
||||||
|
player_data = self._parse_json(video_data, video_id)
|
||||||
|
formats = self._extract_m3u8_formats(player_data['stream_data']['file'], video_id, ext='mp4', entry_protocol='m3u8_native', m3u8_id='hls', fatal=False)
|
||||||
|
return {
|
||||||
|
'id': video_id,
|
||||||
|
'formats': formats,
|
||||||
|
'title': player_data['stream_data']['title']
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue