Compare commits

..

No commits in common. "0fff1bd35315a8c2b41911c60ef04a74a46fd0c0" and "36e17a0d3317d97ba9f6eb3e5c9895ad8b8fdad4" have entirely different histories.

View File

@ -2,20 +2,14 @@ import re
from .common import InfoExtractor
from ..utils import (
int_or_none,
parse_duration,
traverse_obj,
url_or_none,
)
class JTBCIE(InfoExtractor):
IE_DESC = 'jtbc.co.kr'
_VALID_URL = r'''(?x)
https?://(?:
vod\.jtbc\.co\.kr/player/(?:program|clip)
|tv\.jtbc\.co\.kr/(?:replay|trailer|clip)/pr\d+/pm\d+
)/(?P<id>(?:ep|vo)\d+)'''
_VALID_URL = r'https?://(?:vod\.jtbc\.co\.kr/player/(?:program|clip)|tv\.jtbc\.co\.kr/(?:replay|trailer|clip)/pr[0-9]+/pm[0-9]+)/(?P<id>(?:ep|vo)[0-9]+)'
_GEO_COUNTRIES = ['KR']
_TESTS = [{
@ -80,7 +74,7 @@ class JTBCIE(InfoExtractor):
video_id = self._match_id(url)
webpage = self._download_webpage(url, video_id)
file_id = self._search_regex(r'data-vod="(VO\d+)"', webpage, 'vod id')
file_id = self._search_regex(r'data-vod="(VO[0-9]+)"', webpage, 'vod_id')
metadata = self._download_json(
f'https://now-api.jtbc.co.kr/v1/vod/detail?vodFileId={file_id}',
@ -90,23 +84,23 @@ class JTBCIE(InfoExtractor):
f'https://api.jtbc.co.kr/vod/{file_id}', video_id, note='Downloading VOD playback data')
subtitles = {}
for sub in traverse_obj(playback_data, ('tracks', lambda _, v: v['file'])):
subtitles.setdefault(sub.get('label', 'und'), []).append({'url': sub['file']})
for sub in playback_data.get('tracks', []):
subtitles.setdefault(sub.get('label', 'und'), []).append({'url': sub.get('file')})
formats = []
for stream_url in traverse_obj(playback_data, ('sources', 'HLS', ..., 'file')):
m3u8_url = re.sub(r'/playlist(?:_pd\d+)?\.m3u8', '/index.m3u8', stream_url)
formats.extend(self._extract_m3u8_formats(m3u8_url, video_id, fatal=False))
for format_id, stream in traverse_obj(playback_data, ('sources', 'HLS'), default={}).items():
m3u8_url = re.sub(r'/playlist(?:_pd180000)?\.m3u8', '/index.m3u8', stream.get('file'))
formats.extend(self._extract_m3u8_formats(m3u8_url, video_id, m3u8_id=format_id))
return {
'id': video_id,
**traverse_obj(metadata, ('vodDetail', {
'title': 'vodTitleView',
'series': 'programTitle',
'age_limit': ('watchAge', {int_or_none}),
'age_limit': 'watchAge',
'release_date': ('broadcastDate', {lambda x: re.match(r'\d{8}', x.replace('.', ''))}, 0),
'description': 'episodeContents',
'thumbnail': ('imgFileUrl', {url_or_none}),
'thumbnail': 'imgFileUrl',
})),
'duration': parse_duration(playback_data.get('playTime')),
'formats': formats,
@ -116,7 +110,7 @@ class JTBCIE(InfoExtractor):
class JTBCProgramIE(InfoExtractor):
IE_NAME = 'JTBC:program'
_VALID_URL = r'https?://(?:vod\.jtbc\.co\.kr/program|tv\.jtbc\.co\.kr/replay)/(?P<id>pr\d+)/(?:replay|pm\d+)/?(?:$|[?#])'
_VALID_URL = r'https?://(?:vod\.jtbc\.co\.kr/program|tv\.jtbc\.co\.kr/replay)/(?P<id>pr[0-9]+)/(?:replay|pm[0-9]+)$'
_TESTS = [{
'url': 'https://tv.jtbc.co.kr/replay/pr10010392/pm10032710',
@ -138,13 +132,11 @@ class JTBCProgramIE(InfoExtractor):
program_id = self._match_id(url)
vod_list = self._download_json(
'https://now-api.jtbc.co.kr/v1/vodClip/programHome/programReplayVodList', program_id,
note='Downloading program replay list', query={
'programId': program_id,
'rowCount': '10000',
})
f'https://now-api.jtbc.co.kr/v1/vodClip/programHome/programReplayVodList?programId={program_id}&rowCount=10000',
program_id, note='Downloading program replay list')
entries = [self.url_result(f'https://vod.jtbc.co.kr/player/program/{video_id}', JTBCIE, video_id)
for video_id in traverse_obj(vod_list, ('programReplayVodList', ..., 'episodeId'))]
entries = [self.url_result(
'https://vod.jtbc.co.kr/player/program/' + video.get('episodeId'), JTBCIE.ie_key()
) for video in vod_list.get('programReplayVodList', [])]
return self.playlist_result(entries, program_id)