[tvplay] Capture and output native error message
This commit is contained in:
parent
d50aca41f8
commit
3859ebeee6
1 changed files with 18 additions and 8 deletions
|
@ -5,15 +5,17 @@ import re
|
||||||
|
|
||||||
from .common import InfoExtractor
|
from .common import InfoExtractor
|
||||||
from ..compat import (
|
from ..compat import (
|
||||||
|
compat_HTTPError,
|
||||||
compat_str,
|
compat_str,
|
||||||
compat_urlparse,
|
compat_urlparse,
|
||||||
)
|
)
|
||||||
from ..utils import (
|
from ..utils import (
|
||||||
|
determine_ext,
|
||||||
|
ExtractorError,
|
||||||
|
int_or_none,
|
||||||
parse_iso8601,
|
parse_iso8601,
|
||||||
qualities,
|
qualities,
|
||||||
determine_ext,
|
|
||||||
update_url_query,
|
update_url_query,
|
||||||
int_or_none,
|
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@ -206,12 +208,15 @@ class TVPlayIE(InfoExtractor):
|
||||||
|
|
||||||
title = video['title']
|
title = video['title']
|
||||||
|
|
||||||
if video.get('is_geo_blocked'):
|
try:
|
||||||
self.report_warning(
|
|
||||||
'This content might not be available in your country due to copyright reasons')
|
|
||||||
|
|
||||||
streams = self._download_json(
|
streams = self._download_json(
|
||||||
'http://playapi.mtgx.tv/v1/videos/stream/%s' % video_id, video_id, 'Downloading streams JSON')
|
'http://playapi.mtgx.tv/v1/videos/stream/%s' % video_id,
|
||||||
|
video_id, 'Downloading streams JSON')
|
||||||
|
except ExtractorError as e:
|
||||||
|
if isinstance(e.cause, compat_HTTPError) and e.cause.code == 403:
|
||||||
|
msg = self._parse_json(e.cause.read().decode('utf-8'), video_id)
|
||||||
|
raise ExtractorError(msg['msg'], expected=True)
|
||||||
|
raise
|
||||||
|
|
||||||
quality = qualities(['hls', 'medium', 'high'])
|
quality = qualities(['hls', 'medium', 'high'])
|
||||||
formats = []
|
formats = []
|
||||||
|
@ -251,6 +256,11 @@ class TVPlayIE(InfoExtractor):
|
||||||
'url': video_url,
|
'url': video_url,
|
||||||
})
|
})
|
||||||
formats.append(fmt)
|
formats.append(fmt)
|
||||||
|
|
||||||
|
if not formats and video.get('is_geo_blocked'):
|
||||||
|
self.raise_geo_restricted(
|
||||||
|
'This content might not be available in your country due to copyright reasons')
|
||||||
|
|
||||||
self._sort_formats(formats)
|
self._sort_formats(formats)
|
||||||
|
|
||||||
# TODO: webvtt in m3u8
|
# TODO: webvtt in m3u8
|
||||||
|
|
Loading…
Reference in a new issue