Description
Amon2 versions before 6.17 for Perl use an insecure random_string implementation for security functions.

In versions 6.06 through 6.16, the random_string function will attempt to read bytes from the /dev/urandom device, but if that is unavailable then it generates bytes by concatenating a SHA-1 hash seeded with the built-in rand() function, the PID, and the high resolution epoch time. The PID will come from a small set of numbers, and the epoch time may be guessed, if it is not leaked from the HTTP Date header. The built-in rand function is unsuitable for cryptographic usage.

Before version 6.06, there was no fallback when /dev/urandom was not available.

Before version 6.04, the random_string function used the built-in rand() function to generate a mixed-case alphanumeric string.

This function may be used for generating session ids, generating secrets for signing or encrypting cookie session data and generating tokens used for Cross Site Request Forgery (CSRF) protection.
Published: 2026-03-28
Score: 9.8 Critical
EPSS: < 1% Very Low
KEV: No
Impact: Predictable token generation leading to session hijacking or secret compromise
Action: Immediate Patch
AI Analysis

Impact

Amon2 versions prior to 6.17 for Perl contain an insecure implementation of the random_string utility used for generating session identifiers, signing secrets, and CSRF tokens. The function relies on non‑cryptographic randomness; it attempts to read from /dev/urandom, but when that is unavailable it falls back to a construction that concatenates a SHA‑1 hash seeded with the built‑in rand() function, the process ID and a high‑resolution epoch time. Because the seed components have limited entropy or are predictable, the generated tokens can be reproduced or guessed, exposing the application to session hijacking or credential compromise. This weakness maps to CWE‑338 (Cryptographic Failure: Random Number Generation) and CWE‑340 (Cryptographic Failure: Lack of Cryptographic Randomness).

Affected Systems

All official releases of the Perl module Amon2 distributed by TOKUHIROM that are older than 6.17 are affected. That includes the series 6.06 through 6.16, which use the insecure fallback logic, as well as earlier releases 6.04 and 6.05 that rely solely on rand(), and any pre‑6.04 versions with no fallback. Applications that import this module to produce session IDs, CSRF tokens, or signed cookie data are at risk; these typically include web frameworks and CGI scripts built upon Amon2.

Risk and Exploitability

The CVSS base score of 9.8 marks this as a critical vulnerability, yet the EPSS of less than 1% suggests a low likelihood of current exploitation, and the issue is not catalogued in CISA's Known Exploited Vulnerabilities list. Based on the description, it is inferred that an attacker could remotely compromise an application that generates or exposes tokens through HTTP endpoints, or locally for a user that can trigger token generation. No elevated privileges are required, and the exploitation depends solely on the lack of cryptographic randomness. Consequently, the risk escalates for any service that depends on Amon2 for security token generation.

Generated by OpenCVE AI on April 1, 2026 at 06:59 UTC.

Remediation

Vendor Solution

Upgrade to Amon2 version 6.17 or later.


OpenCVE Recommended Actions

  • Upgrade the Amon2 Perl module to version 6.17 or newer.
  • Verify that the application imports the updated module and that no legacy random_string logic remains.
  • Review application code for any hard‑coded or custom random_string calls and replace them with a secure random generator.
  • Monitor authentication logs for suspicious session activity that could indicate token prediction or replay attacks.

Generated by OpenCVE AI on April 1, 2026 at 06:59 UTC.

Tracking

Sign in to view the affected projects.

Advisories

No advisories yet.

History

Wed, 01 Apr 2026 23:45:00 +0000

Type Values Removed Values Added
Metrics ssvc

{'options': {'Automatable': 'yes', 'Exploitation': 'none', 'Technical Impact': 'total'}, 'version': '2.0.3'}


Wed, 01 Apr 2026 02:15:00 +0000

Type Values Removed Values Added
CPEs cpe:2.3:a:tokuhirom:amon2:*:*:*:*:*:perl:*:*
Metrics cvssV3_1

{'score': 9.8, 'vector': 'CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H'}


Mon, 30 Mar 2026 07:15:00 +0000

Type Values Removed Values Added
First Time appeared Tokuhirom
Tokuhirom amon2
Vendors & Products Tokuhirom
Tokuhirom amon2

Sat, 28 Mar 2026 21:30:00 +0000

Type Values Removed Values Added
References

Sat, 28 Mar 2026 19:00:00 +0000

Type Values Removed Values Added
Description Amon2 versions before 6.17 for Perl use an insecure random_string implementation for security functions. In versions 6.06 through 6.16, the random_string function will attempt to read bytes from the /dev/urandom device, but if that is unavailable then it generates bytes by concatenating a SHA-1 hash seeded with the built-in rand() function, the PID, and the high resolution epoch time. The PID will come from a small set of numbers, and the epoch time may be guessed, if it is not leaked from the HTTP Date header. The built-in rand function is unsuitable for cryptographic usage. Before version 6.06, there was no fallback when /dev/urandom was not available. Before version 6.04, the random_string function used the built-in rand() function to generate a mixed-case alphanumeric string. This function may be used for generating session ids, generating secrets for signing or encrypting cookie session data and generating tokens used for Cross Site Request Forgery (CSRF) protection.
Title Amon2 versions before 6.17 for Perl use an insecure random_string implementation for security functions
Weaknesses CWE-338
CWE-340
References

cve-icon MITRE

Status: PUBLISHED

Assigner: CPANSec

Published:

Updated: 2026-04-01T14:13:01.746Z

Reserved: 2026-03-08T23:56:33.670Z

Link: CVE-2025-15604

cve-icon Vulnrichment

Updated: 2026-03-28T20:06:46.387Z

cve-icon NVD

Status : Modified

Published: 2026-03-28T19:16:53.387

Modified: 2026-04-01T15:16:23.170

Link: CVE-2025-15604

cve-icon Redhat

No data.

cve-icon OpenCVE Enrichment

Updated: 2026-04-02T07:55:10Z

Weaknesses