PYSEC-2022-42993
Vulnerability from pysec - Published: 2022-12-16 23:15 - Updated: 2023-05-04 04:29
VLAI?
Details
GuardDog is a CLI tool to identify malicious PyPI packages. Versions prior to v0.1.8 are vulnerable to arbitrary file write when scanning a specially-crafted remote PyPI package. Extracting files using shutil.unpack_archive() from a potentially malicious tarball without validating that the destination file path is within the intended destination directory can cause files outside the destination directory to be overwritten. This issue is patched in version 0.1.8. Potential workarounds include using a safer module, like zipfile, and validating the location of the extracted files and discarding those with malicious paths.
Impacted products
| Name | purl | guarddog | pkg:pypi/guarddog |
|---|
Aliases
{
"affected": [
{
"package": {
"ecosystem": "PyPI",
"name": "guarddog",
"purl": "pkg:pypi/guarddog"
},
"ranges": [
{
"events": [
{
"introduced": "0"
},
{
"fixed": "37c7d0767ba28f4df46117d478f97652594c491c"
}
],
"repo": "https://github.com/DataDog/guarddog",
"type": "GIT"
},
{
"events": [
{
"introduced": "0"
},
{
"fixed": "0.1.8"
}
],
"type": "ECOSYSTEM"
}
],
"versions": [
"0.1.1",
"0.1.3",
"0.1.4",
"0.1.5",
"0.1.6",
"0.1.7"
]
}
],
"aliases": [
"CVE-2022-23530",
"GHSA-78m5-jpmf-ch7v"
],
"details": "GuardDog is a CLI tool to identify malicious PyPI packages. Versions prior to v0.1.8 are vulnerable to arbitrary file write when scanning a specially-crafted remote PyPI package. Extracting files using shutil.unpack_archive() from a potentially malicious tarball without validating that the destination file path is within the intended destination directory can cause files outside the destination directory to be overwritten. This issue is patched in version 0.1.8. Potential workarounds include using a safer module, like zipfile, and validating the location of the extracted files and discarding those with malicious paths.",
"id": "PYSEC-2022-42993",
"modified": "2023-05-04T04:29:25.550921Z",
"published": "2022-12-16T23:15:00Z",
"references": [
{
"type": "EVIDENCE",
"url": "https://github.com/DataDog/guarddog/blob/a1d064ceb09d39bb28deb6972bc0a278756ea91f/guarddog/scanners/package_scanner.py#L153..158"
},
{
"type": "WEB",
"url": "https://github.com/DataDog/guarddog/blob/a1d064ceb09d39bb28deb6972bc0a278756ea91f/guarddog/scanners/package_scanner.py#L153..158"
},
{
"type": "EVIDENCE",
"url": "https://github.com/DataDog/guarddog/security/advisories/GHSA-78m5-jpmf-ch7v"
},
{
"type": "ADVISORY",
"url": "https://github.com/DataDog/guarddog/security/advisories/GHSA-78m5-jpmf-ch7v"
},
{
"type": "FIX",
"url": "https://github.com/DataDog/guarddog/commit/37c7d0767ba28f4df46117d478f97652594c491c"
}
]
}
Loading…
Loading…
Sightings
| Author | Source | Type | Date |
|---|
Nomenclature
- Seen: The vulnerability was mentioned, discussed, or observed by the user.
- Confirmed: The vulnerability has been validated from an analyst's perspective.
- Published Proof of Concept: A public proof of concept is available for this vulnerability.
- Exploited: The vulnerability was observed as exploited by the user who reported the sighting.
- Patched: The vulnerability was observed as successfully patched by the user who reported the sighting.
- Not exploited: The vulnerability was not observed as exploited by the user who reported the sighting.
- Not confirmed: The user expressed doubt about the validity of the vulnerability.
- Not patched: The vulnerability was not observed as successfully patched by the user who reported the sighting.
Loading…
Loading…