mirror of https://github.com/citusdata/citus.git
52 lines
1.8 KiB
SQL
52 lines
1.8 KiB
SQL
CREATE SCHEMA metadata_sync_2pc_schema;
|
|
SET search_path TO metadata_sync_2pc_schema;
|
|
set citus.enable_create_database_propagation to on;
|
|
CREATE DATABASE metadata_sync_2pc_db;
|
|
|
|
\c metadata_sync_2pc_db
|
|
SHOW citus.main_db;
|
|
|
|
CREATE USER "grant_role2pc'_user1";
|
|
CREATE USER "grant_role2pc'_user2";
|
|
CREATE USER "grant_role2pc'_user3";
|
|
CREATE USER grant_role2pc_user4;
|
|
CREATE USER grant_role2pc_user5;
|
|
|
|
\c regression
|
|
select 1 from citus_remove_node('localhost', :worker_2_port);
|
|
|
|
\c metadata_sync_2pc_db
|
|
grant "grant_role2pc'_user1","grant_role2pc'_user2" to "grant_role2pc'_user3" WITH ADMIN OPTION;
|
|
grant "grant_role2pc'_user1","grant_role2pc'_user2" to grant_role2pc_user4,grant_role2pc_user5 granted by "grant_role2pc'_user3";
|
|
|
|
\c regression
|
|
select 1 from citus_add_node('localhost', :worker_2_port);
|
|
|
|
select result FROM run_command_on_all_nodes($$
|
|
SELECT array_to_json(array_agg(row_to_json(t)))
|
|
FROM (
|
|
SELECT member::regrole, roleid::regrole as role, grantor::regrole, admin_option
|
|
FROM pg_auth_members
|
|
WHERE member::regrole::text in
|
|
('"grant_role2pc''_user2"','"grant_role2pc''_user3"','grant_role2pc_user4','grant_role2pc_user5')
|
|
order by member::regrole::text
|
|
) t
|
|
$$);
|
|
|
|
\c metadata_sync_2pc_db
|
|
revoke "grant_role2pc'_user1","grant_role2pc'_user2" from grant_role2pc_user4,grant_role2pc_user5 granted by "grant_role2pc'_user3";
|
|
|
|
revoke admin option for "grant_role2pc'_user1","grant_role2pc'_user2" from "grant_role2pc'_user3";
|
|
|
|
revoke "grant_role2pc'_user1","grant_role2pc'_user2" from "grant_role2pc'_user3";
|
|
|
|
\c regression
|
|
|
|
drop user "grant_role2pc'_user1","grant_role2pc'_user2","grant_role2pc'_user3",grant_role2pc_user4,grant_role2pc_user5;
|
|
set citus.enable_create_database_propagation to on;
|
|
drop database metadata_sync_2pc_db;
|
|
drop schema metadata_sync_2pc_schema;
|
|
|
|
reset citus.enable_create_database_propagation;
|
|
reset search_path;
|