+ password = self.get_param('videopassword')
+ if not password:
+ raise ExtractorError(
+ 'This video is protected by a passcode, use the --video-password option', expected=True)
+ is_meeting = form.get('useWhichPasswd') == 'meeting'
+ validation = self._download_json(
+ base_url + 'rec/validate%s_passwd' % ('_meet' if is_meeting else ''),
+ video_id, 'Validating passcode', 'Wrong passcode', data=urlencode_postdata({
+ 'id': form[('meet' if is_meeting else 'file') + 'Id'],
+ 'passwd': password,
+ 'action': form.get('action'),
+ }))
+ if not validation.get('status'):
+ raise ExtractorError(validation['errorMessage'], expected=True)
+ return self._download_webpage(url, video_id, note=f'Re-downloading {url_type} webpage')
+
+ def _real_extract(self, url):
+ base_url, url_type, video_id = self._match_valid_url(url).group('base_url', 'type', 'id')
+ query = {}
+
+ if url_type == 'share':
+ webpage = self._get_real_webpage(url, base_url, video_id, 'share')
+ meeting_id = self._get_page_data(webpage, video_id)['meetingId']
+ redirect_path = self._download_json(
+ f'{base_url}nws/recording/1.0/play/share-info/{meeting_id}',
+ video_id, note='Downloading share info JSON')['result']['redirectUrl']
+ url = urljoin(base_url, redirect_path)
+ query['continueMode'] = 'true'
+
+ webpage = self._get_real_webpage(url, base_url, video_id, 'play')
+ file_id = self._get_page_data(webpage, video_id)['fileId']
+ if not file_id:
+ # When things go wrong, file_id can be empty string
+ raise ExtractorError('Unable to extract file ID')
+
+ data = self._download_json(
+ f'{base_url}nws/recording/1.0/play/info/{file_id}', video_id, query=query,
+ note='Downloading play info JSON')['result']