Home

Description

Tina is a headless content management system. Prior to version 2.2.2, @tinacms/graphql uses string-based path containment checks in FilesystemBridge. That blocks plain ../ traversal, but it does not resolve symlink or junction targets. If a symlink/junction already exists under the allowed content root, a path like content/posts/pivot/owned.md is still considered "inside" the base even though the real filesystem target can be outside it. As a result, FilesystemBridge.get(), put(), delete(), and glob() can operate on files outside the intended root. This issue has been patched in version 2.2.2.

PUBLISHED Reserved 2026-03-30 | Published 2026-04-01 | Updated 2026-04-01 | Assigner GitHub_M




HIGH: 7.1CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:U/C:H/I:H/A:L

Problem types

CWE-22: Improper Limitation of a Pathname to a Restricted Directory ('Path Traversal')

CWE-59: Improper Link Resolution Before File Access ('Link Following')

Product status

< 2.2.2
affected

References

github.com/...inacms/security/advisories/GHSA-g9c2-gf25-3x67 exploit

github.com/...inacms/security/advisories/GHSA-g9c2-gf25-3x67

github.com/...ommit/f124eabaca10dac9a4d765c9e4135813c4830955

cve.org (CVE-2026-34604)

nvd.nist.gov (CVE-2026-34604)

Download JSON