2024-08-21 03:43:45 +00:00
|
|
|
from .common import InfoExtractor
|
|
|
|
from .piaulizaportal import PIAULIZAPortalAPIIE
|
2024-08-22 15:06:16 +00:00
|
|
|
from ..utils import ExtractorError, extract_attributes, multipart_encode, smuggle_url, traverse_obj
|
2024-08-21 03:43:45 +00:00
|
|
|
|
|
|
|
|
|
|
|
class PiaLiveIE(InfoExtractor):
|
|
|
|
PLAYER_ROOT_URL = 'https://player.pia-live.jp'
|
|
|
|
PIA_LIVE_API_URL = 'https://api.pia-live.jp'
|
|
|
|
_VALID_URL = r'https?://player\.pia-live\.jp/stream/(?P<id>[\w-]+)'
|
|
|
|
|
2024-08-22 03:59:32 +00:00
|
|
|
_TESTS = [
|
|
|
|
{
|
|
|
|
'url': 'https://player.pia-live.jp/stream/4JagFBEIM14s_hK9aXHKf3k3F3bY5eoHFQxu68TC6krUDqGOwN4d61dCWQYOd6CTxl4hjya9dsfEZGsM4uGOUdax60lEI4twsXGXf7crmz8Gk__GhupTrWxA7RFRVt76',
|
|
|
|
'info_dict': {
|
|
|
|
'id': '2431867_001',
|
|
|
|
'title': 'こながめでたい日2024の視聴ページ | PIA LIVE STREAM(ぴあライブストリーム)',
|
|
|
|
'live_status': 'was_live',
|
2024-08-22 15:06:16 +00:00
|
|
|
'comment_count': 1000,
|
2024-08-22 03:59:32 +00:00
|
|
|
},
|
|
|
|
'params': {
|
|
|
|
'skip_download': True,
|
|
|
|
'ignore_no_formats_error': True,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'url': 'https://player.pia-live.jp/stream/4JagFBEIM14s_hK9aXHKf3k3F3bY5eoHFQxu68TC6krJdu0GVBVbVy01IwpJ6J3qBEm3d9TCTt1d0eWpsZGj7DrOjVOmS7GAWGwyscMgiThopJvzgWC4H5b-7XQjAfRZ',
|
|
|
|
'info_dict': {
|
|
|
|
'id': '2431867_002',
|
|
|
|
'title': 'こながめでたい日2024の視聴ページ | PIA LIVE STREAM(ぴあライブストリーム)',
|
|
|
|
'live_status': 'was_live',
|
2024-08-22 15:06:16 +00:00
|
|
|
'comment_count': 1000,
|
2024-08-22 03:59:32 +00:00
|
|
|
},
|
|
|
|
'params': {
|
|
|
|
'skip_download': True,
|
|
|
|
'ignore_no_formats_error': True,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
]
|
|
|
|
|
2024-08-21 06:55:09 +00:00
|
|
|
def handle_embed_player(self, player_tag, video_id, info_dict={}):
|
2024-08-22 15:06:16 +00:00
|
|
|
player_data_url = extract_attributes(player_tag)['src']
|
2024-08-21 06:55:09 +00:00
|
|
|
|
2024-08-22 11:51:05 +00:00
|
|
|
if player_data_url.startswith(PIAULIZAPortalAPIIE.BASE_URL):
|
2024-08-21 06:55:09 +00:00
|
|
|
return self.url_result(
|
|
|
|
smuggle_url(
|
|
|
|
player_data_url,
|
|
|
|
{'video_id': video_id, 'referer': self.PLAYER_ROOT_URL, 'info_dict': info_dict},
|
|
|
|
),
|
|
|
|
ie=PIAULIZAPortalAPIIE.ie_key(),
|
|
|
|
)
|
|
|
|
|
|
|
|
raise ExtractorError('Unsupported streaming platform', expected=True)
|
|
|
|
|
2024-08-21 03:43:45 +00:00
|
|
|
def _real_extract(self, url):
|
|
|
|
video_key = self._match_id(url)
|
|
|
|
webpage = self._download_webpage(url, video_key)
|
|
|
|
program_code = self._search_regex(r"const programCode = '(.*?)';", webpage, 'program code')
|
|
|
|
|
|
|
|
prod_configure = self._download_webpage(
|
|
|
|
self.PLAYER_ROOT_URL + self._search_regex(r'<script [^>]*\bsrc="(/statics/js/s_prod[^"]+)"', webpage, 'prod configure page'),
|
2024-08-22 11:51:05 +00:00
|
|
|
program_code, headers={'Referer': self.PLAYER_ROOT_URL},
|
2024-08-21 03:43:45 +00:00
|
|
|
note='Fetching prod configure page', errnote='Unable to fetch prod configure page',
|
|
|
|
)
|
|
|
|
|
|
|
|
api_key = self._search_regex(r"const APIKEY = '(.*?)';", prod_configure, 'api key')
|
|
|
|
payload, content_type = multipart_encode({
|
|
|
|
'play_url': video_key,
|
|
|
|
'api_key': api_key,
|
|
|
|
})
|
|
|
|
player_tag_list = self._download_json(
|
2024-08-22 03:59:32 +00:00
|
|
|
f'{self.PIA_LIVE_API_URL}/perf/player-tag-list/{program_code}',
|
2024-08-22 11:51:05 +00:00
|
|
|
program_code, data=payload, headers={'Content-Type': content_type, 'Referer': self.PLAYER_ROOT_URL},
|
2024-08-21 03:43:45 +00:00
|
|
|
)
|
|
|
|
|
2024-08-22 15:06:16 +00:00
|
|
|
article_code = self._search_regex(r"const articleCode = '(.*?)';", webpage, 'article code')
|
|
|
|
chat_info = self._download_json(
|
|
|
|
f'{self.PIA_LIVE_API_URL}/perf/chat-tag-list/{program_code}/{article_code}',
|
|
|
|
article_code, data=payload, headers={'Content-Type': content_type, 'Referer': self.PLAYER_ROOT_URL},
|
|
|
|
)['data']['chat_one_tag']
|
|
|
|
chat_room_url = extract_attributes(chat_info)['src']
|
|
|
|
comment_page = self._download_webpage(
|
|
|
|
chat_room_url, program_code, headers={'Referer': f'{self.PLAYER_ROOT_URL}/'}, note='Fetching comment page', errnote='Unable to fetch comment page')
|
|
|
|
comment_list = self._search_json(
|
|
|
|
r'var\s+_history\s*=', comment_page, 'comment list', program_code,
|
|
|
|
contains_pattern=r'\[(?s:.+)\]') or []
|
|
|
|
comments = traverse_obj(comment_list, (..., {
|
|
|
|
'timestamp': (0),
|
|
|
|
'author_is_uploader': (1, {lambda x: x == 2}),
|
|
|
|
'author': (2),
|
|
|
|
'text': (3),
|
|
|
|
'id': (4),
|
|
|
|
}))
|
|
|
|
|
2024-08-21 06:55:09 +00:00
|
|
|
return self.handle_embed_player(
|
|
|
|
player_tag_list['data']['movie_one_tag'],
|
|
|
|
video_id=program_code,
|
|
|
|
info_dict={
|
|
|
|
'id': program_code,
|
|
|
|
'title': self._html_extract_title(webpage),
|
2024-08-22 15:06:16 +00:00
|
|
|
'comments': comments,
|
|
|
|
'comment_count': len(comments),
|
2024-08-21 06:55:09 +00:00
|
|
|
},
|
|
|
|
)
|