{ "schema_version": "1.4.0", "id": "GHSA-8gmx-cpcg-f8h5", "modified": "2023-06-13T17:37:47Z", "published": "2021-08-25T20:55:11Z", "aliases": [ "CVE-2021-30455" ], "summary": "Double-free in id-map", "details": "The clone_from implementation for IdMap drops the values present in the map and then begins cloning values from the other map. If a .clone() call pancics, then the afformentioned dropped elements can be freed again.\nget_or_insert\n\nget_or_insert reserves space for a value, before calling the user provided insertion function f. If the function f panics then uninitialized or previously freed memory can be dropped.\nremove_set\n\nWhen removing a set of elements, ptr::drop_in_place is called on each of the element to be removed. If the Drop impl of one of these elements panics then the previously dropped elements can be dropped again.", "severity": [ { "type": "CVSS_V3", "score": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H" } ], "affected": [ { "package": { "ecosystem": "crates.io", "name": "id-map" }, "ranges": [ { "type": "ECOSYSTEM", "events": [ { "introduced": "0" }, { "last_affected": "0.2.1" } ] } ] } ], "references": [ { "type": "ADVISORY", "url": "https://nvd.nist.gov/vuln/detail/CVE-2021-30455" }, { "type": "WEB", "url": "https://github.com/andrewhickman/id-map/issues/3" }, { "type": "PACKAGE", "url": "https://github.com/andrewhickman/id-map" }, { "type": "WEB", "url": "https://rustsec.org/advisories/RUSTSEC-2021-0052.html" } ], "database_specific": { "cwe_ids": [ "CWE-415" ], "severity": "CRITICAL", "github_reviewed": true, "github_reviewed_at": "2021-08-19T17:04:17Z", "nvd_published_at": null } }