CVE-2025-54379 – github.com/lf-edge/ekuiper
Package
Manager: go
Name: github.com/lf-edge/ekuiper
Vulnerable Version: >=0 <=1.14.7
Severity
Level: High
CVSS v3.1: CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:L/I:N/A:N/E:U/RL:U/RC:R
CVSS v4.0: CVSS:4.0/AV:N/AC:L/AT:N/PR:N/UI:N/VC:H/VI:H/VA:H/SC:N/SI:N/SA:N/E:P
EPSS: 0.00058 pctl0.18391
Details
eKuiper API endpoints handling SQL queries with user-controlled table names. ### Summary A critical SQL Injection vulnerability exists in the `getLast` API functionality of the eKuiper project. This flaw allows unauthenticated remote attackers to execute arbitrary SQL statements on the underlying SQLite database by manipulating the table name input in an API request. Exploitation can lead to data theft, corruption, or deletion, and full database compromise. ### Details The root cause lies in the use of unsanitized user-controlled input when constructing SQL queries using `fmt.Sprintf`, without validating the `table` parameter. Specifically, in: ```go query := fmt.Sprintf("SELECT * FROM %s ORDER BY rowid DESC LIMIT 1", table) ``` Any value passed as the `table` parameter is directly interpolated into the SQL string, enabling injection attacks. This is reachable via API interfaces that expose time-series queries. ### PoC 1. **Deploy eKuiper instance** (default config is sufficient). 2. **Send a crafted request to the SQL query endpoint**: ```bash curl -X POST http://localhost:9081/sql-query \ -H "Content-Type: application/json" \ -d '{ "table": "sensors; DROP TABLE users; --", "operation": "getLast" }' ``` 3. **Effect**: Executes two SQL queries — the first selects data, the second drops the `users` table. 4. **Verify Result**: ```bash sqlite3 etc/kuiper/data/kuiper.db ".tables" ``` ### Impact CWE-89: Improper Neutralization of Special Elements used in an SQL Command ('SQL Injection') ### Refferences - https://github.com/lf-edge/ekuiper/commit/72c4918744934deebf04e324ae66933ec089ebd3
Metadata
Created: 2025-07-24T14:19:17Z
Modified: 2025-07-29T23:38:53Z
Source: https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2025/07/GHSA-526j-mv3p-f4vv/GHSA-526j-mv3p-f4vv.json
CWE IDs: ["CWE-89"]
Alternative ID: GHSA-526j-mv3p-f4vv
Finding: F297
Auto approve: 1