Skip to content

Commit 7b34740

Browse files
committed
adminpack: Revoke EXECUTE on pg_logfile_rotate()
In 9.6, we moved a number of functions over to using the GRANT system to control access instead of having hard-coded superuser checks. As it turns out, adminpack was creating another function in the catalog for one of those backend functions where the superuser check was removed, specifically pg_rotate_logfile(), but it didn't get the memo about having to REVOKE EXECUTE on the alternative-name function (pg_logfile_rotate()), meaning that in any installations with adminpack on 9.6 and higher, any user is able to run the pg_logfile_rotate() function, which then calls pg_rotate_logfile() and rotates the logfile. Fix by adding a new version of adminpack (1.1) which handles the REVOKE. As this function should have only been available to the superuser, this is a security issue, albeit a minor one. In HEAD, move the changes implemented for adminpack up to be adminpack 2.0 instead of 1.1. Security: CVE-2018-1115
1 parent f955d7e commit 7b34740

File tree

4 files changed

+54
-48
lines changed

4 files changed

+54
-48
lines changed

contrib/adminpack/Makefile

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,7 @@ OBJS = adminpack.o $(WIN32RES)
55
PG_CPPFLAGS = -I$(libpq_srcdir)
66

77
EXTENSION = adminpack
8-
DATA = adminpack--1.0.sql adminpack--1.0--1.1.sql
8+
DATA = adminpack--1.0.sql adminpack--1.0--1.1.sql adminpack--1.1--2.0.sql
99
PGFILEDESC = "adminpack - support functions for pgAdmin"
1010

1111
REGRESS = adminpack

contrib/adminpack/adminpack--1.0--1.1.sql

Lines changed: 1 addition & 46 deletions
Original file line numberDiff line numberDiff line change
@@ -3,49 +3,4 @@
33
-- complain if script is sourced in psql, rather than via ALTER EXTENSION
44
\echo Use "ALTER EXTENSION adminpack UPDATE TO '1.1'" to load this file. \quit
55

6-
/* ***********************************************
7-
* Administrative functions for PostgreSQL
8-
* *********************************************** */
9-
10-
/* generic file access functions */
11-
12-
CREATE OR REPLACE FUNCTION pg_catalog.pg_file_write(text, text, bool)
13-
RETURNS bigint
14-
AS 'MODULE_PATHNAME', 'pg_file_write_v1_1'
15-
LANGUAGE C VOLATILE STRICT;
16-
17-
REVOKE EXECUTE ON FUNCTION pg_catalog.pg_file_write(text, text, bool) FROM PUBLIC;
18-
19-
CREATE OR REPLACE FUNCTION pg_catalog.pg_file_rename(text, text, text)
20-
RETURNS bool
21-
AS 'MODULE_PATHNAME', 'pg_file_rename_v1_1'
22-
LANGUAGE C VOLATILE;
23-
24-
REVOKE EXECUTE ON FUNCTION pg_catalog.pg_file_rename(text, text, text) FROM PUBLIC;
25-
26-
CREATE OR REPLACE FUNCTION pg_catalog.pg_file_rename(text, text)
27-
RETURNS bool
28-
AS 'SELECT pg_catalog.pg_file_rename($1, $2, NULL::pg_catalog.text);'
29-
LANGUAGE SQL VOLATILE STRICT;
30-
31-
CREATE OR REPLACE FUNCTION pg_catalog.pg_file_unlink(text)
32-
RETURNS bool
33-
AS 'MODULE_PATHNAME', 'pg_file_unlink_v1_1'
34-
LANGUAGE C VOLATILE STRICT;
35-
36-
REVOKE EXECUTE ON FUNCTION pg_catalog.pg_file_unlink(text) FROM PUBLIC;
37-
38-
CREATE OR REPLACE FUNCTION pg_catalog.pg_logdir_ls()
39-
RETURNS setof record
40-
AS 'MODULE_PATHNAME', 'pg_logdir_ls_v1_1'
41-
LANGUAGE C VOLATILE STRICT;
42-
43-
REVOKE EXECUTE ON FUNCTION pg_catalog.pg_logdir_ls() FROM PUBLIC;
44-
45-
/* These functions are now in the backend and callers should update to use those */
46-
47-
DROP FUNCTION pg_file_read(text, bigint, bigint);
48-
49-
DROP FUNCTION pg_file_length(text);
50-
51-
DROP FUNCTION pg_logfile_rotate();
6+
REVOKE EXECUTE ON FUNCTION pg_catalog.pg_logfile_rotate() FROM PUBLIC;
Lines changed: 51 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,51 @@
1+
/* contrib/adminpack/adminpack--1.1--2.0.sql */
2+
3+
-- complain if script is sourced in psql, rather than via ALTER EXTENSION
4+
\echo Use "ALTER EXTENSION adminpack UPDATE TO '2.0'" to load this file. \quit
5+
6+
/* ***********************************************
7+
* Administrative functions for PostgreSQL
8+
* *********************************************** */
9+
10+
/* generic file access functions */
11+
12+
CREATE OR REPLACE FUNCTION pg_catalog.pg_file_write(text, text, bool)
13+
RETURNS bigint
14+
AS 'MODULE_PATHNAME', 'pg_file_write_v1_1'
15+
LANGUAGE C VOLATILE STRICT;
16+
17+
REVOKE EXECUTE ON FUNCTION pg_catalog.pg_file_write(text, text, bool) FROM PUBLIC;
18+
19+
CREATE OR REPLACE FUNCTION pg_catalog.pg_file_rename(text, text, text)
20+
RETURNS bool
21+
AS 'MODULE_PATHNAME', 'pg_file_rename_v1_1'
22+
LANGUAGE C VOLATILE;
23+
24+
REVOKE EXECUTE ON FUNCTION pg_catalog.pg_file_rename(text, text, text) FROM PUBLIC;
25+
26+
CREATE OR REPLACE FUNCTION pg_catalog.pg_file_rename(text, text)
27+
RETURNS bool
28+
AS 'SELECT pg_catalog.pg_file_rename($1, $2, NULL::pg_catalog.text);'
29+
LANGUAGE SQL VOLATILE STRICT;
30+
31+
CREATE OR REPLACE FUNCTION pg_catalog.pg_file_unlink(text)
32+
RETURNS bool
33+
AS 'MODULE_PATHNAME', 'pg_file_unlink_v1_1'
34+
LANGUAGE C VOLATILE STRICT;
35+
36+
REVOKE EXECUTE ON FUNCTION pg_catalog.pg_file_unlink(text) FROM PUBLIC;
37+
38+
CREATE OR REPLACE FUNCTION pg_catalog.pg_logdir_ls()
39+
RETURNS setof record
40+
AS 'MODULE_PATHNAME', 'pg_logdir_ls_v1_1'
41+
LANGUAGE C VOLATILE STRICT;
42+
43+
REVOKE EXECUTE ON FUNCTION pg_catalog.pg_logdir_ls() FROM PUBLIC;
44+
45+
/* These functions are now in the backend and callers should update to use those */
46+
47+
DROP FUNCTION pg_file_read(text, bigint, bigint);
48+
49+
DROP FUNCTION pg_file_length(text);
50+
51+
DROP FUNCTION pg_logfile_rotate();

contrib/adminpack/adminpack.control

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
# adminpack extension
22
comment = 'administrative functions for PostgreSQL'
3-
default_version = '1.1'
3+
default_version = '2.0'
44
module_pathname = '$libdir/adminpack'
55
relocatable = false
66
schema = pg_catalog

0 commit comments

Comments
 (0)
pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy