Skip to main content

Redis CVE-2026-40937

| EUVD-2026-25092 HIGH
Missing Authorization (CWE-862)
2026-04-22 https://github.com/rustfs/rustfs GHSA-pfcq-4gjr-6gjm
8.3
CVSS 3.1
Share

CVSS VectorNVD

CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:L
Attack Vector
Network
Attack Complexity
Low
Privileges Required
Low
User Interaction
None
Scope
Unchanged
Confidentiality
High
Integrity
High
Availability
Low

Lifecycle Timeline

6
Re-analysis Queued
Apr 24, 2026 - 13:22 vuln.today
cvss_changed
Patch released
Apr 24, 2026 - 13:12 nvd
Patch available
Patch available
Apr 22, 2026 - 22:02 EUVD
EUVD ID Assigned
Apr 22, 2026 - 19:31 euvd
EUVD-2026-25092
Analysis Generated
Apr 22, 2026 - 19:31 vuln.today
CVE Published
Apr 22, 2026 - 19:24 nvd
HIGH 8.3

DescriptionNVD

Missing Admin Auth on Notification Target Endpoints in RustFS

Finding Summary

All four notification target admin API endpoints in rustfs/src/admin/handlers/event.rs use a check_permissions helper that validates authentication only (access key + session token), without performing any admin-action authorization via validate_admin_request. Every other admin handler in the codebase correctly calls validate_admin_request with a specific AdminAction. This is the only admin handler file that skips authorization.

A non-admin user can overwrite a shared admin-defined notification target by name, causing subsequent bucket events to be delivered to an attacker-controlled endpoint. This enables cross-user event interception and audit evasion.

What Was Proven Live

  1. Authorization bypass on all four endpoints (03_readonly_user_bypass.py)
  • PUT, GET list, GET arns, DELETE all return 200 for readonly-user
  • Control routes (list-users, kms/status) correctly return 403
  • Unauthenticated requests correctly rejected (403 Signature required)
  1. SSRF via health probe (04_ssrf_listener_landing.py)
  • HEAD request from rustfs container to attacker-controlled listener
  • No host validation: only scheme check (http/https)
  1. Target hijacking and event exfiltration (05_target_hijacking.py, 06_full_event_exfil.py)
  • Readonly-user overwrites admin-configured target URL by name
  • Subsequent S3 events delivered to attacker-controlled endpoint
  • Captured event body includes object keys, bucket names, user identities, and request metadata
  1. Audit evasion (05_target_hijacking.py)
  • Readonly-user can delete unbound targets
  • Readonly-user can overwrite bound targets (silently redirecting events)

Escalation Vectors Tested But Not Viable

  1. Self-referencing webhook to admin API (13_self_referencing_test.py)
  • Webhook sends unsigned POST with event JSON body
  • Admin endpoints require SigV4 auth -- unsigned request rejected
  • "Confused deputy" via self-referencing does NOT work
  1. Protocol smuggling via non-HTTP targets
  • Only 2 target types implemented: webhook and MQTT (event.rs:613 enforces this)
  • No Redis, Kafka, AMQP, or other protocol targets exist
  • CRLF injection in webhook config fields sanitized by reqwest
  • MQTT uses rumqttc (pure Rust binary protocol client), no raw TCP injection
  1. MQTT target for RCE
  • No unsafe code in MQTT handler
  • rumqttc 0.29.0 has no known public CVEs
  • No Command::new, template engines, or deserialization of broker responses
  1. Unauth access
  • Endpoints correctly reject unauthenticated requests (403)
  • Endpoints correctly reject invalid credentials (403)

Prior Art

No existing advisory covers notification target endpoints. 11 published GHSAs on rustfs/rustfs cover different handlers. Closest:

  • CVE-2026-22042 (ImportIam wrong action constant) -- same bug class, different file
  • CVE-2026-22043 (deny_only short-circuit) -- different bug class

Recommendation

Submit via GitHub PVR. The finding is well-supported with live PoC, code references, and clear root cause. The fix is straightforward (add validate_admin_request calls to event.rs handlers). Core submission should reference 2-3 focused PoC scripts (readonly bypass, target hijack, event exfil), not the full set of 13 exploratory scripts.

Koda Reef

Patch

This issue has been patched in version https://github.com/rustfs/rustfs/releases/tag/1.0.0-alpha.94.

Analysis

All four notification target admin API endpoints in rustfs/src/admin/handlers/event.rs use a check_permissions helper that validates authentication only (access key + session token), without performing any admin-action authorization via validate_admin_request. Every other admin handler in the codebase correctly calls validate_admin_request with a specific AdminAction. …

Sign in for full analysis, threat intelligence, and remediation guidance.

Share

CVE-2026-40937 vulnerability details – vuln.today

This site uses cookies essential for authentication and security. No tracking or analytics cookies are used. Privacy Policy