Elastic releases detections for the Axios supply chain compromise
2026-04-01 • Elastic •
https://www.elastic.co/security-labs/axios-supply-chain-compromise-detections
Elastic Security Labs released triage and behavior-based detections for the Axios supply-chain compromise, where malicious axios versions 1.14.1 and 0.30.4 pulled in [email protected] and executed payloads through npm postinstall activity. The delivery chain consistently moved from node to OS-native interpreters or shells, using curl, cscript, osascript, PowerShell, or zsh to fetch and launch second-stage payloads across Linux, Windows, and macOS. The Linux payload was a Python RAT, the Windows payload was a PowerShell RAT with Run-key persistence and in-memory execution support, and the macOS payload was a self-signed Mach-O backdoor masquerading as an Apple-like cache component. Elastic highlights high-signal process ancestry, renamed signed-binary execution, suspicious registry writes, base64 PowerShell decoding, invalid code signatures, and C2 arguments as detection opportunities. The activity matters because defenders can catch the compromise through cross-platform behavioral patterns rather than depending only on specific filenames or hardcoded indicators.
Indicators of Compromise
| Type | Value | First Seen | Last Seen |
|---|---|---|---|
| DOMAIN | sfrclak.com | 2026-03-30 | 2026-04-20 |
| HASH | ed8560c1ac7ceb6983ba995124d5917… | 2026-03-31 | 2026-04-17 |
| HASH | e10b1fa84f1d6481625f741b6989278… | 2026-03-31 | 2026-04-17 |
| URL | http://sfrclak.com:8000/ | 2026-03-31 | 2026-04-17 |
| HASH | 92ff08773995ebc8d55ec4b8e1a225d… | 2026-03-30 | 2026-04-17 |
| URL | http://sfrclak.com:8000/6202033 | 2026-03-30 | 2026-04-17 |
| IPv4 | 142.11.206.73 | 2026-03-30 | 2026-04-17 |
| HASH | d6f3f62fd3b9f5432f5782b62d8cfd5… | 2026-03-30 | 2026-04-04 |
| HASH | 07d889e2dadce6f3910dcbc253317d2… | 2026-03-30 | 2026-04-04 |
| HASH | e49c2732fb9861548208a78e72996b9… | 2026-03-31 | 2026-04-03 |
| HASH | 6483c004e207137385f480909d6edec… | 2026-04-01 | 2026-04-01 |