GHSA-wgm6-9rvv-3438

Suggest an improvement
Source
https://github.com/advisories/GHSA-wgm6-9rvv-3438
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/02/GHSA-wgm6-9rvv-3438/GHSA-wgm6-9rvv-3438.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-wgm6-9rvv-3438
Aliases
Published
2026-02-18T00:56:30Z
Modified
2026-02-23T19:41:19.274299Z
Severity
  • 6.9 (Medium) CVSS_V4 - CVSS:4.0/AV:N/AC:L/AT:N/PR:N/UI:N/VC:N/VI:N/VA:N/SC:L/SI:L/SA:N CVSS Calculator
Summary
Libredesk has a SSRF Vulnerability in Webhooks
Details

Date: 2025-12-07 Vulnerability: Server-Side Request Forgery (SSRF) Component: Webhooks Module

Executive Summary

A critical security vulnerability exists in the LibreDesk Webhooks module that allows an authenticated "Application Admin" to compromise the underlying cloud infrastructure or internal corporate network where this service is being hosted.

The application fails to validate destination URLs for webhooks. This allows an attacker to force the server to make HTTP requests to arbitrary internal destinations.

Confirmed Attack Vectors

1. Internal Port Scanning (Network Mapping)

Attackers can map the internal network by observing the difference between successful connections and connection errors. This works even if the response body is not returned.

Proof of Exploitation (from Server Logs): * Open Port (8890): The server connects successfully.

timestamp=... level=info message="webhook delivered successfully" ... status_code=200
    
* Closed Port (8891): The server fails to connect.
timestamp=... level=error message="webhook delivery failed" ... error="... connect: connection refused"
    

Impact: An attacker can identify running services (databases, caches, internal apps) on the local network (e.g., localhost, 192.168.x.x).

2. Information Leakage (Error-Based)

If the internal service returns a non-2xx response (e.g., 403 Forbidden, 404 Not Found, 500 Error), the application logs the full response body.

Proof of Exploitation (from Server Logs):

timestamp=... level=error message="webhook delivery failed" ... 
response="{\"secret_key\": \"xxx123\", \"role\": \"admin\"}"

Impact: An attacker can extract sensitive data by targeting endpoints that return errors or by forcing errors on internal services.

Technical Root Cause

  1. Missing Input Validation: cmd/webhooks.go only checks if the URL is empty, not if it resolves to a private IP.
  2. Unrestricted HTTP Client: internal/webhook/webhook.go uses a default http.Client that follows redirects and connects to any IP.
  3. Verbose Error Logging: The application logs the full response body on failure, creating a side-channel for data exfiltration.

Remediation Required

To prevent this, the application must implement Defense in Depth:

  1. Input Validation: Block URLs resolving to private IP ranges (RFC 1918) and Link-Local addresses.
  2. Safe HTTP Client: Use a custom http.Transport that verifies the destination IP address after DNS resolution to prevent DNS rebinding attacks.
Database specific
{
    "github_reviewed": true,
    "cwe_ids": [
        "CWE-209",
        "CWE-918"
    ],
    "nvd_published_at": "2026-02-20T00:16:15Z",
    "github_reviewed_at": "2026-02-18T00:56:30Z",
    "severity": "MODERATE"
}
References

Affected packages

Go / github.com/abhinavxd/libredesk

Package

Name
github.com/abhinavxd/libredesk
View open source insights on deps.dev
Purl
pkg:golang/github.com/abhinavxd/libredesk

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
1.0.2-0.20260215211005-727213631ce6

Database specific

source
"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/02/GHSA-wgm6-9rvv-3438/GHSA-wgm6-9rvv-3438.json"