Description
Stored cross-site scripting (XSS) vulnerability in pgAdmin 4 Browser Tree and Explain Visualizer modules. User-controlled PostgreSQL object names (database, schema, table, column, etc.) were assigned to DOM elements via innerHTML, allowing crafted object names containing HTML markup to execute attacker-supplied JavaScript in the browser of any pgAdmin user who navigated to or executed EXPLAIN over the malicious object. Fix replaces innerHTML with textContent. This issue affects pgAdmin 4: before 9.15.
Authenticated pgAdmin user with INSERT/CREATE privileges on a database object whose name a victim views in pgAdmin's Browser Tree or Explain output. PR:H reflects that planting the malicious object name requires DDL privileges in addition to a pgAdmin login.
Authenticated pgAdmin user with INSERT/CREATE privileges on a database object whose name a victim views in pgAdmin's Browser Tree or Explain output. PR:H reflects that planting the malicious object name requires DDL privileges in addition to a pgAdmin login.
Product status
6.9 (custom) before 9.15
Credits
Fahar Abbas
References
github.com/pgadmin-org/pgadmin4/issues/9865
github.com/pgadmin-org/pgadmin4/pull/9865