SET client_min_messages TO 'warning';
DROP ROLE IF EXISTS regressgroup1;
DROP ROLE IF EXISTS regressgroup2;
DROP ROLE IF EXISTS regressuser1;
DROP ROLE IF EXISTS regressuser2;
DROP ROLE IF EXISTS regressuser3;
DROP ROLE IF EXISTS regressuser4;
DROP ROLE IF EXISTS regressuser5;
DROP ROLE IF EXISTS regressuser6;
SELECT lo_unlink(oid) FROM pg_largeobject_metadata;
RESET client_min_messages;
CREATE USER regressuser1 PASSWORD 'gauss@123';
CREATE USER regressuser2 PASSWORD 'gauss@123';
CREATE USER regressuser3 PASSWORD 'gauss@123';
CREATE USER regressuser4 PASSWORD 'gauss@123';
CREATE USER regressuser5 PASSWORD 'gauss@123';
CREATE USER regressuser5 PASSWORD 'gauss@123';
CREATE GROUP regressgroup1 PASSWORD 'gauss@123';
CREATE GROUP regressgroup2 WITH USER regressuser1, regressuser2 PASSWORD 'gauss@123';
ALTER GROUP regressgroup1 ADD USER regressuser4;
ALTER GROUP regressgroup2 ADD USER regressuser2;
ALTER GROUP regressgroup2 DROP USER regressuser2;
GRANT regressgroup2 TO regressuser4 WITH ADMIN OPTION;
SET SESSION AUTHORIZATION regressuser1 PASSWORD 'gauss@123';
SET search_path to public;
SELECT session_user, current_user;
CREATE TABLE atest1 ( a int, b text );
SELECT * FROM atest1;
INSERT INTO atest1 VALUES (1, 'one');
DELETE FROM atest1;
UPDATE atest1 SET a = 1 WHERE b = 'blech';
TRUNCATE atest1;
START TRANSACTION;
LOCK atest1 IN ACCESS EXCLUSIVE MODE;
COMMIT;
REVOKE ALL ON atest1 FROM PUBLIC;
SELECT * FROM atest1;
GRANT ALL ON atest1 TO regressuser2;
GRANT SELECT ON atest1 TO regressuser3, regressuser4;
SELECT * FROM atest1;
CREATE TABLE atest2 (col1 varchar(10), col2 boolean);
GRANT SELECT ON atest2 TO regressuser2;
GRANT UPDATE ON atest2 TO regressuser3;
GRANT INSERT ON atest2 TO regressuser4;
GRANT TRUNCATE ON atest2 TO regressuser5;
SET SESSION AUTHORIZATION regressuser2 PASSWORD 'gauss@123';
SELECT session_user, current_user;
SELECT * FROM atest1;
SELECT * FROM atest2;
INSERT INTO atest1 VALUES (2, 'two');
INSERT INTO atest2 VALUES ('foo', true);
INSERT INTO atest1 SELECT 1, b FROM atest1;
UPDATE atest1 SET a = 1 WHERE a = 2;
UPDATE atest2 SET col2 = NOT col2;
DELETE FROM atest2;
TRUNCATE atest2;
START TRANSACTION;
LOCK atest2 IN ACCESS EXCLUSIVE MODE;
COMMIT;
COPY atest2 FROM stdin;
GRANT ALL ON atest1 TO PUBLIC;
SELECT * FROM atest1 WHERE ( b IN ( SELECT col1 FROM atest2 ) );
SELECT * FROM atest2 WHERE ( col1 IN ( SELECT b FROM atest1 ) );
SET SESSION AUTHORIZATION regressuser3 PASSWORD 'gauss@123';
SELECT session_user, current_user;
SELECT * FROM atest1 ORDER BY 1;
SELECT * FROM atest2;
INSERT INTO atest1 VALUES (2, 'two');
INSERT INTO atest2 VALUES ('foo', true);
INSERT INTO atest1 SELECT 1, b FROM atest1;
UPDATE atest1 SET a = 1 WHERE a = 2;
UPDATE atest2 SET col2 = NULL;
UPDATE atest2 SET col2 = NOT col2;
UPDATE atest2 SET col2 = true FROM atest1 WHERE atest1.a = 5;
SELECT * FROM atest1 FOR UPDATE;
SELECT * FROM atest2 FOR UPDATE;
DELETE FROM atest2;
TRUNCATE atest2;
START TRANSACTION;
LOCK atest2 IN ACCESS EXCLUSIVE MODE;
COMMIT;
COPY atest2 FROM stdin;
SELECT * FROM atest1 WHERE ( b IN ( SELECT col1 FROM atest2 ) );
SELECT * FROM atest2 WHERE ( col1 IN ( SELECT b FROM atest1 ) );
SET SESSION AUTHORIZATION regressuser4 PASSWORD 'gauss@123';
COPY atest2 FROM stdin;
bar true
\.
SELECT * FROM atest1 ORDER BY 1;
SET SESSION AUTHORIZATION regressuser3 PASSWORD 'gauss@123';
CREATE TABLE atest3 (one int, two int, three int);
GRANT DELETE ON atest3 TO GROUP regressgroup2;
SET SESSION AUTHORIZATION regressuser1 PASSWORD 'gauss@123';
SELECT * FROM atest3;
DELETE FROM atest3;
SET SESSION AUTHORIZATION regressuser3 PASSWORD 'gauss@123';
CREATE VIEW atestv1 AS SELECT * FROM atest1;
CREATE VIEW atestv2 AS SELECT * FROM atest2;
CREATE VIEW atestv3 AS SELECT * FROM atest3;
SELECT * FROM atestv1 order by 1, 2;
SELECT * FROM atestv2;
GRANT SELECT ON atestv1, atestv3 TO regressuser4;
GRANT SELECT ON atestv2 TO regressuser2;
SET SESSION AUTHORIZATION regressuser4 PASSWORD 'gauss@123';
SELECT * FROM atestv1 order by 1, 2;
SELECT * FROM atestv2;
SELECT * FROM atestv3;
CREATE VIEW atestv4 AS SELECT * FROM atestv3;
SELECT * FROM atestv4;
GRANT SELECT ON atestv4 TO regressuser2;
SET SESSION AUTHORIZATION regressuser2 PASSWORD 'gauss@123';
SELECT * FROM atestv3;
SELECT * FROM atestv4;
SELECT * FROM atest2;
SELECT * FROM atestv2;
SET SESSION AUTHORIZATION regressuser1 PASSWORD 'gauss@123';
CREATE TABLE atest5 (one int, two int, three int);
CREATE TABLE atest6 (one int, two int, blue int);
GRANT SELECT (one), INSERT (two), UPDATE (three) ON atest5 TO regressuser4;
GRANT ALL (one) ON atest5 TO regressuser3;
INSERT INTO atest5 VALUES (1,2,3);
SET SESSION AUTHORIZATION regressuser4 PASSWORD 'gauss@123';
SELECT * FROM atest5;
SELECT one FROM atest5;
COPY atest5 (one) TO stdout;
SELECT two FROM atest5;
COPY atest5 (two) TO stdout;
SELECT atest5 FROM atest5;
COPY atest5 (one,two) TO stdout;
SELECT 1 FROM atest5;
SELECT 1 FROM atest5 a JOIN atest5 b USING (one);
SELECT 1 FROM atest5 a JOIN atest5 b USING (two);
SELECT 1 FROM atest5 a NATURAL JOIN atest5 b;
SELECT (j.*) IS NULL FROM (atest5 a JOIN atest5 b USING (one)) j;
SELECT 1 FROM atest5 WHERE two = 2;
SELECT * FROM atest1, atest5;
SELECT atest1.* FROM atest1, atest5 order by 1, 2;
SELECT atest1.*,atest5.one FROM atest1, atest5 order by 1, 2, 3;
SELECT atest1.*,atest5.one FROM atest1 JOIN atest5 ON (atest1.a = atest5.two);
SELECT atest1.*,atest5.one FROM atest1 JOIN atest5 ON (atest1.a = atest5.one);
SELECT one, two FROM atest5;
SET SESSION AUTHORIZATION regressuser1 PASSWORD 'gauss@123';
GRANT SELECT (one,two) ON atest6 TO regressuser4;
SET SESSION AUTHORIZATION regressuser4 PASSWORD 'gauss@123';
SELECT one, two FROM atest5 NATURAL JOIN atest6;
SET SESSION AUTHORIZATION regressuser1 PASSWORD 'gauss@123';
GRANT SELECT (two) ON atest5 TO regressuser4;
SET SESSION AUTHORIZATION regressuser4 PASSWORD 'gauss@123';
SELECT one, two FROM atest5 NATURAL JOIN atest6;
INSERT INTO atest5 (two) VALUES (3);
COPY atest5 FROM stdin;
COPY atest5 (two) FROM stdin;
1
\.
INSERT INTO atest5 (three) VALUES (4);
INSERT INTO atest5 VALUES (5,5,5);
UPDATE atest5 SET three = 10;
UPDATE atest5 SET one = 8;
UPDATE atest5 SET three = 5, one = 2;
SET SESSION AUTHORIZATION regressuser1 PASSWORD 'gauss@123';
REVOKE ALL (one) ON atest5 FROM regressuser4;
GRANT SELECT (one,two,blue) ON atest6 TO regressuser4;
SET SESSION AUTHORIZATION regressuser4 PASSWORD 'gauss@123';
SELECT one FROM atest5;
UPDATE atest5 SET one = 1;
SELECT atest6 FROM atest6;
COPY atest6 TO stdout;
SET SESSION AUTHORIZATION regressuser1 PASSWORD 'gauss@123';
CREATE TABLE t1 (c1 int, c2 int, c3 int check (c3 < 5), primary key (c1, c2));
GRANT SELECT (c1) ON t1 TO regressuser2;
GRANT INSERT (c1, c2, c3) ON t1 TO regressuser2;
GRANT UPDATE (c1, c2, c3) ON t1 TO regressuser2;
INSERT INTO t1 VALUES (1, 1, 1);
INSERT INTO t1 VALUES (1, 2, 1);
INSERT INTO t1 VALUES (2, 1, 2);
INSERT INTO t1 VALUES (2, 2, 2);
INSERT INTO t1 VALUES (3, 1, 3);
SET SESSION AUTHORIZATION regressuser2 PASSWORD 'gauss@123';
INSERT INTO t1 (c1, c2) VALUES (1, 1);
UPDATE t1 SET c2 = 1;
INSERT INTO t1 (c1, c2) VALUES (null, null);
INSERT INTO t1 (c3) VALUES (null);
INSERT INTO t1 (c1) VALUES (5);
UPDATE t1 SET c3 = 10 where c1 = 1;
SET SESSION AUTHORIZATION regressuser1 PASSWORD 'gauss@123';
DROP TABLE t1;
SET SESSION AUTHORIZATION regressuser1 PASSWORD 'gauss@123';
ALTER TABLE atest6 ADD COLUMN three integer;
GRANT DELETE ON atest5 TO regressuser3;
GRANT SELECT (two) ON atest5 TO regressuser3;
REVOKE ALL (one) ON atest5 FROM regressuser3;
GRANT SELECT (one) ON atest5 TO regressuser4;
SET SESSION AUTHORIZATION regressuser4 PASSWORD 'gauss@123';
SELECT atest6 FROM atest6;
SELECT one FROM atest5 NATURAL JOIN atest6;
SET SESSION AUTHORIZATION regressuser1 PASSWORD 'gauss@123';
ALTER TABLE atest6 DROP COLUMN three;
SET SESSION AUTHORIZATION regressuser4 PASSWORD 'gauss@123';
SELECT atest6 FROM atest6;
SELECT one FROM atest5 NATURAL JOIN atest6;
SET SESSION AUTHORIZATION regressuser1 PASSWORD 'gauss@123';
ALTER TABLE atest6 DROP COLUMN two;
REVOKE SELECT (one,blue) ON atest6 FROM regressuser4;
SET SESSION AUTHORIZATION regressuser4 PASSWORD 'gauss@123';
SELECT * FROM atest6;
SELECT 1 FROM atest6;
SET SESSION AUTHORIZATION regressuser3 PASSWORD 'gauss@123';
DELETE FROM atest5 WHERE one = 1;
DELETE FROM atest5 WHERE two = 2;
SET SESSION AUTHORIZATION regressuser1 PASSWORD 'gauss@123';
CREATE TABLE atestp1 (f1 int, f2 int) WITH OIDS;
CREATE TABLE atestp2 (fx int, fy int) WITH OIDS;
CREATE TABLE atestc (fz int) INHERITS (atestp1, atestp2);
GRANT SELECT(fx,fy,oid) ON atestp2 TO regressuser2;
GRANT SELECT(fx) ON atestc TO regressuser2;
SET SESSION AUTHORIZATION regressuser2 PASSWORD 'gauss@123';
SELECT fx FROM atestp2;
SELECT fy FROM atestp2;
SELECT atestp2 FROM atestp2;
SELECT oid FROM atestp2;
SELECT fy FROM atestc;
SET SESSION AUTHORIZATION regressuser1 PASSWORD 'gauss@123';
GRANT SELECT(fy,oid) ON atestc TO regressuser2;
SET SESSION AUTHORIZATION regressuser2 PASSWORD 'gauss@123';
SELECT fx FROM atestp2;
SELECT fy FROM atestp2;
SELECT atestp2 FROM atestp2;
SELECT oid FROM atestp2;
\c -
REVOKE ALL PRIVILEGES ON LANGUAGE sql FROM PUBLIC;
GRANT USAGE ON LANGUAGE sql TO regressuser1;
GRANT USAGE ON LANGUAGE c TO PUBLIC;
SET SESSION AUTHORIZATION regressuser1 PASSWORD 'gauss@123';
SET search_path TO public;
GRANT USAGE ON LANGUAGE sql TO regressuser2;
CREATE FUNCTION testfunc1(int) RETURNS int AS 'select 2 * $1;' LANGUAGE sql;
CREATE FUNCTION testfunc2(int) RETURNS int AS 'select 3 * $1;' LANGUAGE sql;
REVOKE ALL ON FUNCTION testfunc1(int), testfunc2(int) FROM PUBLIC;
GRANT EXECUTE ON FUNCTION testfunc1(int), testfunc2(int) TO regressuser2;
GRANT USAGE ON FUNCTION testfunc1(int) TO regressuser3;
GRANT ALL PRIVILEGES ON FUNCTION testfunc1(int) TO regressuser4;
GRANT ALL PRIVILEGES ON FUNCTION testfunc_nosuch(int) TO regressuser4;
CREATE FUNCTION testfunc4(boolean) RETURNS text
AS 'select col1 from atest2 where col2 = $1;'
LANGUAGE sql SECURITY DEFINER;
GRANT EXECUTE ON FUNCTION testfunc4(boolean) TO regressuser3;
SET SESSION AUTHORIZATION regressuser2 PASSWORD 'gauss@123';
SELECT testfunc1(5), testfunc2(5);
CREATE FUNCTION testfunc3(int) RETURNS int AS 'select 2 * $1;' LANGUAGE sql;
SET SESSION AUTHORIZATION regressuser3 PASSWORD 'gauss@123';
SELECT testfunc1(5);
SELECT col1 FROM atest2 WHERE col2 = true;
SELECT testfunc4(true);
SET SESSION AUTHORIZATION regressuser4 PASSWORD 'gauss@123';
SELECT testfunc1(5);
DROP FUNCTION testfunc1(int);
\c -
DROP FUNCTION testfunc1(int);
GRANT ALL PRIVILEGES ON LANGUAGE sql TO PUBLIC;
\c -
CREATE TYPE testtype1 AS (a int, b text);
REVOKE USAGE ON TYPE testtype1 FROM PUBLIC;
GRANT USAGE ON TYPE testtype1 TO regressuser2;
GRANT USAGE ON TYPE _testtype1 TO regressuser2;
GRANT USAGE ON DOMAIN testtype1 TO regressuser2;
CREATE DOMAIN testdomain1 AS int;
REVOKE USAGE on DOMAIN testdomain1 FROM PUBLIC;
GRANT USAGE ON DOMAIN testdomain1 TO regressuser2;
GRANT USAGE ON TYPE testdomain1 TO regressuser2;
SET SESSION AUTHORIZATION regressuser1 PASSWORD 'gauss@123';
SET search_path TO public;
CREATE AGGREGATE testagg1a(testdomain1) (sfunc = int4_sum, stype = bigint);
CREATE DOMAIN testdomain2a AS testdomain1;
CREATE DOMAIN testdomain3a AS int;
CREATE FUNCTION castfunc(int) RETURNS testdomain3a AS $$ SELECT $1::testdomain3a $$ LANGUAGE SQL;
CREATE CAST (testdomain1 AS testdomain3a) WITH FUNCTION castfunc(int);
DROP FUNCTION castfunc(int) CASCADE;
DROP DOMAIN testdomain3a;
CREATE FUNCTION testfunc5a(a testdomain1) RETURNS int LANGUAGE SQL AS $$ SELECT $1 $$;
CREATE FUNCTION testfunc6a(b int) RETURNS testdomain1 LANGUAGE SQL AS $$ SELECT $1::testdomain1 $$;
CREATE OPERATOR !+! (PROCEDURE = int4pl, LEFTARG = testdomain1, RIGHTARG = testdomain1);
CREATE TABLE test5a (a int, b testdomain1);
CREATE TABLE test6a OF testtype1;
CREATE TABLE test10a (a int[], b testtype1[]);
CREATE TABLE test9a (a int, b int);
ALTER TABLE test9a ADD COLUMN c testdomain1;
ALTER TABLE test9a ALTER COLUMN b TYPE testdomain1;
CREATE TYPE test7a AS (a int, b testdomain1);
CREATE TYPE test8a AS (a int, b int);
ALTER TYPE test8a ADD ATTRIBUTE c testdomain1;
ALTER TYPE test8a ALTER ATTRIBUTE b TYPE testdomain1;
CREATE TABLE test11a AS (SELECT 1::testdomain1 AS a);
REVOKE ALL ON TYPE testtype1 FROM PUBLIC;
SET SESSION AUTHORIZATION regressuser2 PASSWORD 'gauss@123';
CREATE AGGREGATE testagg1b(testdomain1) (sfunc = int4_sum, stype = bigint);
CREATE DOMAIN testdomain2b AS testdomain1;
CREATE DOMAIN testdomain3b AS int;
CREATE FUNCTION castfunc(int) RETURNS testdomain3b AS $$ SELECT $1::testdomain3b $$ LANGUAGE SQL;
CREATE CAST (testdomain1 AS testdomain3b) WITH FUNCTION castfunc(int);
CREATE FUNCTION testfunc5b(a testdomain1) RETURNS int LANGUAGE SQL AS $$ SELECT $1 $$;
CREATE FUNCTION testfunc6b(b int) RETURNS testdomain1 LANGUAGE SQL AS $$ SELECT $1::testdomain1 $$;
CREATE OPERATOR !! (PROCEDURE = testfunc5b, RIGHTARG = testdomain1);
CREATE TABLE test5b (a int, b testdomain1);
CREATE TABLE test6b OF testtype1;
CREATE TABLE test10b (a int[], b testtype1[]);
CREATE TABLE test9b (a int, b int);
ALTER TABLE test9b ADD COLUMN c testdomain1;
ALTER TABLE test9b ALTER COLUMN b TYPE testdomain1;
CREATE TYPE test7b AS (a int, b testdomain1);
CREATE TYPE test8b AS (a int, b int);
ALTER TYPE test8b ADD ATTRIBUTE c testdomain1;
ALTER TYPE test8b ALTER ATTRIBUTE b TYPE testdomain1;
CREATE TABLE test11b AS (SELECT 1::testdomain1 AS a);
REVOKE ALL ON TYPE testtype1 FROM PUBLIC;
\c -
DROP AGGREGATE testagg1b(testdomain1);
DROP DOMAIN testdomain2b;
DROP OPERATOR !! (NONE, testdomain1);
DROP FUNCTION testfunc5b(a testdomain1);
DROP FUNCTION testfunc6b(b int);
DROP TABLE test5b;
DROP TABLE test6b;
DROP TABLE test9b;
DROP TABLE test10b;
DROP TYPE test7b;
DROP TYPE test8b;
DROP CAST (testdomain1 AS testdomain3b);
DROP FUNCTION castfunc(int) CASCADE;
DROP DOMAIN testdomain3b;
DROP TABLE test11b;
DROP TYPE testtype1;
DROP DOMAIN testdomain1;
SET SESSION AUTHORIZATION regressuser5 PASSWORD 'gauss@123';
SET search_path TO public;
TRUNCATE atest2;
TRUNCATE atest3;
select has_table_privilege(NULL,'pg_authid','select');
select has_table_privilege('pg_shad','select');
select has_table_privilege('nosuchuser','pg_authid','select');
select has_table_privilege('pg_authid','sel');
select has_table_privilege(-999999,'pg_authid','update');
select has_table_privilege(1,'select');
\c -
select has_table_privilege(current_user,'pg_authid','select');
select has_table_privilege(current_user,'pg_authid','insert');
select has_table_privilege(t2.oid,'pg_authid','update')
from (select oid from pg_roles where rolname = current_user) as t2;
select has_table_privilege(t2.oid,'pg_authid','delete')
from (select oid from pg_roles where rolname = current_user) as t2;
select has_table_privilege(current_user,t1.oid,'rule')
from (select oid from pg_class where relname = 'pg_authid') as t1;
select has_table_privilege(current_user,t1.oid,'references')
from (select oid from pg_class where relname = 'pg_authid') as t1;
select has_table_privilege(t2.oid,t1.oid,'select')
from (select oid from pg_class where relname = 'pg_authid') as t1,
(select oid from pg_roles where rolname = current_user) as t2;
select has_table_privilege(t2.oid,t1.oid,'insert')
from (select oid from pg_class where relname = 'pg_authid') as t1,
(select oid from pg_roles where rolname = current_user) as t2;
select has_table_privilege('pg_authid','update');
select has_table_privilege('pg_authid','delete');
select has_table_privilege('pg_authid','truncate');
select has_table_privilege(t1.oid,'select')
from (select oid from pg_class where relname = 'pg_authid') as t1;
select has_table_privilege(t1.oid,'trigger')
from (select oid from pg_class where relname = 'pg_authid') as t1;
SET SESSION AUTHORIZATION regressuser3 PASSWORD 'gauss@123';
SET search_path TO public;
select has_table_privilege(current_user,'pg_class','select');
select has_table_privilege(current_user,'pg_class','insert');
select has_table_privilege(t2.oid,'pg_class','update')
from (select oid from pg_roles where rolname = current_user) as t2;
select has_table_privilege(t2.oid,'pg_class','delete')
from (select oid from pg_roles where rolname = current_user) as t2;
select has_table_privilege(current_user,t1.oid,'references')
from (select oid from pg_class where relname = 'pg_class') as t1;
select has_table_privilege(t2.oid,t1.oid,'select')
from (select oid from pg_class where relname = 'pg_class') as t1,
(select oid from pg_roles where rolname = current_user) as t2;
select has_table_privilege(t2.oid,t1.oid,'insert')
from (select oid from pg_class where relname = 'pg_class') as t1,
(select oid from pg_roles where rolname = current_user) as t2;
select has_table_privilege('pg_class','update');
select has_table_privilege('pg_class','delete');
select has_table_privilege('pg_class','truncate');
select has_table_privilege(t1.oid,'select')
from (select oid from pg_class where relname = 'pg_class') as t1;
select has_table_privilege(t1.oid,'trigger')
from (select oid from pg_class where relname = 'pg_class') as t1;
select has_table_privilege(current_user,'atest1','select');
select has_table_privilege(current_user,'atest1','insert');
select has_table_privilege(t2.oid,'atest1','update')
from (select oid from pg_roles where rolname = current_user) as t2;
select has_table_privilege(t2.oid,'atest1','delete')
from (select oid from pg_roles where rolname = current_user) as t2;
select has_table_privilege(current_user,t1.oid,'references')
from (select oid from pg_class where relname = 'atest1') as t1;
select has_table_privilege(t2.oid,t1.oid,'select')
from (select oid from pg_class where relname = 'atest1') as t1,
(select oid from pg_roles where rolname = current_user) as t2;
select has_table_privilege(t2.oid,t1.oid,'insert')
from (select oid from pg_class where relname = 'atest1') as t1,
(select oid from pg_roles where rolname = current_user) as t2;
select has_table_privilege('atest1','update');
select has_table_privilege('atest1','delete');
select has_table_privilege('atest1','truncate');
select has_table_privilege(t1.oid,'select')
from (select oid from pg_class where relname = 'atest1') as t1;
select has_table_privilege(t1.oid,'trigger')
from (select oid from pg_class where relname = 'atest1') as t1;
SET SESSION AUTHORIZATION regressuser1 PASSWORD 'gauss@123';
CREATE TABLE atest4 (a int);
GRANT SELECT ON atest4 TO regressuser2 WITH GRANT OPTION;
GRANT UPDATE ON atest4 TO regressuser2;
GRANT SELECT ON atest4 TO GROUP regressgroup1 WITH GRANT OPTION;
SET SESSION AUTHORIZATION regressuser2 PASSWORD 'gauss@123';
GRANT SELECT ON atest4 TO regressuser3;
GRANT UPDATE ON atest4 TO regressuser3;
SET SESSION AUTHORIZATION regressuser1 PASSWORD 'gauss@123';
REVOKE SELECT ON atest4 FROM regressuser3;
SELECT has_table_privilege('regressuser3', 'atest4', 'SELECT');
REVOKE SELECT ON atest4 FROM regressuser2;
REVOKE GRANT OPTION FOR SELECT ON atest4 FROM regressuser2 CASCADE;
SELECT has_table_privilege('regressuser2', 'atest4', 'SELECT');
SELECT has_table_privilege('regressuser3', 'atest4', 'SELECT');
SELECT has_table_privilege('regressuser1', 'atest4', 'SELECT WITH GRANT OPTION');
\c -
CREATE SEQUENCE x_seq;
GRANT USAGE on x_seq to regressuser2;
SELECT has_sequence_privilege('regressuser1', 'atest1', 'SELECT');
SELECT has_sequence_privilege('regressuser1', 'x_seq', 'INSERT');
SELECT has_sequence_privilege('regressuser1', 'x_seq', 'SELECT');
SET SESSION AUTHORIZATION regressuser2 PASSWORD 'gauss@123';
SET search_path TO public;
SELECT has_sequence_privilege('x_seq', 'USAGE');
\c -
SET SESSION AUTHORIZATION regressuser1 PASSWORD 'gauss@123';
SET search_path TO public;
SELECT lo_create(1001);
SELECT lo_create(1002);
SELECT lo_create(1003);
SELECT lo_create(1004);
SELECT lo_create(1005);
GRANT ALL ON LARGE OBJECT 1001 TO PUBLIC;
GRANT SELECT ON LARGE OBJECT 1003 TO regressuser2;
GRANT SELECT,UPDATE ON LARGE OBJECT 1004 TO regressuser2;
GRANT ALL ON LARGE OBJECT 1005 TO regressuser2;
GRANT SELECT ON LARGE OBJECT 1005 TO regressuser2 WITH GRANT OPTION;
GRANT SELECT, INSERT ON LARGE OBJECT 1001 TO PUBLIC;
GRANT SELECT, UPDATE ON LARGE OBJECT 1001 TO nosuchuser;
GRANT SELECT, UPDATE ON LARGE OBJECT 999 TO PUBLIC;
\c -
SET SESSION AUTHORIZATION regressuser2 PASSWORD 'gauss@123';
SET search_path TO public;
SELECT lo_create(2001);
SELECT lo_create(2002);
SELECT loread(lo_open(1001, x'40000'::int), 32);
SELECT loread(lo_open(1002, x'40000'::int), 32);
SELECT loread(lo_open(1003, x'40000'::int), 32);
SELECT loread(lo_open(1004, x'40000'::int), 32);
SELECT lowrite(lo_open(1001, x'20000'::int), 'abcd');
SELECT lowrite(lo_open(1002, x'20000'::int), 'abcd');
SELECT lowrite(lo_open(1003, x'20000'::int), 'abcd');
SELECT lowrite(lo_open(1004, x'20000'::int), 'abcd');
GRANT SELECT ON LARGE OBJECT 1005 TO regressuser3;
GRANT UPDATE ON LARGE OBJECT 1006 TO regressuser3;
REVOKE ALL ON LARGE OBJECT 2001, 2002 FROM PUBLIC;
GRANT ALL ON LARGE OBJECT 2001 TO regressuser3;
SELECT lo_unlink(1001);
SELECT lo_unlink(2002);
\c -
SELECT oid, pg_get_userbyid(lomowner) ownername, lomacl FROM pg_largeobject_metadata;
SET SESSION AUTHORIZATION regressuser3 PASSWORD 'gauss@123';
SET search_path TO public;
SELECT loread(lo_open(1001, x'40000'::int), 32);
SELECT loread(lo_open(1003, x'40000'::int), 32);
SELECT loread(lo_open(1005, x'40000'::int), 32);
SELECT lo_truncate(lo_open(1005, x'20000'::int), 10);
SELECT lo_truncate(lo_open(2001, x'20000'::int), 10);
\c -
SET lo_compat_privileges = false;
SET SESSION AUTHORIZATION regressuser4 PASSWORD 'gauss@123';
SET search_path TO public;
SELECT loread(lo_open(1002, x'40000'::int), 32);
SELECT lowrite(lo_open(1002, x'20000'::int), 'abcd');
SELECT lo_truncate(lo_open(1002, x'20000'::int), 10);
SELECT lo_unlink(1002);
SELECT lo_export(1001, '/dev/null');
\c -
SET lo_compat_privileges = true;
SET SESSION AUTHORIZATION regressuser4 PASSWORD 'gauss@123';
SET search_path TO public;
SELECT loread(lo_open(1002, x'40000'::int), 32);
SELECT lowrite(lo_open(1002, x'20000'::int), 'abcd');
SELECT lo_truncate(lo_open(1002, x'20000'::int), 10);
SELECT lo_unlink(1002);
SELECT lo_export(1001, '/dev/null');
\c -
SELECT * FROM pg_largeobject LIMIT 0;
SET SESSION AUTHORIZATION regressuser1 PASSWORD 'gauss@123';
SET search_path TO public;
SELECT * FROM pg_largeobject LIMIT 0;
\c -
CREATE SCHEMA testns;
GRANT ALL ON SCHEMA testns TO regressuser1;
CREATE TABLE testns.acltest1 (x int);
SELECT has_table_privilege('regressuser1', 'testns.acltest1', 'SELECT');
SELECT has_table_privilege('regressuser1', 'testns.acltest1', 'INSERT');
ALTER DEFAULT PRIVILEGES IN SCHEMA testns GRANT SELECT ON TABLES TO public;
SELECT has_table_privilege('regressuser1', 'testns.acltest1', 'SELECT');
SELECT has_table_privilege('regressuser1', 'testns.acltest1', 'INSERT');
DROP TABLE testns.acltest1;
CREATE TABLE testns.acltest1 (x int);
SELECT has_table_privilege('regressuser1', 'testns.acltest1', 'SELECT');
SELECT has_table_privilege('regressuser1', 'testns.acltest1', 'INSERT');
ALTER DEFAULT PRIVILEGES IN SCHEMA testns GRANT INSERT ON TABLES TO regressuser1;
DROP TABLE testns.acltest1;
CREATE TABLE testns.acltest1 (x int);
SELECT has_table_privilege('regressuser1', 'testns.acltest1', 'SELECT');
SELECT has_table_privilege('regressuser1', 'testns.acltest1', 'INSERT');
ALTER DEFAULT PRIVILEGES IN SCHEMA testns REVOKE INSERT ON TABLES FROM regressuser1;
DROP TABLE testns.acltest1;
CREATE TABLE testns.acltest1 (x int);
SELECT has_table_privilege('regressuser1', 'testns.acltest1', 'SELECT');
SELECT has_table_privilege('regressuser1', 'testns.acltest1', 'INSERT');
ALTER DEFAULT PRIVILEGES FOR ROLE regressuser1 REVOKE EXECUTE ON FUNCTIONS FROM public;
SET ROLE regressuser1 PASSWORD 'gauss@123';
CREATE FUNCTION testns.foo() RETURNS int AS 'select 1' LANGUAGE sql;
SELECT has_function_privilege('regressuser2', 'testns.foo()', 'EXECUTE');
ALTER DEFAULT PRIVILEGES IN SCHEMA testns GRANT EXECUTE ON FUNCTIONS to public;
DROP FUNCTION testns.foo();
CREATE FUNCTION testns.foo() RETURNS int AS 'select 1' LANGUAGE sql;
SELECT has_function_privilege('regressuser2', 'testns.foo()', 'EXECUTE');
DROP FUNCTION testns.foo();
ALTER DEFAULT PRIVILEGES FOR ROLE regressuser1 REVOKE USAGE ON TYPES FROM public;
CREATE DOMAIN testns.testdomain1 AS int;
SELECT has_type_privilege('regressuser2', 'testns.testdomain1', 'USAGE');
ALTER DEFAULT PRIVILEGES IN SCHEMA testns GRANT USAGE ON TYPES to public;
DROP DOMAIN testns.testdomain1;
CREATE DOMAIN testns.testdomain1 AS int;
SELECT has_type_privilege('regressuser2', 'testns.testdomain1', 'USAGE');
DROP DOMAIN testns.testdomain1;
RESET ROLE;
SELECT count(*)
FROM pg_default_acl d LEFT JOIN pg_namespace n ON defaclnamespace = n.oid
WHERE nspname = 'testns';
DROP SCHEMA testns CASCADE;
SELECT d.*
FROM pg_default_acl d LEFT JOIN pg_namespace n ON defaclnamespace = n.oid
WHERE nspname IS NULL AND defaclnamespace != 0;
\c -
CREATE SCHEMA testns;
CREATE TABLE testns.t1 (f1 int);
CREATE TABLE testns.t2 (f1 int);
SELECT has_table_privilege('regressuser1', 'testns.t1', 'SELECT');
GRANT ALL ON ALL TABLES IN SCHEMA testns TO regressuser1;
SELECT has_table_privilege('regressuser1', 'testns.t1', 'SELECT');
SELECT has_table_privilege('regressuser1', 'testns.t2', 'SELECT');
REVOKE ALL ON ALL TABLES IN SCHEMA testns FROM regressuser1;
SELECT has_table_privilege('regressuser1', 'testns.t1', 'SELECT');
SELECT has_table_privilege('regressuser1', 'testns.t2', 'SELECT');
CREATE FUNCTION testns.testfunc(int) RETURNS int AS 'select 3 * $1;' LANGUAGE sql;
SELECT has_function_privilege('regressuser1', 'testns.testfunc(int)', 'EXECUTE');
REVOKE ALL ON ALL FUNCTIONS IN SCHEMA testns FROM PUBLIC;
SELECT has_function_privilege('regressuser1', 'testns.testfunc(int)', 'EXECUTE');
SET client_min_messages TO 'warning';
DROP SCHEMA testns CASCADE;
RESET client_min_messages;
\c -
set session role regressuser1 PASSWORD 'gauss@123';
set search_path to public;
create table dep_priv_test (a int);
grant select on dep_priv_test to regressuser2 with grant option;
grant select on dep_priv_test to regressuser3 with grant option;
set session role regressuser2 PASSWORD 'gauss@123';
set search_path to public;
grant select on dep_priv_test to regressuser4 with grant option;
set session role regressuser3 PASSWORD 'gauss@123';
set search_path to public;
grant select on dep_priv_test to regressuser4 with grant option;
set session role regressuser4 PASSWORD 'gauss@123';
set search_path to public;
grant select on dep_priv_test to regressuser5;
\dp dep_priv_test
set session role regressuser2 PASSWORD 'gauss@123';
set search_path to public;
revoke select on dep_priv_test from regressuser4 cascade;
\dp dep_priv_test
set session role regressuser3 PASSWORD 'gauss@123';
set search_path to public;
revoke select on dep_priv_test from regressuser4 cascade;
\dp dep_priv_test
set session role regressuser1 PASSWORD 'gauss@123';
set search_path to public;
drop table dep_priv_test;
\c
drop sequence x_seq;
DROP FUNCTION testfunc2(int);
DROP FUNCTION testfunc4(boolean);
DROP VIEW atestv1;
DROP VIEW atestv2;
DROP VIEW atestv3 CASCADE;
DROP VIEW atestv4;
DROP TABLE atest1;
DROP TABLE atest2;
DROP TABLE atest3;
DROP TABLE atest4;
DROP TABLE atest5;
DROP TABLE atest6;
DROP TABLE atestc;
DROP TABLE atestp1;
DROP TABLE atestp2;
SELECT lo_unlink(oid) FROM pg_largeobject_metadata;
DROP GROUP regressgroup1;
DROP GROUP regressgroup2;
REVOKE USAGE ON LANGUAGE sql FROM regressuser1;
DROP OWNED BY regressuser1;
DROP USER regressuser1;
DROP USER regressuser2;
DROP USER regressuser3;
DROP USER regressuser4;
DROP USER regressuser5;
DROP USER regressuser6;
create role setrole_in_transaction password 'Gauss@123';
start transaction;
set role setrole_in_transaction password 'Gauss@123';
rollback;
drop role setrole_in_transaction;
create user sysadmin_user_001 sysadmin password 'Gauss@123';
create user sysadmin_user_002 sysadmin password 'Gauss@123';
create user createrole_user_001 createrole password 'Gauss@123';
create user createrole_user_002 createrole password 'Gauss@123';
create user audit_role_user_001 auditadmin password 'Gauss@123';
create user normalrole_user_001 password 'Gauss@123';
create user normalrole_user_002 password 'Gauss@123';
create resource pool test_user_pool1;
create resource pool test_user_pool2;
create resource pool test_user_pool3;
create resource pool test_user_pool4;
create resource pool test_user_pool5;
set role sysadmin_user_001 password 'Gauss@123';
alter role sysadmin_user_002 CREATEDB;
alter role sysadmin_user_002 CREATEROLE;
alter role sysadmin_user_002 NOINHERIT;
alter role sysadmin_user_002 AUDITADMIN;
alter role sysadmin_user_002 SYSADMIN;
alter role sysadmin_user_002 LOGIN;
alter role sysadmin_user_002 NOREPLICATION;
alter role sysadmin_user_002 CONNECTION LIMIT 10;
alter role sysadmin_user_002 identified by 'Gauss@12302' replace 'Gauss@123';
alter role sysadmin_user_002 valid begin '1111-11-11' valid until '2222-12-12';
alter role sysadmin_user_002 set session_timeout = '5min';
alter role sysadmin_user_002 ACCOUNT UNLOCK;
alter role sysadmin_user_002 RESOURCE POOL 'test_user_pool1';
alter role sysadmin_user_002 rename to normalrole_user_003;
reset role;
set role sysadmin_user_001 password 'Gauss@123';
alter role audit_role_user_001 CREATEDB;
alter role audit_role_user_001 CREATEROLE;
alter role audit_role_user_001 NOINHERIT;
alter role audit_role_user_001 AUDITADMIN;
alter role audit_role_user_001 SYSADMIN;
alter role audit_role_user_001 LOGIN;
alter role audit_role_user_001 NOREPLICATION;
alter role audit_role_user_001 CONNECTION LIMIT 10;
alter role audit_role_user_001 identified by 'Gauss@12302' replace 'Gauss@123';
alter role audit_role_user_001 valid begin '1111-11-11' valid until '2222-12-12';
alter role audit_role_user_001 set session_timeout = '5min';
alter role audit_role_user_001 ACCOUNT UNLOCK;
alter role audit_role_user_001 RESOURCE POOL 'test_user_pool2';
alter role audit_role_user_001 rename to normalrole_user_003;
reset role;
set role sysadmin_user_001 password 'Gauss@123';
alter role normalrole_user_001 CREATEDB;
alter role normalrole_user_001 CREATEROLE;
alter role normalrole_user_001 NOINHERIT;
alter role normalrole_user_001 AUDITADMIN;
alter role normalrole_user_001 SYSADMIN;
alter role normalrole_user_001 LOGIN;
alter role normalrole_user_001 NOREPLICATION;
alter role normalrole_user_001 CONNECTION LIMIT 10;
alter role normalrole_user_001 identified by 'Gauss@12302' replace 'Gauss@123';
alter role normalrole_user_001 valid begin '1111-11-11' valid until '2222-12-12';
alter role normalrole_user_001 set session_timeout = '5min';
alter role normalrole_user_001 ACCOUNT UNLOCK;
alter role normalrole_user_001 RESOURCE POOL 'test_user_pool3';
alter role normalrole_user_001 rename to normalrole_user_003;
reset role;
set role sysadmin_user_001 password 'Gauss@123';
alter role createrole_user_001 CREATEDB;
alter role createrole_user_001 CREATEROLE;
alter role createrole_user_001 NOINHERIT;
alter role createrole_user_001 AUDITADMIN;
alter role createrole_user_001 SYSADMIN;
alter role createrole_user_001 LOGIN;
alter role createrole_user_001 NOREPLICATION;
alter role createrole_user_001 CONNECTION LIMIT 10;
alter role createrole_user_001 identified by 'Gauss@12302' replace 'Gauss@123';
alter role createrole_user_001 valid begin '1111-11-11' valid until '2222-12-12';
alter role createrole_user_001 set session_timeout = '5min';
alter role createrole_user_001 ACCOUNT UNLOCK;
alter role createrole_user_001 RESOURCE POOL 'test_user_pool4';
alter role createrole_user_001 rename to normalrole_user_003;
reset role;
set role createrole_user_002 password 'Gauss@123';
alter role normalrole_user_002 CREATEDB;
alter role normalrole_user_002 CREATEROLE;
alter role normalrole_user_002 NOINHERIT;
alter role normalrole_user_002 AUDITADMIN;
alter role normalrole_user_002 SYSADMIN;
alter role normalrole_user_002 LOGIN;
alter role normalrole_user_002 NOREPLICATION;
alter role normalrole_user_002 CONNECTION LIMIT 10;
alter role normalrole_user_002 identified by 'Gauss@12302' replace 'Gauss@123';
alter role normalrole_user_002 valid begin '1111-11-11' valid until '2222-12-12';
alter role normalrole_user_002 set session_timeout = '5min';
alter role normalrole_user_002 ACCOUNT UNLOCK;
alter role normalrole_user_002 RESOURCE POOL 'test_user_pool5';
alter role normalrole_user_002 rename to normalrole_user_003;
reset role;
drop user sysadmin_user_001;
drop user sysadmin_user_002;
drop user createrole_user_001;
drop user createrole_user_002;
drop user audit_role_user_001;
drop user normalrole_user_001;
drop user normalrole_user_002;
drop user normalrole_user_003 cascade;
drop resource pool test_user_pool1;
drop resource pool test_user_pool2;
drop resource pool test_user_pool3;
drop resource pool test_user_pool4;
drop resource pool test_user_pool5;
create user role_analyze password 'gauss@123';
set session role role_analyze PASSWORD 'gauss@123';
create table test_analyze_priv(a int);
analyze test_analyze_priv;
insert into test_analyze_priv select generate_series(1, 100);
analyze test_analyze_priv;
execute direct on (coordinator2)'select * from pg_statistic';
analyze pg_database;
drop table test_analyze_priv;
reset role;
drop user role_analyze;
update pg_authid set relpassword='123';
insert into pg_authid values('along');
delete from pg_authid;
create user createrole_user01 with createrole password 'Gauss@123';
set role createrole_user01 password 'Gauss@123';
create user auditadmin_user02 with auditadmin password 'Gauss@123';
drop user auditadmin_user02;
reset role;
drop user createrole_user01;