CVE-2026-45364 PUBLISHED

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

Assigner: GitHub_M
Reserved: 12.05.2026 Published: 28.05.2026 Updated: 28.05.2026

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.

Metrics

CVSS Vector: CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:L/A:L
CVSS Score: 7.3

Product Status

Vendor better-auth
Product better-auth
Versions
  • Version < 1.4.17 is affected
  • Version >= 1.5.0-beta.1, < 1.5.0-beta.9 is affected

References

Problem Types

  • CWE-307: Improper Restriction of Excessive Authentication Attempts CWE