openexr

Security Policy

Reporting a Vulnerability

If you think you’ve found a potential vulnerability in OpenEXR, please report it by filing a GitHub security advisory. Alternatively, email security@openexr.com and provide your contact info for further private/secure discussion. If your email does not receive a prompt acknowledgement, your address may be blocked.

Our policy is to acknowledge the receipt of vulnerability reports within 48 hours. Our policy is to address critical security vulnerabilities rapidly and post patches within 14 days if possible.

Known Vulnerabilities

These vulnerabilities are present in the given versions:

See the release notes for more information.

Supported Versions

This gives guidance about which branches are supported with patches to security vulnerabilities.

Version / branch Supported
main :white_check_mark: :construction: ALL fixes immediately, but this is a branch under development with a frequently unstable ABI and occasionally unstable API.
3.2.x :white_check_mark: All fixes that can be backported without breaking ABI compatibility.
3.1.x :warning: Only the most critical fixes, only if they can be easily backported.
3.0.x :warning: Only the most critical fixes, only if they can be easily backported.
2.5.x :warning: Only the most critical fixes, only if they can be easily backported.
<= 1.x :x: No longer receiving patches of any kind.

Signed Releases

Releases artifacts are signed via sigstore. See release-sign.yml for details.

To verify a downloaded release at a given tag:

% pip install sigstore
% sigstore verify github --cert-identity https://github.com/AcademySoftwareFoundation/openexr/.github/workflows/release-sign.yml@refs/tags/<tag> openexr-<tag>.tar.gz

Security Expectations

Software Features

Software Dependencies

OpenEXR depends on Imath, a library of basic math operations also maintained and distributed by the OpenEXR project. Imath follows the same security conventions documented here for OpenEXR itself. The core Imath library has no external dependencies. The Imath python bindings depend on python and boost.

The only external library dependency of OpenEXR is libdeflate, which implements standard deflate/zlib/gzip compression and decompression.

The project uses Snyk to scan for dependency vulnerability.

Potential Vulnerabilities

Potential entry points are images being loaded using the library. Malformed images could caused issues such as heap buffer overflows, out-of-memory faults, or segmentation faults that could be exploitable as denial-of-service attacks.

Hardening

Testing

The OpenEXR project implements a comprehensive suite of validation tests, including fuzz testing to harden against malicious input data. Note that fuzz testing hardens only against small input data files and is not a comprehensive test against all potential input.

Note that the exrcheck utility is intended to be used by testers to demonstrate a particular proof-of-concept input file exposes a vulnerability, and it is very helpful to let us know if a vulnerability can be reproduced using that tool.

The project also uses the OSS Fuzz service for continuous fuzz testing.

Development Cycle and Distribution

OpenEXR is downloadable and buildable by C/C++ source via GitHub. Only members of the project’s Technical Steering Committee, all veteran software engineers at major motion picture studios or vendors, have write permissions on the source code repository. All critical software changes are reviewed by multiple TSC members.

The library is distributed in binary form via many common package managers across all platforms.