mirror of
https://github.com/ytdl-org/youtube-dl
synced 2025-01-26 13:20:10 +09:00
Compare commits
No commits in common. "7f3c90ab252e212c67c8aa80d2e83fb9b686ee6d" and "4ef1fc970727a1bbdd9f20bea54c37deb8794fb0" have entirely different histories.
7f3c90ab25
...
4ef1fc9707
@ -1,52 +0,0 @@
|
|||||||
# coding: utf-8
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
|
|
||||||
from .common import InfoExtractor
|
|
||||||
|
|
||||||
|
|
||||||
class CTVIE(InfoExtractor):
|
|
||||||
_VALID_URL = r'https?://(?:www\.)?ctv\.ca/(?P<id>(?:show|movie)s/[^/]+/[^/?#&]+)'
|
|
||||||
_TESTS = [{
|
|
||||||
'url': 'https://www.ctv.ca/shows/your-morning/wednesday-december-23-2020-s5e88',
|
|
||||||
'info_dict': {
|
|
||||||
'id': '2102249',
|
|
||||||
'ext': 'flv',
|
|
||||||
'title': 'Wednesday, December 23, 2020',
|
|
||||||
'thumbnail': r're:^https?://.*\.jpg$',
|
|
||||||
'description': 'Your Morning delivers original perspectives and unique insights into the headlines of the day.',
|
|
||||||
'timestamp': 1608732000,
|
|
||||||
'upload_date': '20201223',
|
|
||||||
'series': 'Your Morning',
|
|
||||||
'season': '2020-2021',
|
|
||||||
'season_number': 5,
|
|
||||||
'episode_number': 88,
|
|
||||||
'tags': ['Your Morning'],
|
|
||||||
'categories': ['Talk Show'],
|
|
||||||
'duration': 7467.126,
|
|
||||||
},
|
|
||||||
}, {
|
|
||||||
'url': 'https://www.ctv.ca/movies/adam-sandlers-eight-crazy-nights/adam-sandlers-eight-crazy-nights',
|
|
||||||
'only_matching': True,
|
|
||||||
}]
|
|
||||||
|
|
||||||
def _real_extract(self, url):
|
|
||||||
display_id = self._match_id(url)
|
|
||||||
content = self._download_json(
|
|
||||||
'https://www.ctv.ca/space-graphql/graphql', display_id, query={
|
|
||||||
'query': '''{
|
|
||||||
resolvedPath(path: "/%s") {
|
|
||||||
lastSegment {
|
|
||||||
content {
|
|
||||||
... on AxisContent {
|
|
||||||
axisId
|
|
||||||
videoPlayerDestCode
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}''' % display_id,
|
|
||||||
})['data']['resolvedPath']['lastSegment']['content']
|
|
||||||
video_id = content['axisId']
|
|
||||||
return self.url_result(
|
|
||||||
'9c9media:%s:%s' % (content['videoPlayerDestCode'], video_id),
|
|
||||||
'NineCNineMedia', video_id)
|
|
@ -244,7 +244,6 @@ from .crunchyroll import (
|
|||||||
)
|
)
|
||||||
from .cspan import CSpanIE
|
from .cspan import CSpanIE
|
||||||
from .ctsnews import CtsNewsIE
|
from .ctsnews import CtsNewsIE
|
||||||
from .ctv import CTVIE
|
|
||||||
from .ctvnews import CTVNewsIE
|
from .ctvnews import CTVNewsIE
|
||||||
from .cultureunplugged import CultureUnpluggedIE
|
from .cultureunplugged import CultureUnpluggedIE
|
||||||
from .curiositystream import (
|
from .curiositystream import (
|
||||||
|
@ -5,11 +5,10 @@ import re
|
|||||||
|
|
||||||
from .common import InfoExtractor
|
from .common import InfoExtractor
|
||||||
from ..utils import (
|
from ..utils import (
|
||||||
ExtractorError,
|
|
||||||
float_or_none,
|
|
||||||
int_or_none,
|
|
||||||
parse_iso8601,
|
parse_iso8601,
|
||||||
try_get,
|
float_or_none,
|
||||||
|
ExtractorError,
|
||||||
|
int_or_none,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
@ -36,7 +35,7 @@ class NineCNineMediaIE(InfoExtractor):
|
|||||||
'$include': '[HasClosedCaptions]',
|
'$include': '[HasClosedCaptions]',
|
||||||
})
|
})
|
||||||
|
|
||||||
if try_get(content_package, lambda x: x['Constraints']['Security']['Type']):
|
if content_package.get('Constraints', {}).get('Security', {}).get('Type'):
|
||||||
raise ExtractorError('This video is DRM protected.', expected=True)
|
raise ExtractorError('This video is DRM protected.', expected=True)
|
||||||
|
|
||||||
manifest_base_url = content_package_url + 'manifest.'
|
manifest_base_url = content_package_url + 'manifest.'
|
||||||
@ -53,7 +52,7 @@ class NineCNineMediaIE(InfoExtractor):
|
|||||||
self._sort_formats(formats)
|
self._sort_formats(formats)
|
||||||
|
|
||||||
thumbnails = []
|
thumbnails = []
|
||||||
for image in (content.get('Images') or []):
|
for image in content.get('Images', []):
|
||||||
image_url = image.get('Url')
|
image_url = image.get('Url')
|
||||||
if not image_url:
|
if not image_url:
|
||||||
continue
|
continue
|
||||||
@ -71,7 +70,7 @@ class NineCNineMediaIE(InfoExtractor):
|
|||||||
continue
|
continue
|
||||||
container.append(e_name)
|
container.append(e_name)
|
||||||
|
|
||||||
season = content.get('Season') or {}
|
season = content.get('Season', {})
|
||||||
|
|
||||||
info = {
|
info = {
|
||||||
'id': content_id,
|
'id': content_id,
|
||||||
@ -80,14 +79,13 @@ class NineCNineMediaIE(InfoExtractor):
|
|||||||
'timestamp': parse_iso8601(content.get('BroadcastDateTime')),
|
'timestamp': parse_iso8601(content.get('BroadcastDateTime')),
|
||||||
'episode_number': int_or_none(content.get('Episode')),
|
'episode_number': int_or_none(content.get('Episode')),
|
||||||
'season': season.get('Name'),
|
'season': season.get('Name'),
|
||||||
'season_number': int_or_none(season.get('Number')),
|
'season_number': season.get('Number'),
|
||||||
'season_id': season.get('Id'),
|
'season_id': season.get('Id'),
|
||||||
'series': try_get(content, lambda x: x['Media']['Name']),
|
'series': content.get('Media', {}).get('Name'),
|
||||||
'tags': tags,
|
'tags': tags,
|
||||||
'categories': categories,
|
'categories': categories,
|
||||||
'duration': float_or_none(content_package.get('Duration')),
|
'duration': float_or_none(content_package.get('Duration')),
|
||||||
'formats': formats,
|
'formats': formats,
|
||||||
'thumbnails': thumbnails,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if content_package.get('HasClosedCaptions'):
|
if content_package.get('HasClosedCaptions'):
|
||||||
|
Loading…
Reference in New Issue
Block a user