CDB_Group_RenameGroup_API
This commit is contained in:
parent
99641b827c
commit
566adfb0ce
@ -33,8 +33,14 @@ $$ LANGUAGE PLPGSQL VOLATILE;
|
|||||||
CREATE OR REPLACE
|
CREATE OR REPLACE
|
||||||
FUNCTION cartodb.CDB_Group_RenameGroup(old_group_name text, new_group_name text)
|
FUNCTION cartodb.CDB_Group_RenameGroup(old_group_name text, new_group_name text)
|
||||||
RETURNS VOID AS $$
|
RETURNS VOID AS $$
|
||||||
|
DECLARE
|
||||||
|
old_group_role TEXT;
|
||||||
|
new_group_role TEXT;
|
||||||
BEGIN
|
BEGIN
|
||||||
EXECUTE format('ALTER ROLE "%s" RENAME TO "%s"', cartodb._CDB_Group_GroupRole(old_group_name), cartodb._CDB_Group_GroupRole(new_group_name));
|
old_group_role = cartodb._CDB_Group_GroupRole(old_group_name);
|
||||||
|
new_group_role = cartodb._CDB_Group_GroupRole(new_group_name);
|
||||||
|
EXECUTE format('ALTER ROLE "%s" RENAME TO "%s"', old_group_role, new_group_role);
|
||||||
|
PERFORM cartodb._CDB_Group_RenameGroup_API(current_database(), old_group_name, new_group_name, new_group_role);
|
||||||
END
|
END
|
||||||
$$ LANGUAGE PLPGSQL VOLATILE;
|
$$ LANGUAGE PLPGSQL VOLATILE;
|
||||||
|
|
||||||
|
@ -46,6 +46,29 @@ $$
|
|||||||
raise err
|
raise err
|
||||||
$$ LANGUAGE 'plpythonu' VOLATILE;
|
$$ LANGUAGE 'plpythonu' VOLATILE;
|
||||||
|
|
||||||
|
CREATE OR REPLACE
|
||||||
|
FUNCTION cartodb._CDB_Group_RenameGroup_API(database_name text, old_group_name text, new_group_name text, new_group_role text)
|
||||||
|
RETURNS VOID AS
|
||||||
|
$$
|
||||||
|
import httplib
|
||||||
|
import string
|
||||||
|
|
||||||
|
try:
|
||||||
|
params = plpy.execute("select c.host, c.port, c.timeout, c.auth from cartodb._CDB_Group_API_Conf() c;")[0]
|
||||||
|
if params['host'] is None:
|
||||||
|
return
|
||||||
|
|
||||||
|
client = httplib.HTTPConnection(params['host'], params['port'], False, params['timeout'])
|
||||||
|
body = '{ "name": "%s", "database_role": "%s" }' % (new_group_name, new_group_role)
|
||||||
|
headers = { 'Authorization': params['auth'], 'Content-Type': 'application/json' }
|
||||||
|
client.request('PUT', '/api/v1/databases/%s/groups/%s' % (database_name, old_group_name), body, headers)
|
||||||
|
response = client.getresponse()
|
||||||
|
assert response.status == 200
|
||||||
|
except Exception as err:
|
||||||
|
plpy.warning('group creation error: ' + str(err))
|
||||||
|
raise err
|
||||||
|
$$ LANGUAGE 'plpythonu' VOLATILE;
|
||||||
|
|
||||||
DO LANGUAGE 'plpgsql' $$
|
DO LANGUAGE 'plpgsql' $$
|
||||||
BEGIN
|
BEGIN
|
||||||
DROP FUNCTION IF EXISTS cartodb._CDB_Group_API_Conf();
|
DROP FUNCTION IF EXISTS cartodb._CDB_Group_API_Conf();
|
||||||
|
Loading…
Reference in New Issue
Block a user