Bug 1213124 (CVE-2023-35934)

Summary: VUL-0: CVE-2023-35934: yt-dlp: file Downloader cookie leak
Product: [Novell Products] SUSE Security Incidents Reporter: Thomas Leroy <thomas.leroy>
Component: IncidentsAssignee: Jan Engelhardt <jengelh>
Status: RESOLVED FIXED QA Contact: Security Team bot <security-team>
Severity: Normal    
Priority: P3 - Medium CC: security-team
Version: unspecified   
Target Milestone: ---   
Hardware: Other   
OS: Other   
URL: https://smash.suse.de/issue/371508/
Whiteboard:
Found By: Security Response Team Services Priority:
Business Priority: Blocker: ---
Marketing QA Status: --- IT Deployment: ---

Description Thomas Leroy 2023-07-07 07:17:54 UTC
CVE-2023-35934

yt-dlp is a command-line program to download videos from video sites. During
file downloads, yt-dlp or the external downloaders that yt-dlp employs may leak
cookies on HTTP redirects to a different host, or leak them when the host for
download fragments differs from their parent manifest's host. This vulnerable
behavior is present in yt-dlp prior to 2023.07.06 and nightly 2023.07.06.185519.
All native and external downloaders are affected, except for `curl` and `httpie`
(version 3.1.0 or later).

At the file download stage, all cookies are passed by yt-dlp to the file
downloader as a `Cookie` header, thereby losing their scope. This also occurs in
yt-dlp's info JSON output, which may be used by external tools. As a result, the
downloader or external tool may indiscriminately send cookies with requests to
domains or paths for which the cookies are not scoped.

yt-dlp version 2023.07.06 and nightly 2023.07.06.185519 fix this issue by
removing the `Cookie` header upon HTTP redirects; having native downloaders
calculate the `Cookie` header from the cookiejar, utilizing external
downloaders' built-in support for cookies instead of passing them as header
arguments, disabling HTTP redirectiong if the external downloader does not have
proper cookie support, processing cookies passed as HTTP headers to limit their
scope, and having a separate field for cookies in the info dict storing more
information about scoping

Some workarounds are available for those who are unable to upgrade. Avoid using
cookies and user authentication methods. While extractors may set custom
cookies, these usually do not contain sensitive information. Alternatively,
avoid using `--load-info-json`. Or, if authentication is a must: verify the
integrity of download links from unknown sources in browser (including
redirects) before passing them to yt-dlp; use `curl` as external downloader,
since it is not impacted; and/or avoid fragmented formats such as HLS/m3u8,
DASH/mpd and ISM.

References:
http://web.nvd.nist.gov/view/vuln/detail?vulnId=CVE-2023-35934
https://www.cve.org/CVERecord?id=CVE-2023-35934
https://github.com/yt-dlp/yt-dlp-nightly-builds/releases/tag/2023.07.06.185519
https://github.com/yt-dlp/yt-dlp/commit/1ceb657bdd254ad961489e5060f2ccc7d556b729
https://github.com/yt-dlp/yt-dlp/commit/3121512228487c9c690d3d39bfd2579addf96e07
https://github.com/yt-dlp/yt-dlp/commit/f8b4bcc0a791274223723488bfbfc23ea3276641
https://github.com/yt-dlp/yt-dlp/releases/tag/2023.07.06
https://github.com/yt-dlp/yt-dlp/security/advisories/GHSA-v8mc-9377-rwjj
Comment 1 Thomas Leroy 2023-07-07 07:20:17 UTC
Affected:
- openSUSE:Backports:SLE-15-SP5
- openSUSE:Backports:SLE-15-SP4
- openSUSE:Factory
Comment 2 OBSbugzilla Bot 2023-11-15 10:35:02 UTC
This is an autogenerated message for OBS integration:
This bug (1213124) was mentioned in
https://build.opensuse.org/request/show/1126561 Backports:SLE-15-SP5 / yt-dlp
Comment 3 Marcus Meissner 2023-11-18 23:04:57 UTC
openSUSE-SU-2023:0374-1: An update that fixes two vulnerabilities is now available.

Category: security (moderate)
Bug References: 1213124,1216467
CVE References: CVE-2023-35934,CVE-2023-46121
JIRA References: 
Sources used:
openSUSE Backports SLE-15-SP5 (src):    yt-dlp-2023.11.14-bp155.3.3.1
Comment 4 Marcus Meissner 2024-04-15 15:08:12 UTC
releasedrelöease