CVE-2022-35411
CRITICAL9.8EPSS 71.3%rpc.py vulnerable to Deserialization of Untrusted Data
Description
rpc.py through 0.6.0 allows Remote Code Execution because an unpickle occurs when the "serializer: pickle" HTTP header is sent. In other words, although JSON (not Pickle) is the default data format, an unauthenticated client can cause the data to be processed with unpickle. [Per the maintainer](https://github.com/abersheeran/rpc.py/issues/22), rpc.py is not designed for an API that is open to the outside world, and external requests cannot reach rpc.py in real world use. A [fix](https://github.com/abersheeran/rpc.py/commit/491e7a841ed9a754796d6ab047a9fb16e23bf8bd) exists on the `master` branch. As a workaround, use the following code to turn off pickle in older versions: ``` del SERIALIZER_NAMES[PickleSerializer.name] del SERIALIZER_TYPES[PickleSerializer.content_type]
Affected packages (1)
- PyPI/rpc-py>= 0.4.2, <= 0.6.0
CVSS scores
| Source | Version | Severity | Vector |
|---|---|---|---|
| osv | CVSS 3.1 | CRITICAL9.8 | CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H |
References (8)
- ADVISORYhttps://nvd.nist.gov/vuln/detail/CVE-2022-35411
- PATCHhttps://github.com/abersheeran/rpc.py
- WEBhttp://packetstormsecurity.com/files/167872/rpc.py-0.6.0-Remote-Code-Execution.html
- WEBhttps://github.com/abersheeran/rpc.py/commit/491e7a841ed9a754796d6ab047a9fb16e23bf8bd
- WEBhttps://github.com/abersheeran/rpc.py/issues/22
- WEBhttps://github.com/ehtec/rpcpy-exploit
- WEBhttps://medium.com/%40elias.hohl/remote-code-execution-0-day-in-rpc-py-709c76690c30
- WEBhttps://medium.com/@elias.hohl/remote-code-execution-0-day-in-rpc-py-709c76690c30