CVE-2026-49344
Published:June 19, 2026
Updated:June 29, 2026
Mercator is an open source web application that enables mapping of the information system. Prior to version 2025.05.19, Mercator's Query Engine ("/admin/queries/execute") accepts a JSON DSL ("from" / "select" / "filters" / "traverse" / "output"), translates it into an Eloquent query, and returns results as JSON. The controller method "QueryController::execute()" does not enforce an authorization gate, unlike "store()" and "massDestroy()" in the same controller which are correctly protected. As a result, any authenticated account — including the read-only Auditor role — can query models beyond its intended scope, including the "User" model. Additionally, the "password" column, although declared "$hidden", is not excluded from filter predicates, which allows it to be used in "LIKE" conditions. The "schema()" and "schemaModel()" endpoints of the same controller are similarly unguarded. The Query Engine is read-only; integrity and availability are not affected. Version 2025.05.19 patches the issue.
Affected Packages
https://github.com/sourcentis/mercator.git (GITHUB):
Affected version(s) >=mercator-0.1.0 <2026.05.19Fix Suggestion:
Update to version 2026.05.19Related Resources (1)
Do you need more information?
Contact UsCVSS v4
Base Score:
7.1
Attack Vector
NETWORK
Attack Complexity
LOW
Attack Requirements
NONE
Privileges Required
LOW
User Interaction
NONE
Vulnerable System Confidentiality
HIGH
Vulnerable System Integrity
NONE
Vulnerable System Availability
NONE
Subsequent System Confidentiality
NONE
Subsequent System Integrity
NONE
Subsequent System Availability
NONE
CVSS v3
Base Score:
6.5
Attack Vector
NETWORK
Attack Complexity
LOW
Privileges Required
LOW
User Interaction
NONE
Scope
UNCHANGED
Confidentiality
HIGH
Integrity
NONE
Availability
NONE
Weakness Type (CWE)
Exposure of Private Personal Information to an Unauthorized Actor
EPSS
Base Score:
0.28