mirror of
https://github.com/postgres/postgres.git
synced 2025-09-02 04:21:28 +03:00
Replace last PushOverrideSearchPath() call with set_config_option().
The two methods don't cooperate, so set_config_option("search_path", ...) has been ineffective under non-empty overrideStack. This defect enabled an attacker having database-level CREATE privilege to execute arbitrary code as the bootstrap superuser. While that particular attack requires v13+ for the trusted extension attribute, other attacks are feasible in all supported versions. Standardize on the combination of NewGUCNestLevel() and set_config_option("search_path", ...). It is newer than PushOverrideSearchPath(), more-prevalent, and has no known disadvantages. The "override" mechanism remains for now, for compatibility with out-of-tree code. Users should update such code, which likely suffers from the same sort of vulnerability closed here. Back-patch to v11 (all supported versions). Alexander Lakhin. Reported by Alexander Lakhin. Security: CVE-2023-2454
This commit is contained in:
@@ -1,6 +1,14 @@
|
||||
--
|
||||
-- Regression tests for schemas (namespaces)
|
||||
--
|
||||
-- set the whitespace-only search_path to test that the
|
||||
-- GUC list syntax is preserved during a schema creation
|
||||
SELECT pg_catalog.set_config('search_path', ' ', false);
|
||||
set_config
|
||||
------------
|
||||
|
||||
(1 row)
|
||||
|
||||
CREATE SCHEMA test_ns_schema_1
|
||||
CREATE UNIQUE INDEX abc_a_idx ON abc (a)
|
||||
CREATE VIEW abc_view AS
|
||||
@@ -9,6 +17,43 @@ CREATE SCHEMA test_ns_schema_1
|
||||
a serial,
|
||||
b int UNIQUE
|
||||
);
|
||||
-- verify that the correct search_path restored on abort
|
||||
SET search_path to public;
|
||||
BEGIN;
|
||||
SET search_path to public, test_ns_schema_1;
|
||||
CREATE SCHEMA test_ns_schema_2
|
||||
CREATE VIEW abc_view AS SELECT c FROM abc;
|
||||
ERROR: column "c" does not exist
|
||||
LINE 2: CREATE VIEW abc_view AS SELECT c FROM abc;
|
||||
^
|
||||
COMMIT;
|
||||
SHOW search_path;
|
||||
search_path
|
||||
-------------
|
||||
public
|
||||
(1 row)
|
||||
|
||||
-- verify that the correct search_path preserved
|
||||
-- after creating the schema and on commit
|
||||
BEGIN;
|
||||
SET search_path to public, test_ns_schema_1;
|
||||
CREATE SCHEMA test_ns_schema_2
|
||||
CREATE VIEW abc_view AS SELECT a FROM abc;
|
||||
SHOW search_path;
|
||||
search_path
|
||||
--------------------------
|
||||
public, test_ns_schema_1
|
||||
(1 row)
|
||||
|
||||
COMMIT;
|
||||
SHOW search_path;
|
||||
search_path
|
||||
--------------------------
|
||||
public, test_ns_schema_1
|
||||
(1 row)
|
||||
|
||||
DROP SCHEMA test_ns_schema_2 CASCADE;
|
||||
NOTICE: drop cascades to view test_ns_schema_2.abc_view
|
||||
-- verify that the objects were created
|
||||
SELECT COUNT(*) FROM pg_class WHERE relnamespace =
|
||||
(SELECT oid FROM pg_namespace WHERE nspname = 'test_ns_schema_1');
|
||||
|
@@ -2,6 +2,10 @@
|
||||
-- Regression tests for schemas (namespaces)
|
||||
--
|
||||
|
||||
-- set the whitespace-only search_path to test that the
|
||||
-- GUC list syntax is preserved during a schema creation
|
||||
SELECT pg_catalog.set_config('search_path', ' ', false);
|
||||
|
||||
CREATE SCHEMA test_ns_schema_1
|
||||
CREATE UNIQUE INDEX abc_a_idx ON abc (a)
|
||||
|
||||
@@ -13,6 +17,26 @@ CREATE SCHEMA test_ns_schema_1
|
||||
b int UNIQUE
|
||||
);
|
||||
|
||||
-- verify that the correct search_path restored on abort
|
||||
SET search_path to public;
|
||||
BEGIN;
|
||||
SET search_path to public, test_ns_schema_1;
|
||||
CREATE SCHEMA test_ns_schema_2
|
||||
CREATE VIEW abc_view AS SELECT c FROM abc;
|
||||
COMMIT;
|
||||
SHOW search_path;
|
||||
|
||||
-- verify that the correct search_path preserved
|
||||
-- after creating the schema and on commit
|
||||
BEGIN;
|
||||
SET search_path to public, test_ns_schema_1;
|
||||
CREATE SCHEMA test_ns_schema_2
|
||||
CREATE VIEW abc_view AS SELECT a FROM abc;
|
||||
SHOW search_path;
|
||||
COMMIT;
|
||||
SHOW search_path;
|
||||
DROP SCHEMA test_ns_schema_2 CASCADE;
|
||||
|
||||
-- verify that the objects were created
|
||||
SELECT COUNT(*) FROM pg_class WHERE relnamespace =
|
||||
(SELECT oid FROM pg_namespace WHERE nspname = 'test_ns_schema_1');
|
||||
|
Reference in New Issue
Block a user