Orval MCP client is vulnerable to code injection via unsanitized x-enum-descriptions in enum generation
Description
Orval generates type-safe JS clients (TypeScript) from any valid OpenAPI v3 or Swagger v2 specification. Versions prior to 7.19.0 until 8.0.2 are vulnerable to arbitrary code execution in environments consuming generated clients. This issue is similar in nature to CVE-2026-22785, but affects a different code path in @orval/core that was not addressed by CVE-2026-22785's fix. The vulnerability allows untrusted OpenAPI specifications to inject arbitrary TypeScript/JavaScript code into generated clients via the x-enumDescriptions field, which is embedded without proper escaping in getEnumImplementation(). I have confirmed that the injection occurs during const enum generation and results in executable code within the generated schema files. Orval 7.19.0 and 8.0.2 contain a fix for the issue.
Affected packages
Versions sourced from the GitHub Security Advisory.
| Package | Affected versions | Patched versions |
|---|---|---|
@orval/corenpm | >= 8.0.0-rc.0, < 8.0.2 | 8.0.2 |
@orval/corenpm | < 7.19.0 | 7.19.0 |
Affected products
1- Range: v2.0.0, v2.0.1, v2.0.2, …
Patches
19e5d93533904fix(enum): x-enum values must be JS escaped (#2796)
1 file changed · +18 −10
packages/core/src/getters/enum.ts+18 −10 modified@@ -5,23 +5,31 @@ import { NamingConvention, type OpenApiSchemaObject, } from '../types'; -import { conventionName, isNumeric, sanitize } from '../utils'; +import { conventionName, isNumeric, jsStringEscape, sanitize } from '../utils'; export function getEnumNames(schemaObject: OpenApiSchemaObject | undefined) { - return ( - schemaObject?.['x-enumNames'] || - schemaObject?.['x-enumnames'] || - schemaObject?.['x-enum-varnames'] - ); + const names = + schemaObject?.['x-enumNames'] ?? + schemaObject?.['x-enumnames'] ?? + schemaObject?.['x-enum-varnames']; + + if (!names) return; + + return (names as string[]).map((name: string) => jsStringEscape(name)); } export function getEnumDescriptions( schemaObject: OpenApiSchemaObject | undefined, ) { - return ( - schemaObject?.['x-enumDescriptions'] || - schemaObject?.['x-enumdescriptions'] || - schemaObject?.['x-enum-descriptions'] + const descriptions = + schemaObject?.['x-enumDescriptions'] ?? + schemaObject?.['x-enumdescriptions'] ?? + schemaObject?.['x-enum-descriptions']; + + if (!descriptions) return; + + return (descriptions as string[]).map((description: string) => + jsStringEscape(description), ); }
Vulnerability mechanics
Generated by null/stub on May 9, 2026. Inputs: CWE entries + fix-commit diffs from this CVE's patches. Citations validated against bundle.
References
6- github.com/advisories/GHSA-h526-wf6g-67jvghsaADVISORY
- nvd.nist.gov/vuln/detail/CVE-2026-23947ghsaADVISORY
- github.com/orval-labs/orval/commit/9e5d93533904936678ba93b5d20f6bca176a4e1eghsaWEB
- github.com/orval-labs/orval/releases/tag/v7.19.0ghsaWEB
- github.com/orval-labs/orval/releases/tag/v8.0.2ghsax_refsource_MISCWEB
- github.com/orval-labs/orval/security/advisories/GHSA-h526-wf6g-67jvghsax_refsource_CONFIRMWEB
News mentions
0No linked articles in our index yet.