nano-id is a unique string ID generator for Rust. Affected versions of the nano-id crate incorrectly generated IDs using a reduced character set in the `nano_id::base62` and `nano_id::base58` functions. Specifically, the `base62` function used a character set of 32 symbols instead of the intended 62 symbols, and the `base58` function used a character set of 16 symbols instead of the intended 58 symbols. Additionally, the `nano_id::gen` macro is also affected when a custom character set that is not a power of 2 in size is specified. It should be noted that `nano_id::base64` is not affected by this vulnerability. This can result in a significant reduction in entropy, making the generated IDs predictable and vulnerable to brute-force attacks when the IDs are used in security-sensitive contexts such as session tokens or unique identifiers. The vulnerability is fixed in 0.4.0.
References
Link | Resource |
---|---|
https://github.com/viz-rs/nano-id/commit/a9022772b2f1ce38929b5b81eccc670ac9d3ab23 | Patch |
https://github.com/viz-rs/nano-id/security/advisories/GHSA-9hc7-6w9r-wj94 | Exploit Patch Vendor Advisory |
History
No history.
MITRE Information
Status: PUBLISHED
Assigner: GitHub_M
Published: 2024-06-04T14:11:26.945Z
Updated: 2024-06-05T05:15:37.447Z
Reserved: 2024-05-27T15:59:57.030Z
Link: CVE-2024-36400
JSON object: View
NVD Information
Status : Analyzed
Published: 2024-06-04T15:15:46.980
Modified: 2024-06-10T19:39:21.660
Link: CVE-2024-36400
JSON object: View
Redhat Information
No data.
CWE