CVE-2026-52811

Gogs is an open source self-hosted Git service. Prior to 0.14.3, (*Repository).UploadRepoFiles checks for symlinks only on the leaf of the upload target (osx.IsSymlink(targetPath)). The siblings UpdateRepoFile, DeleteRepoFile, and GetDiffPreview use hasSymlinkInPath, which lstats every component — UploadRepoFiles is the lone outlier. An attacker with repo-write access plus a multipart upload whose filename contains a literal backslash (preserved by filepath.Base on Linux, then converted to / by pathx.Clean) redirects the write through a previously-committed directory symlink. iox.CopyFile opens the destination with os.Create (no O_NOFOLLOW), so the kernel follows the parent symlink and writes attacker bytes anywhere the gogs UID can write — ~git/.ssh/authorized_keys → SSH foothold, or <repo>.git/hooks/post-receive → next-push RCE. This vulnerability is fixed in 0.14.3.
CVSS

No CVSS.

Configurations

No configuration.

History

25 Jun 2026, 21:16

Type Values Removed Values Added
References () https://github.com/gogs/gogs/security/advisories/GHSA-89mr-xqfv-758m - () https://github.com/gogs/gogs/security/advisories/GHSA-89mr-xqfv-758m -

24 Jun 2026, 21:16

Type Values Removed Values Added
New CVE

Information

Published : 2026-06-24 21:16

Updated : 2026-06-26 05:16


NVD link : CVE-2026-52811

Mitre link : CVE-2026-52811

CVE.ORG link : CVE-2026-52811


JSON object : View

Products Affected

No product.

CWE
CWE-22

Improper Limitation of a Pathname to a Restricted Directory ('Path Traversal')

CWE-59

Improper Link Resolution Before File Access ('Link Following')

CWE-61

UNIX Symbolic Link (Symlink) Following