[ie/niconico] adjust the warning about the blank part in videos

This commit is contained in:
Mozi 2024-05-31 18:16:46 +00:00
parent 53a7fcc231
commit f65ad7f3c2

View File

@ -1089,26 +1089,32 @@ class NiconicoLiveIE(InfoExtractor):
}.get(traverse_obj(embedded_data, ('programTimeshift', 'publication', 'status', {str})), 'is_live') }.get(traverse_obj(embedded_data, ('programTimeshift', 'publication', 'status', {str})), 'is_live')
if traverse_obj(embedded_data, ('userProgramWatch', 'canWatch', {bool})): if traverse_obj(embedded_data, ('userProgramWatch', 'canWatch', {bool})):
if needs_subscription := traverse_obj(embedded_data, ('program', 'isMemberFree', {bool})): is_member_free = traverse_obj(embedded_data, ('program', 'isMemberFree', {bool}))
msg = 'You have no right to access the paid content. ' is_shown = traverse_obj(embedded_data, ('program', 'trialWatch', 'isShown', {bool}))
if not traverse_obj(embedded_data, ('program', 'trialWatch', 'isShown', {bool})): self.write_debug(f'.program.isMemberFree: {is_member_free}; .program.trialWatch.isShown: {is_shown}')
msg += 'This video may be completely blank'
else: if is_member_free is None and is_shown is None:
# TODO: get the exact duration of the free part return live_status, self._availability()
msg += 'There may be some blank parts in this video'
self.report_warning(msg, video_id) if is_member_free is False:
return live_status, self._availability(needs_subscription=needs_subscription) msg = 'You cannot access the paid content, thus the video may be blank.'
else:
msg = 'You cannot access restricted content, thus a part of the video or the entire video may be blank.'
self.report_warning(msg, video_id)
return live_status, self._availability(needs_subscription=True)
if traverse_obj(embedded_data, ('userProgramWatch', 'isCountryRestrictionTarget', {bool})): if traverse_obj(embedded_data, ('userProgramWatch', 'isCountryRestrictionTarget', {bool})):
self.raise_geo_restricted(countries=self._GEO_COUNTRIES, metadata_available=True) self.raise_geo_restricted(countries=self._GEO_COUNTRIES, metadata_available=True)
return live_status, self._availability() return live_status, self._availability()
rejected_reasons = traverse_obj(embedded_data, ('userProgramWatch', 'rejectedReasons', ..., {str})) rejected_reasons = traverse_obj(embedded_data, ('userProgramWatch', 'rejectedReasons', ..., {str}))
self.write_debug(f'userProgramWatch.rejectedReasons: {rejected_reasons!r}') self.write_debug(f'.userProgramWatch.rejectedReasons: {rejected_reasons!r}')
if 'programNotBegun' in rejected_reasons: if 'programNotBegun' in rejected_reasons:
self.report_warning('Live has not started', video_id)
live_status = 'is_upcoming' live_status = 'is_upcoming'
elif 'timeshiftBeforeOpen' in rejected_reasons: elif 'timeshiftBeforeOpen' in rejected_reasons:
self.report_warning('Live has ended but timeshift is not yet processed', video_id)
live_status = 'post_live' live_status = 'post_live'
elif 'noTimeshiftProgram' in rejected_reasons: elif 'noTimeshiftProgram' in rejected_reasons:
self.report_warning('Timeshift is disabled', video_id) self.report_warning('Timeshift is disabled', video_id)
@ -1140,4 +1146,11 @@ class NiconicoLiveIE(InfoExtractor):
] for x in rejected_reasons), ] for x in rejected_reasons),
}) })
if availability == 'premium_only':
self.raise_login_required('This video requires premium', metadata_available=True)
elif availability == 'subscriber_only':
self.raise_login_required('This video is for members only', metadata_available=True)
elif availability == 'needs_auth':
self.raise_login_required(metadata_available=True)
return live_status, availability return live_status, availability