CVE-2026-49260

HIGH

CVSS v3.1: 8.2

No user interactionOS Command InjectionVendor advisory ref

Source data as of:

At a glance

Severity
HIGH
CVSS
8.2 v3.1 · NVD
EPSS
EPSS not provided by FIRST.org for this CVE
CISA KEV
No
Type
OS Command Injection · NVD CWE
Attack conditions (CVSS vector)
No user interaction · Source: NVD Vector
Published
2026-06-19 · Modified: 2026-06-19

CVSS / EPSS / KEV

CVSS v3.1 8.2 / 10 HIGH Source: NVD
EPSS EPSS not provided by FIRST.org for this CVE Source: FIRST.org
CISA KEV No Source: CISA

Source — CVSS: NVD · EPSS: FIRST.org · KEV: CISA. Data & Sources

Description

PhpWeasyPrint is a PHP library allowing PDF generation from a URL or an HTML page. Prior to version 2.5.1, `pontedilana/php-weasyprint` builds the shell command for WeasyPrint by passing the binary path through `escapeshellarg()` first and then checking the *quoted* result with `is_executable()`. On POSIX `escapeshellarg('/usr/local/bin/weasyprint')` returns `'/usr/local/bin/weasyprint'` with the single-quote characters as part of the string, so `is_executable()` looks for a file whose actual name includes those quotes. That file never exists, the "safe" branch is dead code, and the raw `$binary` string (set via the constructor or `setBinary()`) flows directly into `Symfony\Component\Process\Process::fromShellCommandline()`. Any deployment whose binary path is sourced from configuration, an environment variable, or a per-tenant setting reaches a shell-command-injection sink. The library is documented as a one-to-one substitute for KnpLabs/snappy and inherited the exact pre-fix codepath KnpLabs patched in GHSA-vpr4-p6fq-85jc. PhpWeasyPrint version 2.5.1 contains a patch for the issue.

Record details

CVE ID
CVE-2026-49260
CVSS (v3.1)
8.2 (HIGH)
Vector
CVSS:3.1/AV:L/AC:L/PR:H/UI:N/S:C/C:H/I:H/A:H
Exploitability subscore
1.5
Impact subscore
6.0
CISA KEV
No
Weakness (CWE)
CWE-78
Affected configurations (CPE)
0
Published
2026-06-19
Modified
2026-06-19
Status
Received

References

Reference URLs as listed by NVD, grouped by a mechanical match on the link's host/pattern. Labels describe the link type only.