<?xml version="1.0" encoding="UTF-8"?>
<cvrfdoc xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:cpe="http://cpe.mitre.org/language/2.0" xmlns:cvrf="http://docs.oasis-open.org/csaf/ns/csaf-cvrf/v1.2/cvrf" xmlns:cvrf-common="http://docs.oasis-open.org/csaf/ns/csaf-cvrf/v1.2/common" xmlns:cvssv2="http://scap.nist.gov/schema/cvss-v2/1.0" xmlns:cvssv3="https://www.first.org/cvss/cvss-v3.0.xsd" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:ns0="http://purl.org/dc/elements/1.1/" xmlns:prod="http://docs.oasis-open.org/csaf/ns/csaf-cvrf/v1.2/prod" xmlns:scap-core="http://scap.nist.gov/schema/scap-core/1.0" xmlns:sch="http://purl.oclc.org/dsdl/schematron" xmlns:vuln="http://docs.oasis-open.org/csaf/ns/csaf-cvrf/v1.2/vuln" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://docs.oasis-open.org/csaf/ns/csaf-cvrf/v1.2/cvrf">
  <DocumentTitle xml:lang="en">CVE-2023-35934</DocumentTitle>
  <DocumentType>SUSE CVE</DocumentType>
  <DocumentPublisher Type="Vendor">
    <ContactDetails>security@suse.de</ContactDetails>
    <IssuingAuthority>SUSE Security Team</IssuingAuthority>
  </DocumentPublisher>
  <DocumentTracking>
    <Identification>
      <ID>SUSE CVE-2023-35934</ID>
    </Identification>
    <Status>Interim</Status>
    <Version>1</Version>
    <RevisionHistory>
      <Revision>
        <Number>5</Number>
        <Date>2025-02-16T02:11:25Z</Date>
        <Description>current</Description>
      </Revision>
    </RevisionHistory>
    <InitialReleaseDate>2023-07-07T23:15:26Z</InitialReleaseDate>
    <CurrentReleaseDate>2025-02-16T02:11:25Z</CurrentReleaseDate>
    <Generator>
      <Engine>cve-database/bin/generate-cvrf-cve.pl</Engine>
      <Date>2020-12-27T01:00:00Z</Date>
    </Generator>
  </DocumentTracking>
  <DocumentNotes>
    <Note Title="CVE" Type="Summary" Ordinal="1" xml:lang="en">CVE-2023-35934</Note>
    <Note Title="Mitre CVE Description" Type="Description" Ordinal="2" xml:lang="en">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.</Note>
    <Note Title="Terms of Use" Type="Legal Disclaimer" Ordinal="4" xml:lang="en">The CVRF data is provided by SUSE under the Creative Commons License 4.0 with Attribution (CC-BY-4.0).</Note>
  </DocumentNotes>
  <DocumentReferences>
    <Reference Type="Self">
      <URL>https://lists.opensuse.org/archives/list/security-announce@lists.opensuse.org/thread/6MA5EHVFVH4HRBQQ5KZZ4YVOXJFQUG3W/</URL>
      <Description>E-Mail link for openSUSE-SU-2023:0374-1</Description>
    </Reference>
    <Reference Type="Self">
      <URL>https://www.suse.com/support/security/rating/</URL>
      <Description>SUSE Security Ratings</Description>
    </Reference>
  </DocumentReferences>
  <ProductTree xmlns="http://docs.oasis-open.org/csaf/ns/csaf-cvrf/v1.2/prod">
    <Branch Type="Product Family" Name="SUSE Package Hub 15 SP5">
      <Branch Type="Product Name" Name="SUSE Package Hub 15 SP5">
        <FullProductName ProductID="SUSE Package Hub 15 SP5">SUSE Package Hub 15 SP5</FullProductName>
      </Branch>
    </Branch>
    <Branch Type="Product Family" Name="openSUSE Leap 15.5">
      <Branch Type="Product Name" Name="openSUSE Leap 15.5">
        <FullProductName ProductID="openSUSE Leap 15.5" CPE="cpe:/o:opensuse:leap:15.5">openSUSE Leap 15.5</FullProductName>
      </Branch>
    </Branch>
    <Branch Type="Product Family" Name="openSUSE Tumbleweed">
      <Branch Type="Product Name" Name="openSUSE Tumbleweed">
        <FullProductName ProductID="openSUSE Tumbleweed" CPE="cpe:/o:opensuse:tumbleweed">openSUSE Tumbleweed</FullProductName>
      </Branch>
    </Branch>
    <Branch Type="Product Version" Name="python311-yt-dlp-2023.11.14-bp155.3.3.1">
      <FullProductName ProductID="python311-yt-dlp-2023.11.14-bp155.3.3.1">python311-yt-dlp-2023.11.14-bp155.3.3.1</FullProductName>
    </Branch>
    <Branch Type="Product Version" Name="yt-dlp-2023.07.06-1.1">
      <FullProductName ProductID="yt-dlp-2023.07.06-1.1">yt-dlp-2023.07.06-1.1</FullProductName>
    </Branch>
    <Branch Type="Product Version" Name="yt-dlp-2023.11.14-bp155.3.3.1">
      <FullProductName ProductID="yt-dlp-2023.11.14-bp155.3.3.1">yt-dlp-2023.11.14-bp155.3.3.1</FullProductName>
    </Branch>
    <Branch Type="Product Version" Name="yt-dlp-bash-completion-2023.07.06-1.1">
      <FullProductName ProductID="yt-dlp-bash-completion-2023.07.06-1.1">yt-dlp-bash-completion-2023.07.06-1.1</FullProductName>
    </Branch>
    <Branch Type="Product Version" Name="yt-dlp-bash-completion-2023.11.14-bp155.3.3.1">
      <FullProductName ProductID="yt-dlp-bash-completion-2023.11.14-bp155.3.3.1">yt-dlp-bash-completion-2023.11.14-bp155.3.3.1</FullProductName>
    </Branch>
    <Branch Type="Product Version" Name="yt-dlp-fish-completion-2023.07.06-1.1">
      <FullProductName ProductID="yt-dlp-fish-completion-2023.07.06-1.1">yt-dlp-fish-completion-2023.07.06-1.1</FullProductName>
    </Branch>
    <Branch Type="Product Version" Name="yt-dlp-fish-completion-2023.11.14-bp155.3.3.1">
      <FullProductName ProductID="yt-dlp-fish-completion-2023.11.14-bp155.3.3.1">yt-dlp-fish-completion-2023.11.14-bp155.3.3.1</FullProductName>
    </Branch>
    <Branch Type="Product Version" Name="yt-dlp-zsh-completion-2023.07.06-1.1">
      <FullProductName ProductID="yt-dlp-zsh-completion-2023.07.06-1.1">yt-dlp-zsh-completion-2023.07.06-1.1</FullProductName>
    </Branch>
    <Branch Type="Product Version" Name="yt-dlp-zsh-completion-2023.11.14-bp155.3.3.1">
      <FullProductName ProductID="yt-dlp-zsh-completion-2023.11.14-bp155.3.3.1">yt-dlp-zsh-completion-2023.11.14-bp155.3.3.1</FullProductName>
    </Branch>
    <Relationship ProductReference="python311-yt-dlp-2023.11.14-bp155.3.3.1" RelationType="Default Component Of" RelatesToProductReference="SUSE Package Hub 15 SP5">
      <FullProductName ProductID="SUSE Package Hub 15 SP5:python311-yt-dlp-2023.11.14-bp155.3.3.1">python311-yt-dlp-2023.11.14-bp155.3.3.1 as a component of SUSE Package Hub 15 SP5</FullProductName>
    </Relationship>
    <Relationship ProductReference="yt-dlp-2023.11.14-bp155.3.3.1" RelationType="Default Component Of" RelatesToProductReference="SUSE Package Hub 15 SP5">
      <FullProductName ProductID="SUSE Package Hub 15 SP5:yt-dlp-2023.11.14-bp155.3.3.1">yt-dlp-2023.11.14-bp155.3.3.1 as a component of SUSE Package Hub 15 SP5</FullProductName>
    </Relationship>
    <Relationship ProductReference="yt-dlp-bash-completion-2023.11.14-bp155.3.3.1" RelationType="Default Component Of" RelatesToProductReference="SUSE Package Hub 15 SP5">
      <FullProductName ProductID="SUSE Package Hub 15 SP5:yt-dlp-bash-completion-2023.11.14-bp155.3.3.1">yt-dlp-bash-completion-2023.11.14-bp155.3.3.1 as a component of SUSE Package Hub 15 SP5</FullProductName>
    </Relationship>
    <Relationship ProductReference="yt-dlp-fish-completion-2023.11.14-bp155.3.3.1" RelationType="Default Component Of" RelatesToProductReference="SUSE Package Hub 15 SP5">
      <FullProductName ProductID="SUSE Package Hub 15 SP5:yt-dlp-fish-completion-2023.11.14-bp155.3.3.1">yt-dlp-fish-completion-2023.11.14-bp155.3.3.1 as a component of SUSE Package Hub 15 SP5</FullProductName>
    </Relationship>
    <Relationship ProductReference="yt-dlp-zsh-completion-2023.11.14-bp155.3.3.1" RelationType="Default Component Of" RelatesToProductReference="SUSE Package Hub 15 SP5">
      <FullProductName ProductID="SUSE Package Hub 15 SP5:yt-dlp-zsh-completion-2023.11.14-bp155.3.3.1">yt-dlp-zsh-completion-2023.11.14-bp155.3.3.1 as a component of SUSE Package Hub 15 SP5</FullProductName>
    </Relationship>
    <Relationship ProductReference="python311-yt-dlp-2023.11.14-bp155.3.3.1" RelationType="Default Component Of" RelatesToProductReference="openSUSE Leap 15.5">
      <FullProductName ProductID="openSUSE Leap 15.5:python311-yt-dlp-2023.11.14-bp155.3.3.1">python311-yt-dlp-2023.11.14-bp155.3.3.1 as a component of openSUSE Leap 15.5</FullProductName>
    </Relationship>
    <Relationship ProductReference="yt-dlp-2023.11.14-bp155.3.3.1" RelationType="Default Component Of" RelatesToProductReference="openSUSE Leap 15.5">
      <FullProductName ProductID="openSUSE Leap 15.5:yt-dlp-2023.11.14-bp155.3.3.1">yt-dlp-2023.11.14-bp155.3.3.1 as a component of openSUSE Leap 15.5</FullProductName>
    </Relationship>
    <Relationship ProductReference="yt-dlp-bash-completion-2023.11.14-bp155.3.3.1" RelationType="Default Component Of" RelatesToProductReference="openSUSE Leap 15.5">
      <FullProductName ProductID="openSUSE Leap 15.5:yt-dlp-bash-completion-2023.11.14-bp155.3.3.1">yt-dlp-bash-completion-2023.11.14-bp155.3.3.1 as a component of openSUSE Leap 15.5</FullProductName>
    </Relationship>
    <Relationship ProductReference="yt-dlp-fish-completion-2023.11.14-bp155.3.3.1" RelationType="Default Component Of" RelatesToProductReference="openSUSE Leap 15.5">
      <FullProductName ProductID="openSUSE Leap 15.5:yt-dlp-fish-completion-2023.11.14-bp155.3.3.1">yt-dlp-fish-completion-2023.11.14-bp155.3.3.1 as a component of openSUSE Leap 15.5</FullProductName>
    </Relationship>
    <Relationship ProductReference="yt-dlp-zsh-completion-2023.11.14-bp155.3.3.1" RelationType="Default Component Of" RelatesToProductReference="openSUSE Leap 15.5">
      <FullProductName ProductID="openSUSE Leap 15.5:yt-dlp-zsh-completion-2023.11.14-bp155.3.3.1">yt-dlp-zsh-completion-2023.11.14-bp155.3.3.1 as a component of openSUSE Leap 15.5</FullProductName>
    </Relationship>
    <Relationship ProductReference="yt-dlp-2023.07.06-1.1" RelationType="Default Component Of" RelatesToProductReference="openSUSE Tumbleweed">
      <FullProductName ProductID="openSUSE Tumbleweed:yt-dlp-2023.07.06-1.1">yt-dlp-2023.07.06-1.1 as a component of openSUSE Tumbleweed</FullProductName>
    </Relationship>
    <Relationship ProductReference="yt-dlp-bash-completion-2023.07.06-1.1" RelationType="Default Component Of" RelatesToProductReference="openSUSE Tumbleweed">
      <FullProductName ProductID="openSUSE Tumbleweed:yt-dlp-bash-completion-2023.07.06-1.1">yt-dlp-bash-completion-2023.07.06-1.1 as a component of openSUSE Tumbleweed</FullProductName>
    </Relationship>
    <Relationship ProductReference="yt-dlp-fish-completion-2023.07.06-1.1" RelationType="Default Component Of" RelatesToProductReference="openSUSE Tumbleweed">
      <FullProductName ProductID="openSUSE Tumbleweed:yt-dlp-fish-completion-2023.07.06-1.1">yt-dlp-fish-completion-2023.07.06-1.1 as a component of openSUSE Tumbleweed</FullProductName>
    </Relationship>
    <Relationship ProductReference="yt-dlp-zsh-completion-2023.07.06-1.1" RelationType="Default Component Of" RelatesToProductReference="openSUSE Tumbleweed">
      <FullProductName ProductID="openSUSE Tumbleweed:yt-dlp-zsh-completion-2023.07.06-1.1">yt-dlp-zsh-completion-2023.07.06-1.1 as a component of openSUSE Tumbleweed</FullProductName>
    </Relationship>
  </ProductTree>
  <Vulnerability xmlns="http://docs.oasis-open.org/csaf/ns/csaf-cvrf/v1.2/vuln" Ordinal="1">
    <Notes>
      <Note Title="Vulnerability Description" Type="General" Ordinal="1" xml:lang="en">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.</Note>
    </Notes>
    <CVE>CVE-2023-35934</CVE>
    <ProductStatuses>
      <Status Type="Fixed">
        <ProductID>SUSE Package Hub 15 SP5:python311-yt-dlp-2023.11.14-bp155.3.3.1</ProductID>
        <ProductID>SUSE Package Hub 15 SP5:yt-dlp-2023.11.14-bp155.3.3.1</ProductID>
        <ProductID>SUSE Package Hub 15 SP5:yt-dlp-bash-completion-2023.11.14-bp155.3.3.1</ProductID>
        <ProductID>SUSE Package Hub 15 SP5:yt-dlp-fish-completion-2023.11.14-bp155.3.3.1</ProductID>
        <ProductID>SUSE Package Hub 15 SP5:yt-dlp-zsh-completion-2023.11.14-bp155.3.3.1</ProductID>
        <ProductID>openSUSE Leap 15.5:python311-yt-dlp-2023.11.14-bp155.3.3.1</ProductID>
        <ProductID>openSUSE Leap 15.5:yt-dlp-2023.11.14-bp155.3.3.1</ProductID>
        <ProductID>openSUSE Leap 15.5:yt-dlp-bash-completion-2023.11.14-bp155.3.3.1</ProductID>
        <ProductID>openSUSE Leap 15.5:yt-dlp-fish-completion-2023.11.14-bp155.3.3.1</ProductID>
        <ProductID>openSUSE Leap 15.5:yt-dlp-zsh-completion-2023.11.14-bp155.3.3.1</ProductID>
        <ProductID>openSUSE Tumbleweed:yt-dlp-2023.07.06-1.1</ProductID>
        <ProductID>openSUSE Tumbleweed:yt-dlp-bash-completion-2023.07.06-1.1</ProductID>
        <ProductID>openSUSE Tumbleweed:yt-dlp-fish-completion-2023.07.06-1.1</ProductID>
        <ProductID>openSUSE Tumbleweed:yt-dlp-zsh-completion-2023.07.06-1.1</ProductID>
      </Status>
    </ProductStatuses>
    <Threats>
      <Threat Type="Impact">
        <Description>moderate</Description>
      </Threat>
    </Threats>
    <CVSSScoreSets>
      <ScoreSetV3>
        <BaseScoreV3>6.1</BaseScoreV3>
        <VectorV3>CVSS:3.1/AV:N/AC:H/PR:N/UI:R/S:C/C:H/I:N/A:N</VectorV3>
      </ScoreSetV3>
    </CVSSScoreSets>
  </Vulnerability>
</cvrfdoc>
