First published: Thu Nov 04 2021(Updated: )
Jenkins 2.318 and earlier, LTS 2.303.2 and earlier does not limit agent read/write access to the `libs/` directory inside build directories when using the `FilePath` APIs. This directory is used by the Pipeline: Shared Groovy Libraries Plugin to store copies of shared libraries. This allows attackers in control of agent processes to replace the code of a trusted library with a modified variant, resulting in unsandboxed code execution in the Jenkins controller process. Jenkins 2.319, LTS 2.303.3 prohibits agent read/write access to the `libs/` directory inside build directories. If you are unable to immediately upgrade to Jenkins 2.319, LTS 2.303.3, you can install the [Remoting Security Workaround Plugin](https://www.jenkins.io/redirect/remoting-security-workaround/). It will prevent all agent-to-controller file access using FilePath APIs. Because it is more restrictive than Jenkins 2.319, LTS 2.303.3, more plugins are incompatible with it. Make sure to read the plugin documentation before installing it. It is not easily possible to [customize the file access rules](https://www.jenkins.io/doc/book/security/controller-isolation/agent-to-controller/#file-access-rules) to prohibit access to the `libs/` directory specifically, as built-in rules (granting access to `<BUILDDIR>` contents) would take precedence over a custom rule prohibiting access.
Credit: jenkinsci-cert@googlegroups.com jenkinsci-cert@googlegroups.com jenkinsci-cert@googlegroups.com
Affected Software | Affected Version | How to fix |
---|---|---|
Jenkins Jenkins | <=2.303.2 | |
Jenkins Jenkins | <=2.318 | |
redhat/jenkins | <2.319 | 2.319 |
redhat/jenkins LTS | <2.303.3 | 2.303.3 |
maven/org.jenkins-ci.main:jenkins-core | <=2.303.2 | 2.303.3 |
maven/org.jenkins-ci.main:jenkins-core | >=2.304<=2.318 | 2.319 |
Sign up to SecAlerts for real-time vulnerability data matched to your software, aggregated from hundreds of sources.
CVE-2021-21696 is a vulnerability in Jenkins 2.318 and earlier, LTS 2.303.2 and earlier that allows attackers to replace trusted library code with a modified variant.
CVE-2021-21696 has a severity score of 9.8, which is classified as critical.
Jenkins versions 2.318 and earlier, LTS 2.303.2 and earlier are affected by CVE-2021-21696.
To fix CVE-2021-21696, upgrade to Jenkins version 2.319 or Jenkins LTS version 2.303.3.
You can find more information about CVE-2021-21696 on the following references: - [Openwall](http://www.openwall.com/lists/oss-security/2021/11/04/3) - [Jenkins Security Advisory](https://www.jenkins.io/security/advisory/2021-11-04/#SECURITY-2423) - [Red Hat Security Advisory](https://access.redhat.com/errata/RHSA-2021:4833)