GHSA-mv9j-6xhh-g383

Suggest an improvement
Source
https://github.com/advisories/GHSA-mv9j-6xhh-g383
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/02/GHSA-mv9j-6xhh-g383/GHSA-mv9j-6xhh-g383.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-mv9j-6xhh-g383
Aliases
Published
2026-02-17T21:31:17Z
Modified
2026-03-06T01:03:52.943066Z
Severity
  • 6.2 (Medium) CVSS_V3 - CVSS:3.1/AV:L/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:N CVSS Calculator
  • 6.3 (Medium) CVSS_V4 - CVSS:4.0/AV:N/AC:L/AT:P/PR:N/UI:N/VC:L/VI:L/VA:N/SC:N/SI:N/SA:N CVSS Calculator
Summary
OpenClaw's unauthenticated Nostr profile HTTP endpoints allow remote profile/config tampering
Details

Summary

The OpenClaw Nostr channel plugin (optional, disabled by default, installed separately) exposes profile management HTTP endpoints under /api/channels/nostr/:accountId/profile (GET/PUT) and /api/channels/nostr/:accountId/profile/import (POST). In affected versions, these routes were dispatched via the gateway plugin HTTP layer without requiring gateway authentication, allowing unauthenticated remote callers to read or mutate the Nostr profile and persist changes to the gateway config. Profile updates are also published as a signed Nostr kind:0 event using the bot's private key.

Deployments that do not have the Nostr plugin installed and enabled are not impacted.

Affected Packages / Versions

  • Package: openclaw (npm)
  • Affected versions: <= 2026.2.9
  • Fixed versions: >= 2026.2.12
  • Scope note: only affects deployments with the optional @openclaw/nostr plugin installed and enabled

Details

This is exploitable when the gateway HTTP port is reachable beyond localhost (for example: bound to 0.0.0.0, exposed on a LAN, behind a reverse proxy, or via Tailscale Funnel/Serve).

Unauthenticated callers could update the Nostr profile and persist the new profile in the gateway config.

Mitigation

Upgrade to openclaw 2026.2.12 or later.

As a temporary mitigation, restrict gateway HTTP exposure (bind loopback-only and/or enforce network-layer access controls) until upgraded.

Fix

Gateway now requires gateway authentication for plugin HTTP requests under /api/channels/* before dispatching to plugin handlers.

Fix commit(s): - 647d929c9d0fd114249230d939a5cb3b36dc70e7

Thanks @simecek for reporting.

Database specific
{
    "severity": "MODERATE",
    "cwe_ids": [
        "CWE-285",
        "CWE-306"
    ],
    "github_reviewed": true,
    "github_reviewed_at": "2026-02-17T21:31:17Z",
    "nvd_published_at": "2026-03-05T22:16:17Z"
}
References

Affected packages

npm / openclaw

Package

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
2026.2.12

Database specific

source
"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/02/GHSA-mv9j-6xhh-g383/GHSA-mv9j-6xhh-g383.json"