CVE-2026-44881

CRITICAL

Portainer: Arbitrary File Read via Git Symlink Injection in Stack Auto-Update

Title source: cna
STIX 2.1

Exploitation Summary

EIP tracks 1 public exploit for CVE-2026-44881. PoCs published by 0xdak.

AI-analyzed exploit summary This repository contains a functional exploit for CVE-2026-44881, a Git symlink injection vulnerability in Portainer that allows arbitrary file reads on the host system. The exploit chains credential recovery from a leaked .git directory, authentication, and a malicious Git repository to read sensitive files like /root/.ssh/id_rsa.

Description

Portainer Community Edition is a lightweight service delivery platform for containerized applications that can be used to manage Docker, Swarm, Kubernetes and ACI environments. From 2.33.0 to before 2.33.8, 2.39.2, and 2.41.0, Portainer supports deploying stacks from Git repositories. When a Git-backed stack is created or updated, Portainer clones the repository using go-git v5, which translates Git blob entries with mode 0o120000 (symlink) into real OS symlinks on the host filesystem via os.Symlink. The only entry blocked from becoming a symlink is .gitmodules; every other path is created as a symlink without validation. Portainer's GET /api/stacks/{id}/file endpoint then reads the stack entry point with os.ReadFile, which follows OS symlinks transparently. A repository containing docker-compose.yml as a symlink to an arbitrary filesystem path causes the symlink target's contents to be returned verbatim in the HTTP response. Any authenticated user with rights to create or update a Git-backed stack — the default configuration in Portainer CE — can read arbitrary files accessible to the Portainer process. This vulnerability is fixed in 2.33.8, 2.39.2, and 2.41.0.

Exploits (1)

github WORKING POC
by 0xdak · shellpoc
https://github.com/0xdak/CVE-2026-44881_exploit

This repository contains a functional exploit for CVE-2026-44881, a Git symlink injection vulnerability in Portainer that allows arbitrary file reads on the host system. The exploit chains credential recovery from a leaked .git directory, authentication, and a malicious Git repository to read sensitive files like /root/.ssh/id_rsa.

Classification
Working Poc 100%
Attack Type
Info Leak
Complexity
Moderate
Reliability
Reliable
Target: Portainer CE 2.33.0–2.33.7, 2.39.0–2.39.1, 2.40.x
Auth required
Prerequisites: leaked .git directory accessible on the target · low-privilege Portainer credentials or ability to recover them from .git · network access to the target's Portainer instance
devstral-2 · analyzed Jun 16, 2026 Full analysis →

References (1)

Core 1
Core References

Scores

CVSS v3 9.9
EPSS 0.0037
EPSS Percentile 28.2%
Attack Vector NETWORK
CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:C/C:H/I:H/A:H

CISA SSVC

Vulnrichment
Exploitation none
Automatable no
Technical Impact partial

Details

CWE
CWE-200 CWE-59
Status published
Products (8)
portainer/portainer 2.40.0
portainer/portainer 2.33.0 - 2.33.8
portainer/portainer 2.33.0 - 2.33.8Go
portainer/portainer 2.39.0 - 2.39.2Go
portainer/portainer 2.40.0 - 2.41.0Go
portainer/portainer >= 2.33.0, < 2.33.8
portainer/portainer >= 2.39.0, < 2.39.2
portainer/portainer >= 2.40.0, < 2.41.0
Published May 28, 2026
Tracked Since May 29, 2026