CVE 7.1 HIGH

Laravel Passport’s TokenGuard Authenticates Unrelated User for Client Credentials Tokens_CVE-2026-39976

7.1 / 10
HIGH
CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:C/C:H/I:L/A:N

Description

Laravel Passport provides OAuth2 server support to Laravel. From 13.0.0 to before 13.7.1, there is an Authentication Bypass for client_credentials tokens. the league/oauth2-server library sets the JWT sub claim to the client identifier (since there's no user). The token guard then passes this value to retrieveById() without validating it's actually a user identifier, potentially resolving an unrelated real user. Any machine-to-machine token can inadvertently authenticate as an actual user. This vulnerability is fixed in 13.7.1.

Basic Information

ID CVE-2026-39976
Source GitHub_M
Published Apr 9, 2026 at 16:50
Modified Apr 9, 2026 at 19:31

Affected Product

Vendor laravel
Product passport
Version >= 13.0.0, < 13.7.1
Affected Versions laravel passport >= 13.0.0, < 13.7.1

CWE Classification

References

💭 Join the Security Discussion

🔒 Your email address will not be published. Required fields are marked *

⚠️ Please be respectful and constructive in your comments. Security discussions should remain professional.