|
|
@ -1,12 +1,8 @@ |
|
|
|
# coding: utf-8 |
|
|
|
from __future__ import unicode_literals |
|
|
|
|
|
|
|
import re |
|
|
|
|
|
|
|
from .common import InfoExtractor |
|
|
|
from ..utils import ( |
|
|
|
determine_ext, |
|
|
|
js_to_json, |
|
|
|
parse_duration, |
|
|
|
remove_end, |
|
|
|
) |
|
|
@ -25,7 +21,7 @@ class LRTIE(InfoExtractor): |
|
|
|
'duration': 1783, |
|
|
|
}, |
|
|
|
'params': { |
|
|
|
'skip_download': True, # HLS download |
|
|
|
'skip_download': True, # m3u8 download |
|
|
|
}, |
|
|
|
} |
|
|
|
|
|
|
@ -39,23 +35,8 @@ class LRTIE(InfoExtractor): |
|
|
|
duration = parse_duration(self._search_regex( |
|
|
|
r"var record_len = '([0-9]+:[0-9]+:[0-9]+)';", webpage, 'record_len', fatal=False, default=None)) |
|
|
|
|
|
|
|
formats = [] |
|
|
|
for js in re.findall(r'(?s)config:\s*(\{.*?\})', webpage): |
|
|
|
data = self._parse_json(js, video_id, transform_source=js_to_json) |
|
|
|
if 'provider' not in data: |
|
|
|
continue |
|
|
|
if data['provider'] == 'rtmp': |
|
|
|
formats.append({ |
|
|
|
'format_id': 'rtmp', |
|
|
|
'ext': determine_ext(data['file']), |
|
|
|
'url': data['streamer'], |
|
|
|
'play_path': 'mp4:%s' % data['file'], |
|
|
|
'preference': -1, |
|
|
|
'rtmp_real_time': True, |
|
|
|
}) |
|
|
|
else: |
|
|
|
formats.extend( |
|
|
|
self._extract_m3u8_formats(data['file'], video_id, 'mp4')) |
|
|
|
link = self._search_regex(r'file: "(.*)" \+ location\.hash\.substring\(1\)', webpage, 'link to m3u8') |
|
|
|
formats = self._extract_m3u8_formats(link, video_id, "mp4") |
|
|
|
|
|
|
|
return { |
|
|
|
'id': video_id, |
|
|
|