Home

Description

The Camel-PQC FileBasedKeyLifecycleManager class deserializes the contents of `<keyId>.key` files in the configured key directory using java.io.ObjectInputStream without applying any ObjectInputFilter or class-loading restrictions. The cast to `java.security.KeyPair` is evaluated only after `readObject()` has already returned, so any `readObject()` side effects in the deserialized object run before the type check. An attacker who can write to the key directory used by a Camel application — for example through a path traversal into the directory, misconfigured filesystem permissions on the volume where keys are stored, a compromised key provisioning pipeline, or a symlink attack — can place a crafted serialized Java object that, when deserialized during normal key lifecycle operations, results in arbitrary code execution in the context of the application. This issue affects Apache Camel: from 4.19.0 before 4.20.0, from 4.18.0 before 4.18.2. Users are recommended to upgrade to version 4.20.0, which fixes the issue by replacing java.io.ObjectInputStream-based key and metadata storage with standard PKCS#8 (private key) / X.509 SubjectPublicKeyInfo (public key) Base64 JSON encoding. For users on the 4.18.x LTS releases stream, upgrade to 4.18.2.

PUBLISHED Reserved 2026-04-08 | Published 2026-04-27 | Updated 2026-04-29 | Assigner apache

Problem types

CWE-502 Deserialization of Untrusted Data

Product status

Default status
unaffected

4.19.0 (semver) before 4.20.0
affected

4.18.0 (semver) before 4.18.2
affected

Credits

Andrea Cosentino from ASF finder

Venkatraman Kumar from Securin finder

References

www.openwall.com/lists/oss-security/2026/04/26/6

camel.apache.org/security/CVE-2026-40048.html vendor-advisory

cve.org (CVE-2026-40048)

nvd.nist.gov (CVE-2026-40048)

Download JSON