postgresql_owner: use query_params with cursor (#65310)
* postgresql_owner: use query_params with cursor * add changelog fragment
This commit is contained in:
parent
8d6192d61e
commit
6ae01d4fbd
3 changed files with 26 additions and 18 deletions
|
@ -0,0 +1,2 @@
|
||||||
|
bugfixes:
|
||||||
|
- postgresql_owner - use query_params with cursor object (https://github.com/ansible/ansible/pull/65310).
|
|
@ -275,49 +275,51 @@ class PgOwnership(object):
|
||||||
def __is_owner(self):
|
def __is_owner(self):
|
||||||
"""Return True if self.role is the current object owner."""
|
"""Return True if self.role is the current object owner."""
|
||||||
if self.obj_type == 'table':
|
if self.obj_type == 'table':
|
||||||
query = ("SELECT 1 FROM pg_tables WHERE tablename = '%s' "
|
query = ("SELECT 1 FROM pg_tables "
|
||||||
"AND tableowner = '%s'" % (self.obj_name, self.role))
|
"WHERE tablename = %(obj_name)s "
|
||||||
|
"AND tableowner = %(role)s")
|
||||||
|
|
||||||
elif self.obj_type == 'database':
|
elif self.obj_type == 'database':
|
||||||
query = ("SELECT 1 FROM pg_database AS d "
|
query = ("SELECT 1 FROM pg_database AS d "
|
||||||
"JOIN pg_roles AS r ON d.datdba = r.oid "
|
"JOIN pg_roles AS r ON d.datdba = r.oid "
|
||||||
"WHERE d.datname = '%s' "
|
"WHERE d.datname = %(obj_name)s "
|
||||||
"AND r.rolname = '%s'" % (self.obj_name, self.role))
|
"AND r.rolname = %(role)s")
|
||||||
|
|
||||||
elif self.obj_type == 'function':
|
elif self.obj_type == 'function':
|
||||||
query = ("SELECT 1 FROM pg_proc AS f "
|
query = ("SELECT 1 FROM pg_proc AS f "
|
||||||
"JOIN pg_roles AS r ON f.proowner = r.oid "
|
"JOIN pg_roles AS r ON f.proowner = r.oid "
|
||||||
"WHERE f.proname = '%s' "
|
"WHERE f.proname = %(obj_name)s "
|
||||||
"AND r.rolname = '%s'" % (self.obj_name, self.role))
|
"AND r.rolname = %(role)s")
|
||||||
|
|
||||||
elif self.obj_type == 'sequence':
|
elif self.obj_type == 'sequence':
|
||||||
query = ("SELECT 1 FROM pg_class AS c "
|
query = ("SELECT 1 FROM pg_class AS c "
|
||||||
"JOIN pg_roles AS r ON c.relowner = r.oid "
|
"JOIN pg_roles AS r ON c.relowner = r.oid "
|
||||||
"WHERE c.relkind = 'S' AND c.relname = '%s' "
|
"WHERE c.relkind = 'S' AND c.relname = %(obj_name)s "
|
||||||
"AND r.rolname = '%s'" % (self.obj_name, self.role))
|
"AND r.rolname = %(role)s")
|
||||||
|
|
||||||
elif self.obj_type == 'schema':
|
elif self.obj_type == 'schema':
|
||||||
query = ("SELECT 1 FROM information_schema.schemata "
|
query = ("SELECT 1 FROM information_schema.schemata "
|
||||||
"WHERE schema_name = '%s' "
|
"WHERE schema_name = %(obj_name)s "
|
||||||
"AND schema_owner = '%s'" % (self.obj_name, self.role))
|
"AND schema_owner = %(role)s")
|
||||||
|
|
||||||
elif self.obj_type == 'tablespace':
|
elif self.obj_type == 'tablespace':
|
||||||
query = ("SELECT 1 FROM pg_tablespace AS t "
|
query = ("SELECT 1 FROM pg_tablespace AS t "
|
||||||
"JOIN pg_roles AS r ON t.spcowner = r.oid "
|
"JOIN pg_roles AS r ON t.spcowner = r.oid "
|
||||||
"WHERE t.spcname = '%s' "
|
"WHERE t.spcname = %(obj_name)s "
|
||||||
"AND r.rolname = '%s'" % (self.obj_name, self.role))
|
"AND r.rolname = %(role)s")
|
||||||
|
|
||||||
elif self.obj_type == 'view':
|
elif self.obj_type == 'view':
|
||||||
query = ("SELECT 1 FROM pg_views "
|
query = ("SELECT 1 FROM pg_views "
|
||||||
"WHERE viewname = '%s' "
|
"WHERE viewname = %(obj_name)s "
|
||||||
"AND viewowner = '%s'" % (self.obj_name, self.role))
|
"AND viewowner = %(role)s")
|
||||||
|
|
||||||
elif self.obj_type == 'matview':
|
elif self.obj_type == 'matview':
|
||||||
query = ("SELECT 1 FROM pg_matviews "
|
query = ("SELECT 1 FROM pg_matviews "
|
||||||
"WHERE matviewname = '%s' "
|
"WHERE matviewname = %(obj_name)s "
|
||||||
"AND matviewowner = '%s'" % (self.obj_name, self.role))
|
"AND matviewowner = %(role)s")
|
||||||
|
|
||||||
return exec_sql(self, query, add_to_executed=False)
|
query_params = {'obj_name': self.obj_name, 'role': self.role}
|
||||||
|
return exec_sql(self, query, query_params, add_to_executed=False)
|
||||||
|
|
||||||
def __set_db_owner(self):
|
def __set_db_owner(self):
|
||||||
"""Set the database owner."""
|
"""Set the database owner."""
|
||||||
|
@ -369,7 +371,9 @@ class PgOwnership(object):
|
||||||
|
|
||||||
def __role_exists(self, role):
|
def __role_exists(self, role):
|
||||||
"""Return True if role exists, otherwise return False."""
|
"""Return True if role exists, otherwise return False."""
|
||||||
return exec_sql(self, "SELECT 1 FROM pg_roles WHERE rolname = '%s'" % role, add_to_executed=False)
|
query_params = {'role': role}
|
||||||
|
query = "SELECT 1 FROM pg_roles WHERE rolname = %(role)s"
|
||||||
|
return exec_sql(self, query, query_params, add_to_executed=False)
|
||||||
|
|
||||||
|
|
||||||
# ===========================================
|
# ===========================================
|
||||||
|
|
|
@ -1,2 +1,4 @@
|
||||||
# Initial CI tests of postgresql_owner module
|
# Initial CI tests of postgresql_owner module
|
||||||
- import_tasks: postgresql_owner_initial.yml
|
- import_tasks: postgresql_owner_initial.yml
|
||||||
|
when:
|
||||||
|
- postgres_version_resp.stdout is version('9.4', '>=')
|
||||||
|
|
Loading…
Reference in a new issue