mirror of
https://github.com/ansible-collections/community.mysql.git
synced 2025-04-05 10:10:32 -07:00
mysql_role: fix and simplify role member detection (#368)
* mysql_role: fix and simplify role membership detection * add changelog fragment * Update changelogs/fragments/368-mysql_role-fix-member-detection.yml Co-authored-by: Andrew Klychkov <aaklychkov@mail.ru> Co-authored-by: Felix Hamme <felix.hamme@ionos.com> Co-authored-by: Andrew Klychkov <aaklychkov@mail.ru>
This commit is contained in:
parent
c489cf1a37
commit
07a72865f7
2 changed files with 11 additions and 44 deletions
|
@ -0,0 +1,6 @@
|
||||||
|
bugfixes:
|
||||||
|
- >
|
||||||
|
mysql_role - in some cases (when "SHOW GRANTS" did not use backticks for quotes), no unwanted members were detached
|
||||||
|
from the role (and redundant "GRANT" statements were executed for wanted members). This is fixed by querying the
|
||||||
|
existing role members from the mysql.role_edges (MySQL) or mysql.roles_mapping (MariaDB) tables instead of parsing
|
||||||
|
the "SHOW GRANTS" output (https://github.com/ansible-collections/community.mysql/pull/368).
|
|
@ -896,50 +896,11 @@ class Role():
|
||||||
Returns:
|
Returns:
|
||||||
set: Members.
|
set: Members.
|
||||||
"""
|
"""
|
||||||
members = set()
|
if self.is_mariadb:
|
||||||
|
self.cursor.execute('select user, host from mysql.roles_mapping where role = %s', (self.name,))
|
||||||
for user, host in self.server.get_users():
|
else:
|
||||||
# Don't handle itself
|
self.cursor.execute('select TO_USER as user, TO_HOST as host from mysql.role_edges where FROM_USER = %s', (self.name,))
|
||||||
if user == self.name and host == self.host:
|
return set(self.cursor.fetchall())
|
||||||
continue
|
|
||||||
|
|
||||||
grants = self.server.get_grants(user, host)
|
|
||||||
|
|
||||||
if self.__is_member(grants):
|
|
||||||
members.add((user, host))
|
|
||||||
|
|
||||||
return members
|
|
||||||
|
|
||||||
def __is_member(self, grants):
|
|
||||||
"""Check if a user / role is a member of a role.
|
|
||||||
|
|
||||||
To check if a user is a member of a role,
|
|
||||||
we parse their grants looking for the role name in them.
|
|
||||||
In the following grants, we can see that test@% is a member of readers.
|
|
||||||
+---------------------------------------------------+
|
|
||||||
| Grants for test@% |
|
|
||||||
+---------------------------------------------------+
|
|
||||||
| GRANT SELECT, INSERT, UPDATE ON *.* TO `test`@`%` |
|
|
||||||
| GRANT ALL PRIVILEGES ON `mysql`.* TO `test`@`%` |
|
|
||||||
| GRANT INSERT ON `mysql`.`user` TO `test`@`%` |
|
|
||||||
| GRANT `readers`@`%` TO `test`@`%` |
|
|
||||||
+---------------------------------------------------+
|
|
||||||
|
|
||||||
Args:
|
|
||||||
grants (list): Grants of a user to parse.
|
|
||||||
|
|
||||||
Returns:
|
|
||||||
bool: True if the self.full_name has been found in grants,
|
|
||||||
otherwise returns False.
|
|
||||||
"""
|
|
||||||
if not grants:
|
|
||||||
return False
|
|
||||||
|
|
||||||
for grant in grants:
|
|
||||||
if self.full_name in grant[0]:
|
|
||||||
return True
|
|
||||||
|
|
||||||
return False
|
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
|
|
Loading…
Add table
Reference in a new issue