Loading HuntDB...

GHSA-qcx9-j53g-ccgf

GitHub Security Advisory

Remote Code Execution via unsafe classes in otherwise permitted modules

✓ GitHub Reviewed MODERATE Has CVE

Advisory Details

### Impact
The module `AccessControl` defines security policies for Python code used in restricted code within Zope applications. Restricted code is any code that resides in Zope's object database, such as the contents of `Script (Python)` objects.

The policies defined in `AccessControl` severely restrict access to Python modules and only exempt a few that are deemed safe, such as Python's `string` module. However, full access to the `string` module also allows access to the class `Formatter`, which can be overridden and extended within `Script (Python)` in a way that provides access to other unsafe Python libraries. Those unsafe Python libraries can be used for remote code execution.

By default, you need to have the admin-level Zope "Manager" role to add or edit `Script (Python)` objects through the web. Only sites that allow untrusted users to add/edit these scripts through the web - which would be a very unusual configuration to begin with - are at risk.

### Patches
The problem has been fixed in AccessControl 4.3 and 5.2.
Only AccessControl versions 4 and 5 are vulnerable, and only on Python 3, not Python 2.7.

### Workarounds
A site administrator can restrict adding/editing `Script (Python)` objects through the web using the standard Zope user/role permission mechanisms. Untrusted users should not be assigned the Zope Manager role and adding/editing these scripts through the web should be restricted to trusted users only. This is the default configuration in Zope.

### For more information
If you have any questions or comments about this advisory:
* Open an issue in the [AccessControl issue tracker](https://github.com/zopefoundation/AccessControl/issues)
* Email us at [[email protected]](mailto:[email protected])

Affected Packages

PyPI AccessControl
Affected versions: 4.0 (fixed in 4.3)
PyPI AccessControl
Affected versions: 5.0 (fixed in 5.2)

Related CVEs

Key Information

GHSA ID
GHSA-qcx9-j53g-ccgf
Published
August 5, 2021 5:01 PM
Last Modified
September 3, 2024 9:13 PM
CVSS Score
5.0 /10
Primary Ecosystem
PyPI
Primary Package
AccessControl
GitHub Reviewed
✓ Yes

Dataset

Last updated: July 13, 2025 6:28 AM

Data from GitHub Advisory Database. This information is provided for research and educational purposes.