Get a Demo

Let's Patch It!

Book a short call with one our specialists, we'll walk you through how Endor Patches work, and ask you a few questions about your environment (like your primary programming languages and repository management). We'll also send you an email right after you fill out the form, feel free to reply with any questions you have in advance!

CVE

CVE-2026-41491

Dapr: Service Invocation path traversal ACL bypass
Back to all
CVE

CVE-2026-41491

Dapr: Service Invocation path traversal ACL bypass

Summary

A vulnerability has been found in Dapr that allows bypassing access control policies for service invocation using reserved URL characters and path traversal sequences in method paths. The ACL normalized the method path independently from the dispatch layer, so the ACL evaluated one path while the target application received a different one.

Users who have configured access control policies for service invocation are strongly encouraged to upgrade Dapr to the respective patch version 1.17.51.16.14, and 1.15.14.

Impact

This vulnerability impacts Dapr users who have configured access control policies for service invocation. An attacker who can reach the Dapr HTTP or gRPC API could:

  • Use encoded path traversal (ex: admin%2F..%2Fpublic) to reach an allowed path while the method started from a denied prefix.
  • Use encoded fragment (%23) or query (%3F) characters to cause the ACL to evaluate a different path than what was delivered to the target application.

Patches

Users should upgrade immediately to their respective Dapr version 1.17.51.16.14, and 1.15.14.

Details

Dapr supports access control policies for service invocation, which allow operators to restrict which methods an application is permitted to call on a target app. When a request arrives, Dapr evaluates the method path against the configured policy before dispatching to the target.

Prior to this fix, the ACL and the dispatch layer normalized the method path independently. The ACL used purell.NormalizeURLString, which decoded %XX sequences, resolved ../, and stripped # and ? as URL delimiters. The dispatch layer used the raw method string. This mismatch meant the ACL authorized one path while the target application received a different one.

For example, a method of admin%2F..%2Fpublic was normalized by the ACL to public (allowed), but the target application received admin/../public

The gRPC API was the more dangerous vector because gRPC passes method strings raw — #?../, and control characters were all delivered literally with no client-side sanitization.

References

This PR signaled to us about the CVE, special thanks to @dbconfession78 for the efforts here and the original PR.

Package Versions Affected

Package Version
patch Availability
No items found.

Automatically patch vulnerabilities without upgrading

Fix Without Upgrading
Detect compatible fix
Apply safe remediation
Fix with a single pull request

CVSS Version

Severity
Base Score
CVSS Version
Score Vector
C
H
U
8.1
-
3.1
CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:N
C
H
U
0
-
3.1
CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:N
C
H
U
8.1
-
3.1
CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:N

Related Resources

No items found.

References

https://github.com/dapr/dapr/security/advisories/GHSA-85gx-3qv6-4463, https://nvd.nist.gov/vuln/detail/CVE-2026-41491, https://github.com/dapr/dapr/pull/9589, https://github.com/dapr/dapr

Severity

8.1

CVSS Score
0
10

Basic Information

Ecosystem
Base CVSS
8.1
EPSS Probability
0.00041%
EPSS Percentile
0.12754%
Introduced Version
1.17.0-rc.1,v1.17.0-rc.1,v1.16.0-rc.1,v1.15.0-rc.2,v0.0.0-20241216170643-f0f6a0369437,v1.14.0-rc.1,v0.0.0-20240227215810-2e298ef30db3,v1.13.0-rc.1,v0.0.0-20240112173042-472c287fa3c2,v1.12.0-rc.1,v0.0.0-20230801005239-e63333b8e7af,v0.0.0-20230627032239-bac6ae6d505f,v1.10.0-rc.1,v0.0.0-20221215005946-7190a7329e86,v1.3.0-rc.1,v0.0.0-20210613201634-5a6c585ce5d9,0
Fix Available
1.17.5,v1.17.5,v1.16.14,v1.15.14,v0.0.0-20260416144315-3974797d4325,1.15.14-r0

Fix Critical Vulnerabilities Instantly

Secure your app without upgrading.
Fix Without Upgrading