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-29186

TechDocs Mkdocs Configuration Key Enables Arbitrary Code Execution
Back to all
CVE

CVE-2026-29186

TechDocs Mkdocs Configuration Key Enables Arbitrary Code Execution

Impact

This is a configuration bypass vulnerability that enables arbitrary code execution. The @backstage/plugin-techdocs-node package uses an allowlist to filter dangerous MkDocs configuration keys during the documentation build process. 

A gap in this allowlist allows attackers to craft an mkdocs.yml that causes arbitrary Python code execution, completely bypassing TechDocs' security controls.     

Patches

Patched in @backstage/plugin-techdocs-node version 1.14.3

Workarounds

If users cannot upgrade immediately:

  1. Use Docker mode with restricted access: Configure TechDocs with runIn: docker instead of runIn: local. This provides container isolation, though it does not fully mitigate the risk.
  2. Restrict repository access: Limit who can modify mkdocs.yml files in repositories that TechDocs processes. Only allow trusted contributors.
  3. Manual review: Implement PR review requirements for changes to mkdocs.yml files to detect malicious hooks configurations before they are merged.
  4. Downgrade MkDocs: Use MkDocs < 1.4.0 (e.g., 1.3.1) which does not support hooks. Note: This may limit access to newer MkDocs features.

Note: Building documentation in CI/CD pipelines using @techdocs/cli does not mitigate this vulnerability, as the CLI uses the same vulnerable @backstage/plugin-techdocs-node package.

Resources

MkDocs Hooks Documentation

MkDocs 1.4 Release Notes

TechDocs Architecture

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
7.7
-
3.1
CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:C/C:H/I:L/A:L
C
H
U
0
-
3.1
CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:C/C:H/I:L/A:L
C
H
U
7.7
-
3.1
CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:C/C:H/I:L/A:L

Related Resources

No items found.

References

https://github.com/backstage/backstage/security/advisories/GHSA-928r-fm4v-mvrw, https://nvd.nist.gov/vuln/detail/CVE-2026-29186, https://backstage.io/docs/features/techdocs/architecture, https://github.com/backstage/backstage, https://www.mkdocs.org/about/release-notes/#version-14-2022-09-27, https://www.mkdocs.org/user-guide/configuration/#hooks

Severity

7.7

CVSS Score
0
10

Basic Information

Ecosystem
Base CVSS
7.7
EPSS Probability
0.00038%
EPSS Percentile
0.11478%
Introduced Version
0,1.14.1,0.0.0-nightly-20260131030451
Fix Available
1.14.3,1.14.3-next.1,0.0.0-nightly-20260304030634

Fix Critical Vulnerabilities Instantly

Secure your app without upgrading.
Fix Without Upgrading