CVE-2025-27146 Vulnerability Analysis & Exploit Details

CVE-2025-27146
Vulnerability Scoring

2.7
/10
Low Risk

Security experts classify CVE-2025-27146 as a minor vulnerability with limited consequences.

Attack Complexity Details

  • Attack Complexity: Low
    Exploits can be performed without significant complexity or special conditions.
  • Attack Vector: Network
    Vulnerability is exploitable over a network without physical access.
  • Privileges Required: High
    High-level privileges are required for exploitation.
  • Scope: Unchanged
    Exploit remains within the originally vulnerable component.
  • User Interaction: None
    No user interaction is necessary for exploitation.

CVE-2025-27146 Details

Status: Analyzed

Last updated: 🕣 04 Mar 2025, 20:42 UTC
Originally published on: 🕗 25 Feb 2025, 20:15 UTC

Time between publication and last update: 7 days

CVSS Release: version 3

CVSS3 Source

security-advisories@github.com

CVSS3 Type

Secondary

CVSS3 Vector

CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:N/I:L/A:N

CVE-2025-27146 Vulnerability Summary

CVE-2025-27146: matrix-appservice-irc is a Node.js IRC bridge for Matrix. The matrix-appservice-irc bridge up to version 3.0.3 contains a vulnerability which can lead to arbitrary IRC command execution as the puppeted user. The attacker can only inject commands executed as their own IRC user. The vulnerability has been patched in matrix-appservice-irc version 3.0.4.

Assessing the Risk of CVE-2025-27146

Access Complexity Graph

The exploitability of CVE-2025-27146 depends on two key factors: attack complexity (the level of effort required to execute an exploit) and privileges required (the access level an attacker needs).

Exploitability Analysis for CVE-2025-27146

The exploitability of CVE-2025-27146 is influenced by multiple factors. Security teams should analyze system configurations and apply appropriate countermeasures to mitigate threats.

Understanding AC and PR

A lower complexity and fewer privilege requirements make exploitation easier. Security teams should evaluate these aspects to determine the urgency of mitigation strategies, such as patch management and access control policies.

Attack Complexity (AC) measures the difficulty in executing an exploit. A high AC means that specific conditions must be met, making an attack more challenging, while a low AC means the vulnerability can be exploited with minimal effort.

Privileges Required (PR) determine the level of system access necessary for an attack. Vulnerabilities requiring no privileges are more accessible to attackers, whereas high privilege requirements limit exploitation to authorized users with elevated access.

CVSS Score Breakdown Chart

Above is the CVSS Sub-score Breakdown for CVE-2025-27146, illustrating how Base, Impact, and Exploitability factors combine to form the overall severity rating. A higher sub-score typically indicates a more severe or easier-to-exploit vulnerability.

CIA Impact Analysis

Below is the Impact Analysis for CVE-2025-27146, showing how Confidentiality, Integrity, and Availability might be affected if the vulnerability is exploited. Higher values usually signal greater potential damage.

  • Confidentiality: None
    CVE-2025-27146 has no significant impact on data confidentiality.
  • Integrity: Low
    Exploiting CVE-2025-27146 may cause minor changes to data without severely impacting its accuracy.
  • Availability: None
    CVE-2025-27146 does not impact system availability.

Exploit Prediction Scoring System (EPSS)

The EPSS score estimates the probability that this vulnerability will be exploited in the near future.

EPSS Score: 0.044% (probability of exploit)

EPSS Percentile: 15.46% (lower percentile = lower relative risk)
This vulnerability is less risky than approximately 84.53999999999999% of others.

CVE-2025-27146 References

External References

CWE Common Weakness Enumeration

CWE-77

CAPEC Common Attack Pattern Enumeration and Classification

  • LDAP Injection CAPEC-136 An attacker manipulates or crafts an LDAP query for the purpose of undermining the security of the target. Some applications use user input to create LDAP queries that are processed by an LDAP server. For example, a user might provide their username during authentication and the username might be inserted in an LDAP query during the authentication process. An attacker could use this input to inject additional commands into an LDAP query that could disclose sensitive information. For example, entering a * in the aforementioned query might return information about all users on the system. This attack is very similar to an SQL injection attack in that it manipulates a query to gather additional information or coerce a particular return value.
  • Command Delimiters CAPEC-15 An attack of this type exploits a programs' vulnerabilities that allows an attacker's commands to be concatenated onto a legitimate command with the intent of targeting other resources such as the file system or database. The system that uses a filter or denylist input validation, as opposed to allowlist validation is vulnerable to an attacker who predicts delimiters (or combinations of delimiters) not present in the filter or denylist. As with other injection attacks, the attacker uses the command delimiter payload as an entry point to tunnel through the application and activate additional attacks through SQL queries, shell commands, network scanning, and so on.
  • IMAP/SMTP Command Injection CAPEC-183 An adversary exploits weaknesses in input validation on web-mail servers to execute commands on the IMAP/SMTP server. Web-mail servers often sit between the Internet and the IMAP or SMTP mail server. User requests are received by the web-mail servers which then query the back-end mail server for the requested information and return this response to the user. In an IMAP/SMTP command injection attack, mail-server commands are embedded in parts of the request sent to the web-mail server. If the web-mail server fails to adequately sanitize these requests, these commands are then sent to the back-end mail server when it is queried by the web-mail server, where the commands are then executed. This attack can be especially dangerous since administrators may assume that the back-end server is protected against direct Internet access and therefore may not secure it adequately against the execution of malicious commands.
  • Command Injection CAPEC-248 An adversary looking to execute a command of their choosing, injects new items into an existing command thus modifying interpretation away from what was intended. Commands in this context are often standalone strings that are interpreted by a downstream component and cause specific responses. This type of attack is possible when untrusted values are used to build these command strings. Weaknesses in input validation or command construction can enable the attack and lead to successful exploitation.
  • Manipulating Writeable Terminal Devices CAPEC-40 This attack exploits terminal devices that allow themselves to be written to by other users. The attacker sends command strings to the target terminal device hoping that the target user will hit enter and thereby execute the malicious command with their privileges. The attacker can send the results (such as copying /etc/passwd) to a known directory and collect once the attack has succeeded.
  • Exploiting Multiple Input Interpretation Layers CAPEC-43 An attacker supplies the target software with input data that contains sequences of special characters designed to bypass input validation logic. This exploit relies on the target making multiples passes over the input data and processing a "layer" of special characters with each pass. In this manner, the attacker can disguise input that would otherwise be rejected as invalid by concealing it with layers of special/escape characters that are stripped off by subsequent processing steps. The goal is to first discover cases where the input validation layer executes before one or more parsing layers. That is, user input may go through the following logic in an application: <parser1> --> <input validator> --> <parser2>. In such cases, the attacker will need to provide input that will pass through the input validator, but after passing through parser2, will be converted into something that the input validator was supposed to stop.
  • Manipulating Writeable Configuration Files CAPEC-75 Generally these are manually edited files that are not in the preview of the system administrators, any ability on the attackers' behalf to modify these files, for example in a CVS repository, gives unauthorized access directly to the application, the same as authorized users.
  • Manipulating Web Input to File System Calls CAPEC-76 An attacker manipulates inputs to the target software which the target software passes to file system calls in the OS. The goal is to gain access to, and perhaps modify, areas of the file system that the target software did not intend to be accessible.

Vulnerable Configurations

  • cpe:2.3:a:matrix:matrix_irc_bridge:0.1.1:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.1.1:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.3.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.3.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.3.1:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.3.1:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.4.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.4.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.5.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.5.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.6.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.6.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.7.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.7.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.7.1:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.7.1:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.7.2:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.7.2:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.8.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.8.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.10.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.10.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.10.1:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.10.1:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.11.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.11.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.11.1:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.11.1:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.11.2:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.11.2:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.12.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.12.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.13.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.13.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.13.1:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.13.1:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.14.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.14.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.14.1:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.14.1:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.15.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.15.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.15.1:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.15.1:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.15.2:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.15.2:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.16.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.16.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.17.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.17.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.17.1:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.17.1:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.18.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.18.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.19.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.19.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.20.1:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.20.1:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.20.2:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.20.2:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.20.3:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.20.3:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.21.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.21.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.22.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.22.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.23.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.23.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.24.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.24.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.25.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.25.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.26.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.26.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.26.1:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.26.1:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.27.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.27.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.29.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.29.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.30.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.30.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.31.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.31.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.32.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.32.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.32.1:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.32.1:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.33.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.33.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.33.1:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.33.1:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.34.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.34.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.35.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.35.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.35.1:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.35.1:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.36.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.36.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.37.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.37.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.37.1:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.37.1:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:0.38.0:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:0.38.0:*:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:1.0.0:-:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:1.0.0:-:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:1.0.0:rc1:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:1.0.0:rc1:*:*:*:node.js:*:*
  • cpe:2.3:a:matrix:matrix_irc_bridge:1.0.1:*:*:*:*:node.js:*:*
    cpe:2.3:a:matrix:matrix_irc_bridge:1.0.1:*:*:*:*:node.js:*:*

Protect Your Infrastructure against CVE-2025-27146: Combat Critical CVE Threats

Stay updated with real-time CVE vulnerabilities and take action to secure your systems. Enhance your cybersecurity posture with the latest threat intelligence and mitigation techniques. Develop the skills necessary to defend against CVEs and secure critical infrastructures. Join the top cybersecurity professionals safeguarding today's infrastructures.

Other 5 Recently Published CVEs Vulnerabilities

  • CVE-2025-12221 – Busybox 1.31.1 - Multiple Known Vulnerabilities.This issue affects BLU-IC2: through 1.19.5; BLU-IC4: through 1.19.5.
  • CVE-2025-12220 – Busybox 1.31.1 - Multiple Known Vulnerabilities.This issue affects BLU-IC2: through 1.19.5; BLU-IC4: through 1.19.5.
  • CVE-2025-12219 – Vulnerable Components in Azure Access OS.This issue affects BLU-IC2: through 1.19.5; BLU-IC4: through 1.19.5.
  • CVE-2025-12218 – Weak Default Credentials.This issue affects BLU-IC2: through 1.19.5; BLU-IC4: through 1.19.5.
  • CVE-2025-12217 – SNMP Default Community String (public).This issue affects BLU-IC2: through 1.19.5; BLU-IC4: through 1.19.5.