CVE-2026-45364

HIGH

Better Auth: Rate limiter keys IPv6 addresses individually and is bypassable via prefix rotation

Title source: cna
STIX 2.1

Description

Better Auth is an authentication and authorization library for TypeScript. Prior to 1.4.17 and 1.5.0-beta.9, Better Auth's HTTP rate limiter keyed each request by the exact textual IP address it received in x-forwarded-for (or the configured IP-bearing header). IPv6 clients controlling a typical /64 allocation could rotate through 2^64 distinct source addresses without exhausting the per-address counter, defeating rate limiting on /sign-in/email, /sign-up/email, /forget-password, and every other path the limiter protects. The same bug allowed a single client to vary the textual encoding of one IPv6 address (uppercase, compression, IPv4-mapped, hex-encoded IPv4-in-IPv6) and produce multiple distinct keys. This vulnerability is fixed in 1.4.17 and 1.5.0-beta.9.

Scores

CVSS v3 7.3
EPSS 0.0029
EPSS Percentile 20.9%
Attack Vector NETWORK
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:L/A:L

CISA SSVC

Vulnrichment
Exploitation none
Automatable yes
Technical Impact partial

Details

CWE
CWE-307
Status published
Products (4)
better-auth/better-auth < 1.4.17
better-auth/better-auth >= 1.5.0-beta.1, < 1.5.0-beta.9
npm/better-auth 0 - 1.4.17npm
npm/better-auth 1.5.0-beta.1 - 1.5.0-beta.9npm
Published May 28, 2026
Tracked Since May 29, 2026