Vulnerability Details : CVE-2023-24816
Potential exploit
IPython (Interactive Python) is a command shell for interactive computing in multiple programming languages, originally developed for the Python programming language. Versions prior to 8.1.0 are subject to a command injection vulnerability with very specific prerequisites. This vulnerability requires that the function `IPython.utils.terminal.set_term_title` be called on Windows in a Python environment where ctypes is not available. The dependency on `ctypes` in `IPython.utils._process_win32` prevents the vulnerable code from ever being reached in the ipython binary. However, as a library that could be used by another tool `set_term_title` could be called and hence introduce a vulnerability. Should an attacker get untrusted input to an instance of this function they would be able to inject shell commands as current process and limited to the scope of the current process. Users of ipython as a library are advised to upgrade. Users unable to upgrade should ensure that any calls to the `IPython.utils.terminal.set_term_title` function are done with trusted or filtered input.
Products affected by CVE-2023-24816
- cpe:2.3:a:ipython:ipython:*:*:*:*:*:*:*:*
Exploit prediction scoring system (EPSS) score for CVE-2023-24816
0.42%
Probability of exploitation activity in the next 30 days
EPSS Score History
~ 61 %
Percentile, the proportion of vulnerabilities that are scored at or less
CVSS scores for CVE-2023-24816
Base Score | Base Severity | CVSS Vector | Exploitability Score | Impact Score | Score Source | First Seen |
---|---|---|---|---|---|---|
7.0
|
HIGH | CVSS:3.1/AV:L/AC:H/PR:N/UI:R/S:U/C:H/I:H/A:H |
1.0
|
5.9
|
NIST | |
4.5
|
MEDIUM | CVSS:3.1/AV:L/AC:H/PR:N/UI:R/S:U/C:L/I:L/A:L |
1.0
|
3.4
|
GitHub, Inc. |
CWE ids for CVE-2023-24816
-
The product receives input or data, but it does not validate or incorrectly validates that the input has the properties that are required to process the data safely and correctly.Assigned by: security-advisories@github.com (Secondary)
-
The product constructs all or part of an OS command using externally-influenced input from an upstream component, but it does not neutralize or incorrectly neutralizes special elements that could modify the intended OS command when it is sent to a downstream component.Assigned by:
- nvd@nist.gov (Primary)
- security-advisories@github.com (Secondary)
References for CVE-2023-24816
-
https://github.com/ipython/ipython/blob/56e6925dfa50e2c7f4a6471547b8176275db7c25/IPython/utils/_process_win32.py#L20
ipython/_process_win32.py at 56e6925dfa50e2c7f4a6471547b8176275db7c25 · ipython/ipython · GitHubIssue Tracking
-
https://github.com/ipython/ipython/security/advisories/GHSA-29gw-9793-fvw7
set_term_title command injection. · Advisory · ipython/ipython · GitHubExploit;Mitigation;Vendor Advisory
-
https://github.com/ipython/ipython/commit/385d69325319a5972ee9b5983638e3617f21cb1f
Merge pull request from GHSA-29gw-9793-fvw7 · ipython/ipython@385d693 · GitHubPatch
-
https://github.com/ipython/ipython/blob/3f0bf05f072a91b2a3042d23ce250e5e906183fd/IPython/utils/terminal.py#L103-L117
ipython/terminal.py at 3f0bf05f072a91b2a3042d23ce250e5e906183fd · ipython/ipython · GitHubIssue Tracking
Jump to