CVEReports
CVEReports

Automated vulnerability intelligence platform. Comprehensive reports for high-severity CVEs generated by AI.

Product

  • Home
  • Sitemap
  • RSS Feed

Company

  • About
  • Contact
  • Privacy Policy
  • Terms of Service

© 2026 CVEReports. All rights reserved.

Made with love by Amit Schendel & Alon Barad



GHSA-JWF4-8WF4-JF2M

GHSA-JWF4-8WF4-JF2M: Critical Authorization Bypass in OpenClaw BlueBubbles Plugin

Alon Barad
Alon Barad
Software Engineer

Mar 4, 2026·5 min read·19 visits

Executive Summary (TL;DR)

The OpenClaw BlueBubbles plugin fails to enforce access controls when the allowed sender list is empty. Due to a 'fail-open' logic error in the underlying SDK, unconfigured instances accept DMs from any source, granting full interaction with the AI assistant.

A critical access control vulnerability exists in the OpenClaw BlueBubbles plugin due to a logic error in the shared authorization utility. The flaw causes the system to fail-open when the allowlist configuration is empty, permitting unauthorized remote users to bypass Direct Message (DM) gating policies. This allows arbitrary unauthenticated users to interact with the AI assistant, potentially triggering sensitive actions or accessing private data.

Vulnerability Overview

The vulnerability resides in the plugin-sdk component of OpenClaw, specifically within the authorization logic used by the BlueBubbles optional channel extension. OpenClaw is a personal AI assistant infrastructure that aggregates communications from various platforms. The BlueBubbles plugin integrates iMessage and SMS capabilities, allowing the assistant to process and respond to messages.

The core issue is an Incorrect Authorization (CWE-863) flaw where the system defaults to an authorized state when no access policies are defined. In a secure configuration, an empty allowlist should result in all traffic being denied until explicitly permitted. However, the vulnerable implementation treated an empty list as a directive to allow all traffic, bypassing the intended pairing or allowlist security modes.

This flaw is particularly critical because pairing is often the default secure mode for new installations. Administrators expecting a 'deny-by-default' posture until devices are paired are instead left exposed to a 'permit-all' state, allowing any actor capable of routing a message to the BlueBubbles instance to interact with the AI agent.

Root Cause Analysis

The root cause is a logic error in the isAllowedParsedChatSender utility function located in src/plugin-sdk/allow-from.ts. This function is responsible for validating whether an incoming message sender is authorized based on the user's configuration.

The function accepts a list of allowed senders (allowFrom). The logic was intended to support a wildcard (*) for public access, but the implementation checked the length of the array to determine the default behavior. Specifically, the code contained a conditional check: if (allowFrom.length === 0). If this condition was met—meaning the user had not yet added any trusted contacts—the function returned true.

This effectively inverted the security model. Instead of failing closed (denying access when no rules exist), the system failed open. The BlueBubbles plugin relies on this boolean return value to gate access to the processMessage and processReaction workflows. Consequently, an uninitialized configuration resulted in the complete bypass of authentication checks.

Code Analysis

The following analysis compares the vulnerable code path with the patched version in src/plugin-sdk/allow-from.ts. The fix involves inverting the return value for empty lists and requiring an explicit wildcard for open access.

Vulnerable Implementation:

export function isAllowedParsedChatSender(params: AllowedParsedChatSenderParams) {
  const allowFrom = params.allowFrom.map((entry) => String(entry).trim());
 
  // VULNERABILITY: If the list is empty, return TRUE (Allow all)
  if (allowFrom.length === 0) {
    return true;
  }
 
  // ... checks for specific sender ID ...
}

Patched Implementation (Commit 9632b9b):

export function isAllowedParsedChatSender(params: AllowedParsedChatSenderParams) {
  const allowFrom = params.allowFrom.map((entry) => String(entry).trim());
 
  // FIX: Fail-closed. If the list is empty, return FALSE (Deny all)
  if (allowFrom.length === 0) {
    return false;
  }
 
  // Explicitly require wildcard for allow-all behavior
  if (allowFrom.includes("*")) {
    return true;
  }
 
  // ... checks for specific sender ID ...
}

The patch ensures that an empty configuration results in a secure state. Additionally, logic was unified in resolveDmGroupAccessDecision to prevent similar drift in reaction processing.

Exploitation Methodology

Exploiting this vulnerability requires no specialized tools or authentication. The attacker simply needs to identify a target OpenClaw instance running the BlueBubbles plugin that has not yet been configured with specific trusted peers.

  1. Reconnaissance: The attacker identifies the target's contact handle (e.g., phone number or email associated with the BlueBubbles/iMessage account).
  2. Interaction: The attacker sends a standard text message or iMessage to the target. The message content typically includes a command understood by the AI, such as "What is my schedule?" or "Turn on the lights."
  3. Bypass Execution:
    • The OpenClaw instance receives the message.
    • The BlueBubbles plugin calls isAllowedParsedChatSender.
    • Due to the unconfigured allowFrom list, the function returns true.
  4. Action: The AI processes the message as if it came from a trusted administrator, executing the command and replying with the output.

The vulnerability also extends to reactions (Tapbacks), allowing an attacker to trigger event-driven workflows simply by reacting to a message history.

Impact Assessment

The impact of this vulnerability is critical due to the capabilities typically granted to personal AI assistants.

  • Confidentiality Loss: Unauthorized users can query the assistant for sensitive data stored in its memory (Vector DB) or accessible via connected APIs (e.g., calendar entries, emails, notes).
  • Integrity Violation: Attackers can inject false information into the assistant's memory or trigger state changes in connected systems (e.g., modifying smart home devices, sending messages on behalf of the user).
  • Resource Exhaustion: An attacker can spam the assistant with complex queries, driving up LLM API costs (OpenAI, Anthropic, etc.) or exhausting local compute resources.

The CVSS score is estimated at 9.8 (Critical) because the attack vector is network-based (via the messaging platform), requires no privileges, requires no user interaction, and results in a total compromise of the confidentiality and integrity of the AI agent's operations.

Official Patches

OpenClawFix: fail closed parsed chat allowlist
OpenClawRefactor: make empty allowlist behavior explicit

Fix Analysis (1)

Technical Appendix

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

Affected Systems

OpenClaw (Core)OpenClaw BlueBubbles Plugin

Affected Versions Detail

Product
Affected Versions
Fixed Version
OpenClaw
OpenClaw
< Feb 22, 2026commit 9632b9b
AttributeDetail
CWE IDCWE-863
Attack VectorNetwork
CVSS9.8 (Critical)
ImpactAuthorization Bypass
Exploit StatusPoC Available
Fix ComplexityLow (Logic Update)

MITRE ATT&CK Mapping

T1190Exploit Public-Facing Application
Initial Access
T1078Valid Accounts
Defense Evasion
CWE-863
Incorrect Authorization

The software does not provide sufficient authorization for an actor to access a resource or perform an action, or it incorrectly validates the authorization.

Known Exploits & Detection

Internal ResearchLogic flaw demonstrated in commit history.

Vulnerability Timeline

Vulnerability identified in adjacent plugins
2026-02-15
Root cause identified in plugin-sdk
2026-02-21
Fix merged to main branch
2026-02-21
GHSA-JWF4-8WF4-JF2M Published
2026-02-22

References & Sources

  • [1]GitHub Advisory GHSA-JWF4-8WF4-JF2M
  • [2]OpenClaw Security Documentation

Attack Flow Diagram

Press enter or space to select a node. You can then use the arrow keys to move the node around. Press delete to remove it and escape to cancel.
Press enter or space to select an edge. You can then press delete to remove it or escape to cancel.

More Reports

•10 days ago•CVE-2026-9354
6.9

CVE-2026-9354: Arbitrary Mass Mention Bypass in NousResearch hermes-agent Slack and Mattermost Adapters

A vulnerability in the Slack and Mattermost platform adapters for NousResearch hermes-agent permits an unauthenticated remote attacker to execute arbitrary mass mentions. By leveraging prompt injection, an attacker can bypass output sanitization logic and trigger workspace-wide notification exhaustion.

Alon Barad
Alon Barad
47 views•6 min read
•10 days ago•CVE-2026-9306
6.3

CVE-2026-9306: Unauthenticated Insecure Direct Object Reference (IDOR) in QuantumNous new-api Midjourney Relay

CVE-2026-9306 is a critical unauthenticated Insecure Direct Object Reference (IDOR) vulnerability located in the QuantumNous new-api application, affecting versions up to and including 0.12.1. The flaw is caused by improper middleware ordering combined with a lack of object-level authorization checks. This allows remote, unauthenticated attackers to retrieve sensitive Midjourney images belonging to other users by supplying a valid task identifier.

Amit Schendel
Amit Schendel
23 views•5 min read
•11 days ago•GHSA-GGXF-37HM-9WQF
6.5

GHSA-GGXF-37HM-9WQF: Session Leakage via Unsafe Challenge Path Parsing in instagrapi

The instagrapi library prior to version 2.6.9 contains an improper input validation vulnerability within its challenge handling mechanism. Maliciously crafted server responses can manipulate the client into forwarding session cookies and credentials to an external attacker-controlled domain.

Amit Schendel
Amit Schendel
27 views•6 min read
•11 days ago•GHSA-QQQM-5547-774X
9.1

GHSA-QQQM-5547-774X: Unauthenticated Path Traversal in FileBrowser Quantum PATCH Handler

GHSA-QQQM-5547-774X is a critical path traversal vulnerability in the FileBrowser Quantum application, specifically within the Go backend package. The vulnerability resides in the HTTP handler responsible for processing bulk file modifications via the public API. Unauthenticated attackers can exploit an order-of-operations flaw in the path sanitization logic to bypass intended directory restrictions. This allows adversaries to arbitrarily read, move, and overwrite files on the underlying filesystem by supplying specially crafted HTTP PATCH requests.

Alon Barad
Alon Barad
18 views•6 min read
•11 days ago•CVE-2026-8723
5.3

CVE-2026-8723: Synchronous Denial of Service in qs npm Package via TypeError

The qs query string parsing and serialization library for Node.js is vulnerable to a synchronous Denial of Service (DoS) attack. The vulnerability manifests as a process-terminating TypeError when processing arrays with null or undefined elements under specific configuration parameters.

Amit Schendel
Amit Schendel
43 views•7 min read
•11 days ago•GHSA-7M8F-HGJQ-8GC9
7.5

GHSA-7M8F-HGJQ-8GC9: Pre-Authentication Denial of Service via Insecure Deserialization Order in aiosend

The aiosend library prior to version 3.0.6 contains a pre-authentication Denial of Service (DoS) vulnerability in its webhook handling mechanism. The software processes and deserializes incoming JSON payloads before verifying the cryptographic signature, allowing unauthenticated attackers to exhaust server CPU and memory resources by sending large, complex payloads.

Amit Schendel
Amit Schendel
5 views•6 min read