CVE-2026-52811
Gogs: UploadRepoFiles writes outside repo working tree via committed parent sym
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.
| CWE | CWE-22 CWE-59 CWE-61 |
| Vendor | gogs |
| Product | gogs |
| Published | Jun 24, 2026 |
Get instant alerts for gogs gogs
Be the first to know when new unknown vulnerabilities affecting gogs gogs are published โ delivered to Slack, Telegram or Discord.