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-R9Q5-C7QC-P26W

GHSA-R9Q5-C7QC-P26W: Webhook Replay Vulnerability in OpenClaw Nextcloud Talk Integration

Alon Barad
Alon Barad
Software Engineer

Mar 4, 2026·4 min read·10 visits

Executive Summary (TL;DR)

OpenClaw's Nextcloud Talk webhook handler accepts replayed requests due to missing nonce/ID verification. Attackers can trigger duplicate AI actions. Fixed in v2026.2.25.

A capture-replay vulnerability exists in the Nextcloud Talk integration of the OpenClaw AI platform. The webhook handler properly verifies cryptographic signatures but fails to track processed message identifiers, allowing attackers to re-submit captured valid requests. This results in duplicate processing of AI commands and potential redundant side effects.

Vulnerability Overview

OpenClaw acts as a personal AI assistant that integrates with various platforms, including Nextcloud Talk, to receive and process user messages. The integration relies on incoming webhooks to trigger AI responses and execute tool-based commands. A vulnerability was identified in how these webhooks are processed: the system is stateless regarding message history.

While the application implements cryptographic signature verification using x-nextcloud-talk-signature (HMAC), it does not maintain a record of processed request identifiers (nonces or message IDs). This omission allows valid, signed requests to be captured and replayed against the server. The server accepts these replayed requests as new, legitimate events because the signature remains mathematically valid for the payload.

Root Cause Analysis

The root cause is a Missing Replay Protection mechanism (CWE-294) within the webhook handler. Secure webhook implementations typically require two components: identity verification (signature) and uniqueness verification (nonce/timestamp caching). OpenClaw implemented the former but neglected the latter.

Specifically, the onMessage handler in the Nextcloud Talk extension accepts HTTP POST requests and verifies headers. However, prior to version 2026.2.25, the handler lacked a deduplication logic or a state store to track the messageId or token of processed requests. Consequently, if an attacker intercepts a request with a valid x-nextcloud-talk-signature, they can resend it indefinitely. The application logic re-processes the payload, triggering the AI agent's logic flow anew for every submission.

Code Analysis & Fix

The remediation introduced in version 2026.2.25 adds a persistence layer to track processed messages. A new component, NextcloudTalkReplayGuard, was implemented to check incoming message IDs against a local JSON-based deduplication store.

The fix involves two key changes:

  1. Persistent Deduplication: The system now extracts a unique identifier from the webhook payload and checks if it exists in a replay-dedupe log on disk. If the ID is found and the entry is within the Time-To-Live (TTL) window, the request is rejected.
  2. Origin Validation: The patch adds a check against the x-nextcloud-talk-backend header to ensure the request originates from the configured Nextcloud instance URL, preventing cross-tenant replays.

Fixed Logic (Simplified):

// src/replay-guard.ts
export function createNextcloudTalkReplayGuard(options) {
  const persistentDedupe = createPersistentDedupe({
    ttlMs: options.ttlMs ?? DEFAULT_REPLAY_TTL_MS,
    // Stores IDs in: state/nextcloud-talk/replay-dedupe/<namespace>.json
    resolveFilePath: (namespace) => path.join(stateDir, ...),
  });
 
  return {
    shouldProcessMessage: async ({ accountId, roomToken, messageId }) => {
      // Unique key combines token and message ID
      const replayKey = `${roomToken}:${messageId}`;
      // Returns false if key already exists
      return await persistentDedupe.checkAndRecord(replayKey, { namespace: accountId });
    },
  };
}

Exploitation Scenario

Exploitation requires an attacker to have network visibility to capture traffic between the Nextcloud instance and the OpenClaw server (e.g., via Man-in-the-Middle or access to a proxy log). No authentication credentials are required to replay the request, as the valid signature is contained within the captured headers.

Attack Steps:

  1. Interception: The attacker passively monitors traffic to the OpenClaw webhook endpoint.
  2. Capture: The attacker records a valid HTTP POST request, preserving the body and the headers x-nextcloud-talk-signature, x-nextcloud-talk-random, and x-nextcloud-talk-backend.
  3. Replay: The attacker uses a tool like curl or Burp Suite to resend the exact request to the OpenClaw server.
  4. Result: The server validates the signature (which is still valid for that specific body) and processes the message again. The AI agent generates a duplicate response or executes the associated command a second time.

Impact Assessment

The primary impact is integrity violation regarding application state and resource exhaustion.

  • Duplicate Actions: If the replayed message contains a command (e.g., "Schedule a meeting at 2 PM"), the AI agent may attempt to execute this action multiple times. Depending on the downstream system's idempotency, this could create duplicate calendar entries, tasks, or database records.
  • API Cost Inflation: AI processing typically involves calls to paid LLM APIs (e.g., OpenAI, Anthropic). An attacker could flood the system with replayed requests to exhaust the victim's API credits.
  • Operational Noise: Duplicate processing pollutes logs and chat history, potentially confusing users and complicating audit trails.

Official Patches

OpenClawCommit d512163d: Add replay guard

Fix Analysis (1)

Technical Appendix

CVSS Score
Unknown/ 10

Affected Systems

OpenClaw Nextcloud Talk Integration

Affected Versions Detail

Product
Affected Versions
Fixed Version
OpenClaw
OpenClaw
< 2026.2.252026.2.25
AttributeDetail
CWECWE-294
Attack VectorNetwork
Attack ComplexityLow
Privileges RequiredNone
ImpactDuplicate Processing

MITRE ATT&CK Mapping

T1557Adversary-in-the-Middle
Credential Access
T1499Endpoint Denial of Service
Impact
CWE-294
Authentication Bypass by Capture-replay

A capture-replay flaw occurs when a design does not properly validate that a request is unique or fresh, allowing an attacker to resubmit a captured valid request.

Vulnerability Timeline

Vulnerability reported by @aristorechina
2026-02-25
Fix commit pushed by Peter Steinberger
2026-02-25
OpenClaw v2026.2.25 released with fix
2026-02-26

References & Sources

  • [1]GitHub Advisory GHSA-R9Q5-C7QC-P26W
  • [2]Security Blog Post: OpenClaw Message Reliability

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

•9 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
38 views•6 min read
•9 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
17 views•5 min read
•10 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
21 views•6 min read
•10 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
12 views•6 min read
•10 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
38 views•7 min read
•10 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
4 views•6 min read