Impact
All unpatched versions of Argo CD starting with v1.5.0 are vulnerable to a path traversal vulnerability allowing a malicious user with read/write access to leak sensitive files from Argo CD’s repo-server.
A malicious Argo CD user who has been granted create
or update
access to Applications can leak the contents of any text file on the repo-server. By crafting a malicious Helm chart and using it in an Application, the attacker can retrieve the sensitive file’s contents either as part of the generated manifests or in an error message. The attacker would have to know or guess the location of the target file.
Sensitive files which could be leaked include files from other Application’s source repositories (potentially decrypted files, if you are using a decryption plugin) or any secrets which have been mounted as files on the repo-server.
Patches
A patch for this vulnerability has been released in the following Argo CD versions:
- v2.3.0
- v2.2.6
- v2.1.11
Workarounds
The only certain way to avoid the vulnerability is to upgrade.
To mitigate the problem, you can
- avoid storing secrets in git
- avoid mounting secrets as files on the repo-server
- avoid decrypting secrets into files on the repo-server
- carefully limit who can
create
orupdate
Applications
References
For more information
Open an issue in the Argo CD issue tracker or discussions
Join us on Slack in channel #argo-cd