๐Ÿ” CVE Alert

CVE-2026-31886

CRITICAL 9.1

Dagu has a Path Traversal via `dagRunId` in Inline DAG Execution

CVSS Score
9.1
EPSS Score
0.0%
EPSS Percentile
0th

Dagu is a workflow engine with a built-in Web user interface. Prior to 2.2.4, the dagRunId request field accepted by the inline DAG execution endpoints is passed directly into filepath.Join to construct a temporary directory path without any format validation. Go's filepath.Join resolves .. segments lexically, so a caller can supply a value such as ".." to redirect the computed directory outside the intended /tmp/<name>/<id> path. A deferred cleanup function that calls os.RemoveAll on that directory then runs unconditionally when the HTTP handler returns, deleting whatever directory the traversal resolved to. With dagRunId set to "..", the resolved directory is the system temporary directory (/tmp on Linux). On non-root deployments, os.RemoveAll("/tmp") removes all files in /tmp owned by the dagu process user, disrupting every concurrent dagu run that has live temp files. On root or Docker deployments, the call removes the entire contents of /tmp, causing a system-wide denial of service. This vulnerability is fixed in 2.2.4.

CWE CWE-22
Vendor dagu-org
Product dagu
Published Mar 13, 2026
Last Updated Mar 13, 2026
Stay Ahead of the Next One

Get instant alerts for dagu-org dagu

Be the first to know when new critical vulnerabilities affecting dagu-org dagu are published โ€” delivered to Slack, Telegram or Discord.

Get Free Alerts โ†’ Free ยท No credit card ยท 60 sec setup

CVSS v3 Breakdown

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

Affected Versions

dagu-org / dagu
< 2.2.4

References

NVD โ†— CVE.org โ†— EPSS Data โ†—
github.com: https://github.com/dagu-org/dagu/security/advisories/GHSA-m4q3-457p-hh2x github.com: https://github.com/dagu-org/dagu/commit/12c2e5395bd9331d49ca103593edfd0db39c4f38