CVE-2024-38519

Source
https://nvd.nist.gov/vuln/detail/CVE-2024-38519
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2024-38519.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2024-38519
Aliases
Related
Published
2024-07-02T14:15:13Z
Modified
2025-01-08T16:11:58.364380Z
Summary
[none]
Details

yt-dlp and youtube-dl are command-line audio/video downloaders. Prior to the fixed versions, yt-dlp and youtube-dl do not limit the extensions of downloaded files, which could lead to arbitrary filenames being created in the download folder (and path traversal on Windows). Since yt-dlp and youtube-dl also read config from the working directory (and on Windows executables will be executed from the yt-dlp or youtube-dl directory), this could lead to arbitrary code being executed.

yt-dlp version 2024.07.01 fixes this issue by whitelisting the allowed extensions. youtube-dl fixes this issue in commit d42a222 on the master branch and in nightly builds tagged 2024-07-03 or later. This might mean some very uncommon extensions might not get downloaded, however it will also limit the possible exploitation surface. In addition to upgrading, have .%(ext)s at the end of the output template and make sure the user trusts the websites that they are downloading from. Also, make sure to never download to a directory within PATH or other sensitive locations like one's user directory, system32, or other binaries locations. For users who are not able to upgrade, keep the default output template (-o "%(title)s [%(id)s].%(ext)s); make sure the extension of the media to download is a common video/audio/sub/... one; try to avoid the generic extractor; and/or use --ignore-config --config-location ... to not load config from common locations.

References

Affected packages

Debian:11 / youtube-dl

Package

Name
youtube-dl
Purl
pkg:deb/debian/youtube-dl?arch=source

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected

Affected versions

2021.*

2021.06.06-1
2021.12.17-1~bpo11+1
2021.12.17-1
2021.12.17-2

Ecosystem specific

{
    "urgency": "unimportant"
}

Debian:12 / youtube-dl

Package

Name
youtube-dl
Purl
pkg:deb/debian/youtube-dl?arch=source

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected

Affected versions

2021.*

2021.12.17-2

Ecosystem specific

{
    "urgency": "unimportant"
}

Debian:12 / yt-dlp

Package

Name
yt-dlp
Purl
pkg:deb/debian/yt-dlp?arch=source

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected

Affected versions

2023.*

2023.03.04-1
2023.06.21-1
2023.06.22-1~bpo12+1
2023.06.22-1
2023.07.06-1~bpo12+1
2023.07.06-1
2023.09.24-1
2023.09.24-2~bpo12+1
2023.09.24-2
2023.10.07-1~bpo12+1
2023.10.07-1
2023.10.13-1~bpo11+1
2023.10.13-1~bpo12+1
2023.10.13-1
2023.11.16-1~bpo11+1
2023.11.16-1~bpo12+1
2023.11.16-1
2023.12.30-1

2024.*

2024.03.10-1~bpo12+1
2024.03.10-1
2024.04.09-1~bpo12+1
2024.04.09-1
2024.05.26-1~bpo12+1
2024.05.26-1
2024.05.27-1~bpo12+1
2024.05.27-1
2024.07.01-1
2024.07.02-1~bpo12+1
2024.07.02-1
2024.07.07-1
2024.07.09-1~bpo12+1
2024.07.09-1
2024.07.16-1~bpo12+1
2024.07.16-1
2024.07.25-1~bpo12+1
2024.07.25-1
2024.08.01-1~bpo12+1
2024.08.01-1
2024.08.06-1~bpo12+1
2024.08.06-1
2024.09.27-1~bpo12+1
2024.09.27-1
2024.10.07-1~bpo12+1
2024.10.07-1
2024.10.22-1~bpo12+1
2024.10.22-1
2024.11.04-1
2024.11.18-1~bpo12+1
2024.11.18-1
2024.12.03-1~bpo12+1
2024.12.03-1
2024.12.06-1~bpo12+1
2024.12.06-1
2024.12.13-1~bpo12+1
2024.12.13-1
2024.12.23-1~bpo12+1
2024.12.23-1

Ecosystem specific

{
    "urgency": "unimportant"
}

Debian:13 / yt-dlp

Package

Name
yt-dlp
Purl
pkg:deb/debian/yt-dlp?arch=source

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
2024.07.01-1

Affected versions

2023.*

2023.03.04-1
2023.06.21-1
2023.06.22-1~bpo12+1
2023.06.22-1
2023.07.06-1~bpo12+1
2023.07.06-1
2023.09.24-1
2023.09.24-2~bpo12+1
2023.09.24-2
2023.10.07-1~bpo12+1
2023.10.07-1
2023.10.13-1~bpo11+1
2023.10.13-1~bpo12+1
2023.10.13-1
2023.11.16-1~bpo11+1
2023.11.16-1~bpo12+1
2023.11.16-1
2023.12.30-1

2024.*

2024.03.10-1~bpo12+1
2024.03.10-1
2024.04.09-1~bpo12+1
2024.04.09-1
2024.05.26-1~bpo12+1
2024.05.26-1
2024.05.27-1~bpo12+1
2024.05.27-1

Ecosystem specific

{
    "urgency": "unimportant"
}

Git / github.com/yt-dlp/yt-dlp

Affected ranges

Type
GIT
Repo
https://github.com/yt-dlp/yt-dlp
Events
Introduced
0 Unknown introduced commit / All previous commits are affected
Fixed
Fixed
Type
GIT
Repo
https://github.com/ytdl-org/youtube-dl
Events
Introduced
0 Unknown introduced commit / All previous commits are affected
Fixed
Fixed

Affected versions

2021.*

2021.01.07
2021.01.08
2021.01.09
2021.01.10
2021.01.12
2021.01.14
2021.01.16
2021.01.20
2021.01.29
2021.02.04
2021.02.09
2021.02.15
2021.02.19
2021.02.24
2021.03.01
2021.03.03.2
2021.03.07
2021.03.15
2021.03.24
2021.03.24.1
2021.04.03
2021.04.11
2021.04.22
2021.05.11
2021.06.01
2021.06.08
2021.06.09
2021.06.23
2021.07.07
2021.07.21
2021.07.24
2021.08.02
2021.08.10
2021.09.02
2021.09.25
2021.10.09
2021.10.10
2021.10.22
2021.11.10
2021.11.10.1
2021.12.01
2021.12.25
2021.12.27

2022.*

2022.02.03
2022.02.04
2022.03.08.1
2022.04.08
2022.05.18
2022.06.22
2022.06.22.1
2022.06.29
2022.07.18
2022.08.08
2022.08.14
2022.08.19
2022.09.01
2022.10.04
2022.11.11

2023.*

2023.01.02
2023.01.06
2023.02.17
2023.03.03
2023.03.04
2023.06.21
2023.06.22
2023.07.06
2023.09.24
2023.10.07
2023.10.13
2023.11.14
2023.11.16
2023.12.30

2024.*

2024.03.10
2024.04.09
2024.05.26
2024.05.27