{"document":{"aggregate_severity":{"namespace":"https://www.suse.com/support/security/rating/","text":"moderate"},"category":"csaf_vex","csaf_version":"2.0","distribution":{"text":"Copyright 2024 SUSE LLC. All rights reserved.","tlp":{"label":"WHITE","url":"https://www.first.org/tlp/"}},"lang":"en","notes":[{"category":"summary","text":"SUSE CVE-2025-54368","title":"Title"},{"category":"description","text":"uv is a Python package and project manager written in Rust. In versions 0.8.5 and earlier, remote ZIP archives were handled in a streamwise fashion, and file entries were not reconciled against the archive's central directory. An attacker could contrive a ZIP archive that would extract with legitimate contents on some package installers, and malicious contents on others due to multiple local file entries. An attacker could  also contrive a \"stacked\" ZIP input with multiple internal ZIPs, which would be handled differently by different package installers. The attacker could choose which installer to target in both scenarios. This issue is fixed in version 0.8.6. To work around this issue, users may choose to set UV_INSECURE_NO_ZIP_VALIDATION=1 to revert to the previous behavior.","title":"Description of the CVE"},{"category":"legal_disclaimer","text":"CSAF 2.0 data is provided by SUSE under the Creative Commons License 4.0 with Attribution (CC-BY-4.0).","title":"Terms of use"}],"publisher":{"category":"vendor","contact_details":"https://www.suse.com/support/security/contact/","name":"SUSE Product Security Team","namespace":"https://www.suse.com/"},"references":[{"category":"external","summary":"CVE-2025-54368","url":"https://www.suse.com/security/cve/CVE-2025-54368"},{"category":"external","summary":"SUSE Security Ratings","url":"https://www.suse.com/support/security/rating/"},{"category":"external","summary":"SUSE Bug 1247829 for CVE-2025-54368","url":"https://bugzilla.suse.com/1247829"}],"title":"SUSE CVE CVE-2025-54368","tracking":{"current_release_date":"2026-03-02T00:27:22Z","generator":{"date":"2025-08-08T23:22:10Z","engine":{"name":"cve-database.git:bin/generate-csaf-vex.pl","version":"1"}},"id":"CVE-2025-54368","initial_release_date":"2025-08-08T23:22:10Z","revision_history":[{"date":"2025-08-08T23:22:10Z","number":"2","summary":"Current version"},{"date":"2025-08-09T23:22:08Z","number":"3","summary":"Current version"},{"date":"2025-09-01T23:22:50Z","number":"4","summary":"Current version"},{"date":"2025-11-02T03:52:19Z","number":"5","summary":"Current version"},{"date":"2026-03-02T00:27:22Z","number":"6","summary":"unknown changes"}],"status":"interim","version":"6"}},"product_tree":{"branches":[{"branches":[{"branches":[{"category":"product_name","name":"SUSE Linux Enterprise Server 16.0","product":{"name":"SUSE Linux Enterprise Server 16.0","product_id":"SUSE Linux Enterprise Server 16.0","product_identification_helper":{"cpe":"cpe:/o:suse:sles:16:16.0:server"}}},{"category":"product_name","name":"openSUSE Tumbleweed","product":{"name":"openSUSE Tumbleweed","product_id":"openSUSE Tumbleweed","product_identification_helper":{"cpe":"cpe:/o:opensuse:tumbleweed"}}},{"category":"product_version","name":"python311-uv-0.8.8-1.1","product":{"name":"python311-uv-0.8.8-1.1","product_id":"python311-uv-0.8.8-1.1","product_identification_helper":{"purl":"pkg:rpm/suse/python311-uv@0.8.8-1.1"}}},{"category":"product_version","name":"python311-uv-bash-completion-0.8.8-1.1","product":{"name":"python311-uv-bash-completion-0.8.8-1.1","product_id":"python311-uv-bash-completion-0.8.8-1.1","product_identification_helper":{"purl":"pkg:rpm/suse/python311-uv-bash-completion@0.8.8-1.1"}}},{"category":"product_version","name":"python311-uv-fish-completion-0.8.8-1.1","product":{"name":"python311-uv-fish-completion-0.8.8-1.1","product_id":"python311-uv-fish-completion-0.8.8-1.1","product_identification_helper":{"purl":"pkg:rpm/suse/python311-uv-fish-completion@0.8.8-1.1"}}},{"category":"product_version","name":"python311-uv-zsh-completion-0.8.8-1.1","product":{"name":"python311-uv-zsh-completion-0.8.8-1.1","product_id":"python311-uv-zsh-completion-0.8.8-1.1","product_identification_helper":{"purl":"pkg:rpm/suse/python311-uv-zsh-completion@0.8.8-1.1"}}},{"category":"product_version","name":"python312-uv-0.8.8-1.1","product":{"name":"python312-uv-0.8.8-1.1","product_id":"python312-uv-0.8.8-1.1","product_identification_helper":{"purl":"pkg:rpm/suse/python312-uv@0.8.8-1.1"}}},{"category":"product_version","name":"python312-uv-bash-completion-0.8.8-1.1","product":{"name":"python312-uv-bash-completion-0.8.8-1.1","product_id":"python312-uv-bash-completion-0.8.8-1.1","product_identification_helper":{"purl":"pkg:rpm/suse/python312-uv-bash-completion@0.8.8-1.1"}}},{"category":"product_version","name":"python312-uv-fish-completion-0.8.8-1.1","product":{"name":"python312-uv-fish-completion-0.8.8-1.1","product_id":"python312-uv-fish-completion-0.8.8-1.1","product_identification_helper":{"purl":"pkg:rpm/suse/python312-uv-fish-completion@0.8.8-1.1"}}},{"category":"product_version","name":"python312-uv-zsh-completion-0.8.8-1.1","product":{"name":"python312-uv-zsh-completion-0.8.8-1.1","product_id":"python312-uv-zsh-completion-0.8.8-1.1","product_identification_helper":{"purl":"pkg:rpm/suse/python312-uv-zsh-completion@0.8.8-1.1"}}},{"category":"product_version","name":"python313-uv-0.7.18-160000.2.2","product":{"name":"python313-uv-0.7.18-160000.2.2","product_id":"python313-uv-0.7.18-160000.2.2","product_identification_helper":{"purl":"pkg:rpm/suse/python313-uv@0.7.18-160000.2.2?upstream=python-uv-0.7.18-160000.2.2.src.rpm"}}},{"category":"product_version","name":"python313-uv-0.8.8-1.1","product":{"name":"python313-uv-0.8.8-1.1","product_id":"python313-uv-0.8.8-1.1","product_identification_helper":{"purl":"pkg:rpm/suse/python313-uv@0.8.8-1.1?upstream=python-uv-0.8.8-1.1.src.rpm"}}},{"category":"product_version","name":"python313-uv-bash-completion-0.8.8-1.1","product":{"name":"python313-uv-bash-completion-0.8.8-1.1","product_id":"python313-uv-bash-completion-0.8.8-1.1","product_identification_helper":{"purl":"pkg:rpm/suse/python313-uv-bash-completion@0.8.8-1.1"}}},{"category":"product_version","name":"python313-uv-fish-completion-0.8.8-1.1","product":{"name":"python313-uv-fish-completion-0.8.8-1.1","product_id":"python313-uv-fish-completion-0.8.8-1.1","product_identification_helper":{"purl":"pkg:rpm/suse/python313-uv-fish-completion@0.8.8-1.1"}}},{"category":"product_version","name":"python313-uv-zsh-completion-0.8.8-1.1","product":{"name":"python313-uv-zsh-completion-0.8.8-1.1","product_id":"python313-uv-zsh-completion-0.8.8-1.1","product_identification_helper":{"purl":"pkg:rpm/suse/python313-uv-zsh-completion@0.8.8-1.1"}}}],"category":"product_family","name":"SUSE Linux Enterprise"}],"category":"vendor","name":"SUSE"}],"relationships":[{"category":"default_component_of","full_product_name":{"name":"python313-uv-0.7.18-160000.2.2 as component of SUSE Linux Enterprise Server 16.0","product_id":"SUSE Linux Enterprise Server 16.0:python313-uv-0.7.18-160000.2.2"},"product_reference":"python313-uv-0.7.18-160000.2.2","relates_to_product_reference":"SUSE Linux Enterprise Server 16.0"},{"category":"default_component_of","full_product_name":{"name":"python311-uv-0.8.8-1.1 as component of openSUSE Tumbleweed","product_id":"openSUSE Tumbleweed:python311-uv-0.8.8-1.1"},"product_reference":"python311-uv-0.8.8-1.1","relates_to_product_reference":"openSUSE Tumbleweed"},{"category":"default_component_of","full_product_name":{"name":"python311-uv-bash-completion-0.8.8-1.1 as component of openSUSE Tumbleweed","product_id":"openSUSE Tumbleweed:python311-uv-bash-completion-0.8.8-1.1"},"product_reference":"python311-uv-bash-completion-0.8.8-1.1","relates_to_product_reference":"openSUSE Tumbleweed"},{"category":"default_component_of","full_product_name":{"name":"python311-uv-fish-completion-0.8.8-1.1 as component of openSUSE Tumbleweed","product_id":"openSUSE Tumbleweed:python311-uv-fish-completion-0.8.8-1.1"},"product_reference":"python311-uv-fish-completion-0.8.8-1.1","relates_to_product_reference":"openSUSE Tumbleweed"},{"category":"default_component_of","full_product_name":{"name":"python311-uv-zsh-completion-0.8.8-1.1 as component of openSUSE Tumbleweed","product_id":"openSUSE Tumbleweed:python311-uv-zsh-completion-0.8.8-1.1"},"product_reference":"python311-uv-zsh-completion-0.8.8-1.1","relates_to_product_reference":"openSUSE Tumbleweed"},{"category":"default_component_of","full_product_name":{"name":"python312-uv-0.8.8-1.1 as component of openSUSE Tumbleweed","product_id":"openSUSE Tumbleweed:python312-uv-0.8.8-1.1"},"product_reference":"python312-uv-0.8.8-1.1","relates_to_product_reference":"openSUSE Tumbleweed"},{"category":"default_component_of","full_product_name":{"name":"python312-uv-bash-completion-0.8.8-1.1 as component of openSUSE Tumbleweed","product_id":"openSUSE Tumbleweed:python312-uv-bash-completion-0.8.8-1.1"},"product_reference":"python312-uv-bash-completion-0.8.8-1.1","relates_to_product_reference":"openSUSE Tumbleweed"},{"category":"default_component_of","full_product_name":{"name":"python312-uv-fish-completion-0.8.8-1.1 as component of openSUSE Tumbleweed","product_id":"openSUSE Tumbleweed:python312-uv-fish-completion-0.8.8-1.1"},"product_reference":"python312-uv-fish-completion-0.8.8-1.1","relates_to_product_reference":"openSUSE Tumbleweed"},{"category":"default_component_of","full_product_name":{"name":"python312-uv-zsh-completion-0.8.8-1.1 as component of openSUSE Tumbleweed","product_id":"openSUSE Tumbleweed:python312-uv-zsh-completion-0.8.8-1.1"},"product_reference":"python312-uv-zsh-completion-0.8.8-1.1","relates_to_product_reference":"openSUSE Tumbleweed"},{"category":"default_component_of","full_product_name":{"name":"python313-uv-0.8.8-1.1 as component of openSUSE Tumbleweed","product_id":"openSUSE Tumbleweed:python313-uv-0.8.8-1.1"},"product_reference":"python313-uv-0.8.8-1.1","relates_to_product_reference":"openSUSE Tumbleweed"},{"category":"default_component_of","full_product_name":{"name":"python313-uv-bash-completion-0.8.8-1.1 as component of openSUSE Tumbleweed","product_id":"openSUSE Tumbleweed:python313-uv-bash-completion-0.8.8-1.1"},"product_reference":"python313-uv-bash-completion-0.8.8-1.1","relates_to_product_reference":"openSUSE Tumbleweed"},{"category":"default_component_of","full_product_name":{"name":"python313-uv-fish-completion-0.8.8-1.1 as component of openSUSE Tumbleweed","product_id":"openSUSE Tumbleweed:python313-uv-fish-completion-0.8.8-1.1"},"product_reference":"python313-uv-fish-completion-0.8.8-1.1","relates_to_product_reference":"openSUSE Tumbleweed"},{"category":"default_component_of","full_product_name":{"name":"python313-uv-zsh-completion-0.8.8-1.1 as component of openSUSE Tumbleweed","product_id":"openSUSE Tumbleweed:python313-uv-zsh-completion-0.8.8-1.1"},"product_reference":"python313-uv-zsh-completion-0.8.8-1.1","relates_to_product_reference":"openSUSE Tumbleweed"}]},"vulnerabilities":[{"cve":"CVE-2025-54368","ids":[{"system_name":"SUSE CVE Page","text":"https://www.suse.com/security/cve/CVE-2025-54368"}],"notes":[{"category":"general","text":"uv is a Python package and project manager written in Rust. In versions 0.8.5 and earlier, remote ZIP archives were handled in a streamwise fashion, and file entries were not reconciled against the archive's central directory. An attacker could contrive a ZIP archive that would extract with legitimate contents on some package installers, and malicious contents on others due to multiple local file entries. An attacker could  also contrive a \"stacked\" ZIP input with multiple internal ZIPs, which would be handled differently by different package installers. The attacker could choose which installer to target in both scenarios. This issue is fixed in version 0.8.6. To work around this issue, users may choose to set UV_INSECURE_NO_ZIP_VALIDATION=1 to revert to the previous behavior.","title":"CVE description"}],"product_status":{"recommended":["SUSE Linux Enterprise Server 16.0:python313-uv-0.7.18-160000.2.2","openSUSE Tumbleweed:python311-uv-0.8.8-1.1","openSUSE Tumbleweed:python311-uv-bash-completion-0.8.8-1.1","openSUSE Tumbleweed:python311-uv-fish-completion-0.8.8-1.1","openSUSE Tumbleweed:python311-uv-zsh-completion-0.8.8-1.1","openSUSE Tumbleweed:python312-uv-0.8.8-1.1","openSUSE Tumbleweed:python312-uv-bash-completion-0.8.8-1.1","openSUSE Tumbleweed:python312-uv-fish-completion-0.8.8-1.1","openSUSE Tumbleweed:python312-uv-zsh-completion-0.8.8-1.1","openSUSE Tumbleweed:python313-uv-0.8.8-1.1","openSUSE Tumbleweed:python313-uv-bash-completion-0.8.8-1.1","openSUSE Tumbleweed:python313-uv-fish-completion-0.8.8-1.1","openSUSE Tumbleweed:python313-uv-zsh-completion-0.8.8-1.1"]},"references":[{"category":"external","summary":"CVE-2025-54368","url":"https://www.suse.com/security/cve/CVE-2025-54368"},{"category":"external","summary":"SUSE Security Ratings","url":"https://www.suse.com/support/security/rating/"},{"category":"external","summary":"SUSE Bug 1247829 for CVE-2025-54368","url":"https://bugzilla.suse.com/1247829"}],"remediations":[{"category":"vendor_fix","details":"To install this SUSE Security Update use the SUSE recommended installation methods like YaST online_update or \"zypper patch\".\n","product_ids":["SUSE Linux Enterprise Server 16.0:python313-uv-0.7.18-160000.2.2","openSUSE Tumbleweed:python311-uv-0.8.8-1.1","openSUSE Tumbleweed:python311-uv-bash-completion-0.8.8-1.1","openSUSE Tumbleweed:python311-uv-fish-completion-0.8.8-1.1","openSUSE Tumbleweed:python311-uv-zsh-completion-0.8.8-1.1","openSUSE Tumbleweed:python312-uv-0.8.8-1.1","openSUSE Tumbleweed:python312-uv-bash-completion-0.8.8-1.1","openSUSE Tumbleweed:python312-uv-fish-completion-0.8.8-1.1","openSUSE Tumbleweed:python312-uv-zsh-completion-0.8.8-1.1","openSUSE Tumbleweed:python313-uv-0.8.8-1.1","openSUSE Tumbleweed:python313-uv-bash-completion-0.8.8-1.1","openSUSE Tumbleweed:python313-uv-fish-completion-0.8.8-1.1","openSUSE Tumbleweed:python313-uv-zsh-completion-0.8.8-1.1"]}],"scores":[{"cvss_v3":{"baseScore":6.5,"baseSeverity":"MEDIUM","vectorString":"CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:U/C:N/I:H/A:N","version":"3.1"},"products":["SUSE Linux Enterprise Server 16.0:python313-uv-0.7.18-160000.2.2","openSUSE Tumbleweed:python311-uv-0.8.8-1.1","openSUSE Tumbleweed:python311-uv-bash-completion-0.8.8-1.1","openSUSE Tumbleweed:python311-uv-fish-completion-0.8.8-1.1","openSUSE Tumbleweed:python311-uv-zsh-completion-0.8.8-1.1","openSUSE Tumbleweed:python312-uv-0.8.8-1.1","openSUSE Tumbleweed:python312-uv-bash-completion-0.8.8-1.1","openSUSE Tumbleweed:python312-uv-fish-completion-0.8.8-1.1","openSUSE Tumbleweed:python312-uv-zsh-completion-0.8.8-1.1","openSUSE Tumbleweed:python313-uv-0.8.8-1.1","openSUSE Tumbleweed:python313-uv-bash-completion-0.8.8-1.1","openSUSE Tumbleweed:python313-uv-fish-completion-0.8.8-1.1","openSUSE Tumbleweed:python313-uv-zsh-completion-0.8.8-1.1"]}],"threats":[{"category":"impact","date":"2025-08-08T02:00:10Z","details":"moderate"}],"title":"CVE-2025-54368"}]}