mirror of
https://github.com/yt-dlp/yt-dlp
synced 2025-01-18 23:03:05 +01:00
[cleanup] Misc (#8510)
Authored by: bashonly, coletdjnz, dirkf, gamer191, seproDev, Grub4K
This commit is contained in:
parent
f04b5bedad
commit
b012271d01
8 changed files with 33 additions and 21 deletions
6
.github/PULL_REQUEST_TEMPLATE.md
vendored
6
.github/PULL_REQUEST_TEMPLATE.md
vendored
|
@ -40,10 +40,4 @@ Fixes #
|
||||||
- [ ] Core bug fix/improvement
|
- [ ] Core bug fix/improvement
|
||||||
- [ ] New feature (It is strongly [recommended to open an issue first](https://github.com/yt-dlp/yt-dlp/blob/master/CONTRIBUTING.md#adding-new-feature-or-making-overarching-changes))
|
- [ ] New feature (It is strongly [recommended to open an issue first](https://github.com/yt-dlp/yt-dlp/blob/master/CONTRIBUTING.md#adding-new-feature-or-making-overarching-changes))
|
||||||
|
|
||||||
|
|
||||||
<!-- Do NOT edit/remove anything below this! -->
|
|
||||||
</details><details><summary>Copilot Summary</summary>
|
|
||||||
|
|
||||||
copilot:all
|
|
||||||
|
|
||||||
</details>
|
</details>
|
||||||
|
|
|
@ -163,10 +163,10 @@ Some of yt-dlp's default options are different from that of youtube-dl and youtu
|
||||||
For ease of use, a few more compat options are available:
|
For ease of use, a few more compat options are available:
|
||||||
|
|
||||||
* `--compat-options all`: Use all compat options (Do NOT use)
|
* `--compat-options all`: Use all compat options (Do NOT use)
|
||||||
* `--compat-options youtube-dl`: Same as `--compat-options all,-multistreams,-playlist-match-filter`
|
* `--compat-options youtube-dl`: Same as `--compat-options all,-multistreams,-playlist-match-filter,-manifest-filesize-approx`
|
||||||
* `--compat-options youtube-dlc`: Same as `--compat-options all,-no-live-chat,-no-youtube-channel-redirect,-playlist-match-filter`
|
* `--compat-options youtube-dlc`: Same as `--compat-options all,-no-live-chat,-no-youtube-channel-redirect,-playlist-match-filter,-manifest-filesize-approx`
|
||||||
* `--compat-options 2021`: Same as `--compat-options 2022,no-certifi,filename-sanitization,no-youtube-prefer-utc-upload-date`
|
* `--compat-options 2021`: Same as `--compat-options 2022,no-certifi,filename-sanitization,no-youtube-prefer-utc-upload-date`
|
||||||
* `--compat-options 2022`: Same as `--compat-options playlist-match-filter,no-external-downloader-progress,prefer-legacy-http-handler`. Use this to enable all future compat options
|
* `--compat-options 2022`: Same as `--compat-options playlist-match-filter,no-external-downloader-progress,prefer-legacy-http-handler,manifest-filesize-approx`. Use this to enable all future compat options
|
||||||
|
|
||||||
|
|
||||||
# INSTALLATION
|
# INSTALLATION
|
||||||
|
|
|
@ -98,5 +98,21 @@
|
||||||
"action": "add",
|
"action": "add",
|
||||||
"when": "61bdf15fc7400601c3da1aa7a43917310a5bf391",
|
"when": "61bdf15fc7400601c3da1aa7a43917310a5bf391",
|
||||||
"short": "[priority] Security: [[CVE-2023-40581](https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2023-40581)] [Prevent RCE when using `--exec` with `%q` on Windows](https://github.com/yt-dlp/yt-dlp/security/advisories/GHSA-42h4-v29r-42qg)\n - The shell escape function is now using `\"\"` instead of `\\\"`.\n - `utils.Popen` has been patched to properly quote commands."
|
"short": "[priority] Security: [[CVE-2023-40581](https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2023-40581)] [Prevent RCE when using `--exec` with `%q` on Windows](https://github.com/yt-dlp/yt-dlp/security/advisories/GHSA-42h4-v29r-42qg)\n - The shell escape function is now using `\"\"` instead of `\\\"`.\n - `utils.Popen` has been patched to properly quote commands."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"action": "change",
|
||||||
|
"when": "8a8b54523addf46dfd50ef599761a81bc22362e6",
|
||||||
|
"short": "[rh:requests] Add handler for `requests` HTTP library (#3668)\n\n\tAdds support for HTTPS proxies and persistent connections (keep-alive)",
|
||||||
|
"authors": ["bashonly", "coletdjnz", "Grub4K"]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"action": "add",
|
||||||
|
"when": "1d03633c5a1621b9f3a756f0a4f9dc61fab3aeaa",
|
||||||
|
"short": "[priority] **The release channels have been adjusted!**\n\t* [`master`](https://github.com/yt-dlp/yt-dlp-master-builds) builds are made after each push, containing the latest fixes (but also possibly bugs). This was previously the `nightly` channel.\n\t* [`nightly`](https://github.com/yt-dlp/yt-dlp-nightly-builds) builds are now made once a day, if there were any changes."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"action": "add",
|
||||||
|
"when": "f04b5bedad7b281bee9814686bba1762bae092eb",
|
||||||
|
"short": "[priority] Security: [[CVE-2023-46121](https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2023-46121)] Patch [Generic Extractor MITM Vulnerability via Arbitrary Proxy Injection](https://github.com/yt-dlp/yt-dlp/security/advisories/GHSA-3ch3-jhc6-5r8x)\n\t- Disallow smuggling of arbitary `http_headers`; extractors now only use specific headers"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|
|
@ -208,9 +208,9 @@ class LA7PodcastIE(LA7PodcastEpisodeIE): # XXX: Do not subclass from concrete I
|
||||||
'url': 'https://www.la7.it/propagandalive/podcast',
|
'url': 'https://www.la7.it/propagandalive/podcast',
|
||||||
'info_dict': {
|
'info_dict': {
|
||||||
'id': 'propagandalive',
|
'id': 'propagandalive',
|
||||||
'title': "Propaganda Live",
|
'title': 'Propaganda Live',
|
||||||
},
|
},
|
||||||
'playlist_count_min': 10,
|
'playlist_mincount': 10,
|
||||||
}]
|
}]
|
||||||
|
|
||||||
def _real_extract(self, url):
|
def _real_extract(self, url):
|
||||||
|
|
|
@ -39,7 +39,7 @@ class RedTubeIE(InfoExtractor):
|
||||||
def _real_extract(self, url):
|
def _real_extract(self, url):
|
||||||
video_id = self._match_id(url)
|
video_id = self._match_id(url)
|
||||||
webpage = self._download_webpage(
|
webpage = self._download_webpage(
|
||||||
'http://www.redtube.com/%s' % video_id, video_id)
|
f'https://www.redtube.com/{video_id}', video_id)
|
||||||
|
|
||||||
ERRORS = (
|
ERRORS = (
|
||||||
(('video-deleted-info', '>This video has been removed'), 'has been removed'),
|
(('video-deleted-info', '>This video has been removed'), 'has been removed'),
|
||||||
|
|
|
@ -11,6 +11,7 @@ from ..utils import (
|
||||||
ExtractorError,
|
ExtractorError,
|
||||||
InAdvancePagedList,
|
InAdvancePagedList,
|
||||||
int_or_none,
|
int_or_none,
|
||||||
|
remove_start,
|
||||||
traverse_obj,
|
traverse_obj,
|
||||||
update_url_query,
|
update_url_query,
|
||||||
url_or_none,
|
url_or_none,
|
||||||
|
@ -39,11 +40,11 @@ class VideoKenBaseIE(InfoExtractor):
|
||||||
if not video_url and not video_id:
|
if not video_url and not video_id:
|
||||||
return
|
return
|
||||||
elif not video_url or 'embed/sign-in' in video_url:
|
elif not video_url or 'embed/sign-in' in video_url:
|
||||||
video_url = f'https://slideslive.com/embed/{video_id.lstrip("slideslive-")}'
|
video_url = f'https://slideslive.com/embed/{remove_start(video_id, "slideslive-")}'
|
||||||
if url_or_none(referer):
|
if url_or_none(referer):
|
||||||
return update_url_query(video_url, {
|
return update_url_query(video_url, {
|
||||||
'embed_parent_url': referer,
|
'embed_parent_url': referer,
|
||||||
'embed_container_origin': f'https://{urllib.parse.urlparse(referer).netloc}',
|
'embed_container_origin': f'https://{urllib.parse.urlparse(referer).hostname}',
|
||||||
})
|
})
|
||||||
return video_url
|
return video_url
|
||||||
|
|
||||||
|
@ -57,12 +58,12 @@ class VideoKenBaseIE(InfoExtractor):
|
||||||
video_url = video_id
|
video_url = video_id
|
||||||
ie_key = 'Youtube'
|
ie_key = 'Youtube'
|
||||||
else:
|
else:
|
||||||
video_url = traverse_obj(video, 'embed_url', 'embeddableurl')
|
video_url = traverse_obj(video, 'embed_url', 'embeddableurl', expected_type=url_or_none)
|
||||||
if urllib.parse.urlparse(video_url).netloc == 'slideslive.com':
|
if not video_url:
|
||||||
|
continue
|
||||||
|
elif urllib.parse.urlparse(video_url).hostname == 'slideslive.com':
|
||||||
ie_key = SlidesLiveIE
|
ie_key = SlidesLiveIE
|
||||||
video_url = self._create_slideslive_url(video_url, video_id, url)
|
video_url = self._create_slideslive_url(video_url, video_id, url)
|
||||||
if not video_url:
|
|
||||||
continue
|
|
||||||
yield self.url_result(video_url, ie_key, video_id)
|
yield self.url_result(video_url, ie_key, video_id)
|
||||||
|
|
||||||
|
|
||||||
|
@ -178,7 +179,7 @@ class VideoKenIE(VideoKenBaseIE):
|
||||||
return self.url_result(
|
return self.url_result(
|
||||||
self._create_slideslive_url(None, video_id, url), SlidesLiveIE, video_id)
|
self._create_slideslive_url(None, video_id, url), SlidesLiveIE, video_id)
|
||||||
elif re.match(r'^[\w-]{11}$', video_id):
|
elif re.match(r'^[\w-]{11}$', video_id):
|
||||||
self.url_result(video_id, 'Youtube', video_id)
|
return self.url_result(video_id, 'Youtube', video_id)
|
||||||
else:
|
else:
|
||||||
raise ExtractorError('Unable to extract without VideoKen API response')
|
raise ExtractorError('Unable to extract without VideoKen API response')
|
||||||
|
|
||||||
|
|
|
@ -6687,7 +6687,7 @@ class YoutubePlaylistIE(InfoExtractor):
|
||||||
'uploader_url': 'https://www.youtube.com/@milan5503',
|
'uploader_url': 'https://www.youtube.com/@milan5503',
|
||||||
'availability': 'public',
|
'availability': 'public',
|
||||||
},
|
},
|
||||||
'expected_warnings': [r'[Uu]navailable videos? (is|are|will be) hidden'],
|
'expected_warnings': [r'[Uu]navailable videos? (is|are|will be) hidden', 'Retrying', 'Giving up'],
|
||||||
}, {
|
}, {
|
||||||
'url': 'http://www.youtube.com/embed/_xDOZElKyNU?list=PLsyOSbh5bs16vubvKePAQ1x3PhKavfBIl',
|
'url': 'http://www.youtube.com/embed/_xDOZElKyNU?list=PLsyOSbh5bs16vubvKePAQ1x3PhKavfBIl',
|
||||||
'playlist_mincount': 455,
|
'playlist_mincount': 455,
|
||||||
|
|
|
@ -255,7 +255,8 @@ class RequestsRH(RequestHandler, InstanceStoreMixin):
|
||||||
handler.setFormatter(logging.Formatter('requests: %(message)s'))
|
handler.setFormatter(logging.Formatter('requests: %(message)s'))
|
||||||
handler.addFilter(Urllib3LoggingFilter())
|
handler.addFilter(Urllib3LoggingFilter())
|
||||||
logger.addHandler(handler)
|
logger.addHandler(handler)
|
||||||
logger.setLevel(logging.WARNING)
|
# TODO: Use a logger filter to suppress pool reuse warning instead
|
||||||
|
logger.setLevel(logging.ERROR)
|
||||||
|
|
||||||
if self.verbose:
|
if self.verbose:
|
||||||
# Setting this globally is not ideal, but is easier than hacking with urllib3.
|
# Setting this globally is not ideal, but is easier than hacking with urllib3.
|
||||||
|
|
Loading…
Add table
Reference in a new issue