CVE-2026-30242
Plane has SSRF via Incomplete IP Validation in Webhook URL Serializer
Description
### Summary The webhook URL validation in `plane/app/serializers/webhook.py` only checks `ip.is_loopback`, allowing attackers with workspace ADMIN role to create webhooks pointing to private/internal network addresses (`10.x.x.x`, `172.16.x.x`, `192.168.x.x`, `169.254.169.254`, etc.). When webhook events fire, the server makes requests to these internal addresses and stores the response — enabling SSRF with full response read-back. ### Impact - **Cloud metadata exfiltration**: Access AWS/GCP/Azure instance metadata (IAM credentials, tokens) - **Internal service scanning**: Probe internal network services not exposed to the internet - **Data exfiltration via response logs**: Full response body from internal services is stored and returned to the attacker through the webhook logs API - Bypass vectors: `10.0.0.0/8`, `172.16.0.0/12`, `192.168.0.0/16`, `169.254.0.0/16`, `0.0.0.0`, `::ffff:` mapped addresses
How to fix CVE-2026-30242
To remediate CVE-2026-30242, upgrade the affected package to a fixed version below.
- —upgrade to 1.2.3 or later
Is CVE-2026-30242 being exploited?
Low — EPSS is 0.0%, meaning exploitation activity has not been observed at scale.
Affected packages (1)
- from 0, < 1.2.3
CVSS scores
| Source | Version | Severity | Vector |
|---|---|---|---|
| osv | CVSS 3.1 | HIGH8.5 | CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:C/C:H/I:L/A:N |