VDB

CVE-2026-40198

CVE-2026-40198 PUBLISHED

Reported by CPANSec · Published April 10, 2026

Net::CIDR::Lite versions before 0.23 for Perl does not validate IPv6 group count, which may allow IP ACL bypass. _pack_ipv6() does not check that uncompressed IPv6 addresses (without ::) have exactly 8 hex groups. Inputs like "abcd", "1:2:3", or "1:2:3:4:5:6:7" are accepted and produce packed values of wrong length (3, 7, or 15 bytes instead of 17). The packed values are used internally for mask and comparison operations. find() and bin_find() use Perl string comparison (lt/gt) on these values, and comparing strings of different lengths gives wrong results. This can cause find() to incorrectly report an address as inside or outside a range. Example: my $cidr = Net::CIDR::Lite->new("::/8"); $cidr->find("1:2:3"); # invalid input, incorrectly returns true This is the same class of input validation issue as CVE-2021-47154 (IPv4 leading zeros) previously fixed in this module. See also CVE-2026-40199, a related issue in the same function affecting IPv4 mapped IPv6 addresses.

EPSS 0.05% · 16.5th percentile

Risk Scores

EPSS Score
0.05%
16.5th percentile

Affected Products

VendorProductVersions
STIGTSPNet::CIDR::Lite0
STIGTSPNet::CIDR::Lite0

Timeline

  • Apr 10, 2026 CVE Published
  • Apr 11, 2026 EPSS Score
  • Apr 13, 2026 Security Advisory
  • May 18, 2026 EPSS Score
  • May 19, 2026 EPSS Score
  • May 20, 2026 EPSS Score
  • May 21, 2026 EPSS Score
  • May 22, 2026 EPSS Score
  • May 23, 2026 EPSS Score
  • May 24, 2026 EPSS Score
  • May 25, 2026 EPSS Score
  • May 26, 2026 EPSS Score

References

  • patch
  • release-notes
  • related
Open in Interactive Console →
$ Console Community · 100/wk Open console ›