CVE-2023-48786

4.3 MEDIUM

📋 TL;DR

This CVE describes a server-side request forgery (SSRF) vulnerability in Fortinet FortiClientEMS that allows authenticated attackers to make internal network requests via crafted HTTP/HTTPS requests. It affects FortiClientEMS versions 7.4.0 through 7.4.2 and versions before 7.2.6. Attackers must have valid authentication credentials to exploit this vulnerability.

💻 Affected Systems

Products:
  • Fortinet FortiClientEMS
Versions: 7.4.0 through 7.4.2, and versions before 7.2.6
Operating Systems: All supported FortiClientEMS platforms
Default Config Vulnerable: ⚠️ Yes
Notes: Only affects systems with FortiClientEMS installed and configured. Requires attacker authentication.

📦 What is this software?

⚠️ Risk & Real-World Impact

🔴

Worst Case

An authenticated attacker could use SSRF to access internal services, potentially leading to data exfiltration, internal network reconnaissance, or chaining with other vulnerabilities to achieve remote code execution.

🟠

Likely Case

Authenticated attackers scanning internal networks, accessing metadata services, or interacting with internal APIs that shouldn't be externally accessible.

🟢

If Mitigated

Limited to authenticated users only, with network segmentation preventing access to critical internal systems.

🌐 Internet-Facing: MEDIUM - Requires authentication but could be exploited if EMS is internet-facing and credentials are compromised.
🏢 Internal Only: MEDIUM - Internal attackers with valid credentials could abuse this to pivot within the network.

🎯 Exploit Status

Public PoC: ✅ No
Weaponized: UNKNOWN
Unauthenticated Exploit: ✅ No
Complexity: LOW

Exploitation requires authenticated access. SSRF vulnerabilities are typically straightforward to exploit once authentication is obtained.

🛠️ Fix & Mitigation

✅ Official Fix

Patch Version: 7.4.3 or 7.2.6 and later

Vendor Advisory: https://fortiguard.fortinet.com/psirt/FG-IR-23-342

Restart Required: Yes

Instructions:

1. Download FortiClientEMS version 7.4.3 or 7.2.6+ from Fortinet support portal. 2. Backup current configuration. 3. Install the update following Fortinet's upgrade guide. 4. Restart the EMS service.

🔧 Temporary Workarounds

Network Segmentation

all

Restrict FortiClientEMS server network access to only necessary internal services

Access Control

all

Implement strict authentication controls and monitor for suspicious authenticated sessions

🧯 If You Can't Patch

  • Implement network segmentation to limit FortiClientEMS server's ability to reach sensitive internal systems
  • Enhance authentication security with MFA and strict access controls to reduce risk of credential compromise

🔍 How to Verify

Check if Vulnerable:

Check FortiClientEMS version via web interface or CLI. Vulnerable if version is 7.4.0-7.4.2 or <7.2.6.

Check Version:

From EMS CLI: get system status | grep Version

Verify Fix Applied:

Verify version is 7.4.3 or ≥7.2.6 after patching. Test SSRF functionality is blocked.

📡 Detection & Monitoring

Log Indicators:

  • Unusual outbound HTTP/HTTPS requests from EMS server to internal IPs
  • Multiple failed authentication attempts followed by SSRF-like requests

Network Indicators:

  • EMS server making unexpected requests to internal services
  • Traffic from EMS to metadata services or internal APIs

SIEM Query:

source="forticlientems" AND (url CONTAINS "internal" OR dst_ip IN [RFC1918 ranges]) AND method IN ["GET","POST"]

🔗 References

📤 Share & Export