-
Notifications
You must be signed in to change notification settings - Fork 89
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
mysql_user idempotency issue with REQUIRESSL and ALL privileges #89
Comments
@kkeane thanks for reporting this! There was significant work done related to SSL during the recent months by @Jorge-Rodriguez. Alternatively, 2.9 supports collections. You can get the latest collection tarbal from Galaxy. How to install and use it, see this (official) guide. Waiting for your feedback! |
@kkeane the Waiting for your feedback. |
@Andersson007 we've seen other bugs related to three |
@Jorge-Rodriguez good question:) I''m not a great user of mysql and ssl related options. Does it impliy any breaking changes? |
Done carefully, it shouldn't be a breaking change, although personally, I'd like to deprecate the old |
First, thank you for pointing me to the latest community version of community.mysql . I installed it (version 1.2.0) but am not sure how to verify that this is actually being used.
Switching to the tls_requires attribute works correctly, but the mysql_user module still always reports changed.
Here are all the arguments I'm passing to the module_args (collected with --vvv)
changed: [redacted] => (item=redacted) => {
"ansible_loop_var": "item",
"changed": true,
"invocation": {
"module_args": {
"append_privs": false,
"ca_cert": null,
"check_hostname": null,
"check_implicit_admin": false,
"client_cert": null,
"client_key": null,
"config_file": "/root/.my.cnf",
"connect_timeout": 30,
"encrypted": false,
"host": "redacted",
"host_all": false,
"login_host": "localhost",
"login_password": null,
"login_port": 3306,
"login_unix_socket": null,
"login_user": "root",
"name": "redacted",
"password": "VALUE_SPECIFIED_IN_NO_LOG_PARAMETER",
"plugin": null,
"plugin_auth_string": null,
"plugin_hash_string": null,
"priv": "redacted.*:ALL",
"resource_limits": null,
"sql_log_bin": true,
"state": "present",
"tls_requires": {
"SSL": null
},
"update_password": "always",
"user": "redacted"
}
},
"item": "redacted",
"msg": "Privileges updated",
"user": "redacted"
}
And here are the grants for the same user as MariaSQL actually sees it.
MariaDB [(none)]> show grants for redacted@'redacted';
+-------------------------------------------------------------------------------------------+
| Grants for redacted@redacted |
+-------------------------------------------------------------------------------------------+
| GRANT USAGE ON *.* TO `redacted`@`redacted` IDENTIFIED BY PASSWORD 'redacted' REQUIRE SSL |
| GRANT ALL PRIVILEGES ON `redacted`.* TO `redacted`@`redacted` |
+-------------------------------------------------------------------------------------------+
2 rows in set (0.001 sec)
Sent with [ProtonMail](https://protonmail.com) Secure Email.
‐‐‐‐‐‐‐ Original Message ‐‐‐‐‐‐‐
…On Friday, January 15, 2021 2:59 AM, Andrew Klychkov ***@***.***> wrote:
***@***.***(https://github.com/kkeane) thanks for reporting this!
Could you please try this using Ansible 2.10.5?
There was significant work done related to SSL during the recent months by ***@***.***(https://github.com/Jorge-Rodriguez).
Alternatively, 2.9 supports collections. You can get the latest collection tarbal from [Galaxy](https://galaxy.ansible.com/community/mysql). How to install and use it, see this (official) [guide](https://docs.ansible.com/ansible/latest/user_guide/collections_using.html).
Waiting for your feedback!
—
You are receiving this because you were mentioned.
Reply to this email directly, [view it on GitHub](#89 (comment)), or [unsubscribe](https://github.com/notifications/unsubscribe-auth/AABY5OVN5M5U7RPSMSNAZUDS2ANXXANCNFSM4WBYVWOQ).
|
@kkeane thanks for the feedback! As far as I remember there's a similar issue related to reporting changed=True when using |
Thank you! I did use the FQCN, so we know it was a community version, but in this case knowing that is not enough. RedHat's Ansible 2.9 ships with the community version as well, but that would be an older version. I believe the RedHat version does not include the tls_requires attribute, so most likely I used the correct version - I just can't guarantee it.
My issue is different from #77. For one, I'm using MariaDB 10.5. For another,unlike what's described in that issue, MariaDB does report "ALL PRIVILEGES" in the show grants output (the exact output is included upthread).
Sent with [ProtonMail](https://protonmail.com) Secure Email.
‐‐‐‐‐‐‐ Original Message ‐‐‐‐‐‐‐
…On Friday, February 12, 2021 2:27 AM, Andrew Klychkov ***@***.***> wrote:
***@***.***(https://github.com/kkeane) thanks for the feedback!
For information: you can be sure that your playbook uses community.mysql by using a fully qualified collection name (FQCN), i.e. change mysql_user: to community.mysql.mysql_user: (and other modules invocations similarly).
As far as I remember there's a similar issue related to reporting changed=True when using ALL, [#77](#77) , the issue author explains why.
If anyone decides to fix this (if it's technically possible), I'd be happy to review.
—
You are receiving this because you were mentioned.
Reply to this email directly, [view it on GitHub](#89 (comment)), or [unsubscribe](https://github.com/notifications/unsubscribe-auth/AABY5OWG6UHB7SAA6THQNXLS6T7BJANCNFSM4WBYVWOQ).
|
@kkeane thank you so much for the info, it's very valuable. This is still an important issue and it's high on my priority list, but I won't be providing a fix just yet. I'm the meanwhile, whatever extra information you can gather is greatly appreciated. |
Completely agreed with your prioritization. This is not a showstopper, and I lived with it for months before I even filed the issue.
Sent with [ProtonMail](https://protonmail.com) Secure Email.
‐‐‐‐‐‐‐ Original Message ‐‐‐‐‐‐‐
…On Friday, February 12, 2021 8:57 AM, Jorge Rodriguez (A.K.A. Tiriel) ***@***.***> wrote:
***@***.***(https://github.com/kkeane) thank you so much for the info, it's very valuable.
The bad news is I won't be taking this issue immediately. Since it seems to involve discrepancies with MariaDB, I feel it makes more sense to handle the MariaDB refactor first.
This is still an important issue and it's high on my priority list, but I won't be providing a fix just yet.
I'm the meanwhile, whatever extra information you can gather is greatly appreciated.
—
You are receiving this because you were mentioned.
Reply to this email directly, [view it on GitHub](#89 (comment)), or [unsubscribe](https://github.com/notifications/unsubscribe-auth/AABY5OTOMKXD5RPNY3AJJR3S6VMYVANCNFSM4WBYVWOQ).
|
One more update:
It appears that the REQUIRESSL issue might well be fixed with tls_requires, and that my current problem could be a separate one. Again, not a showstopper for me.
The module will also always report "changed" when I create a backup user with the following privileges and no tls_requirements attribute: I have a feeling that trying to chase down all the various possible combinations of permissions is a game of whack-a-mole; you have my sympathy.
"priv": "*.*:SELECT,LOCK TABLES,RELOAD,SHOW VIEW,REPLICATION CLIENT,EVENT,TRIGGER"
Output of "show grants" for that user shows that "REPLICATION CLIENT" is replaced with "BINLOG MONITOR"
GRANT SELECT, RELOAD, LOCK TABLES, BINLOG MONITOR, SHOW VIEW, EVENT, TRIGGER ON *.* TO `redacted` IDENTIFIED BY PASSWORD
Sent with [ProtonMail](https://protonmail.com) Secure Email.
‐‐‐‐‐‐‐ Original Message ‐‐‐‐‐‐‐
…On Friday, February 12, 2021 8:57 AM, Jorge Rodriguez (A.K.A. Tiriel) ***@***.***> wrote:
***@***.***(https://github.com/kkeane) thank you so much for the info, it's very valuable.
The bad news is I won't be taking this issue immediately. Since it seems to involve discrepancies with MariaDB, I feel it makes more sense to handle the MariaDB refactor first.
This is still an important issue and it's high on my priority list, but I won't be providing a fix just yet.
I'm the meanwhile, whatever extra information you can gather is greatly appreciated.
—
You are receiving this because you were mentioned.
Reply to this email directly, [view it on GitHub](#89 (comment)), or [unsubscribe](https://github.com/notifications/unsubscribe-auth/AABY5OTOMKXD5RPNY3AJJR3S6VMYVANCNFSM4WBYVWOQ).
|
@kkeane we're dropping support for I would appreciate if you could verify whether this bug appears on your setup with the new code. I'll tag you and this issue on the PR. |
SUMMARY
There is an idempotency mismatch for certain privilege specifications. This probably happens because the names of certain privileges do not exactly match the names used by the database. See Ansible bug #29625 (which is not actually resolved for these cases).
Specific examples I found (for MariaDB 10.5)
ISSUE TYPE
COMPONENT NAME
mysql_user
ANSIBLE VERSION
CONFIGURATION
OS / ENVIRONMENT
Target OS: RHEL 8.3. MariaDB 10.5.8, installed from the MariaDB repository.
Also observed on some older versions of mysql.
Python 3.6.8 on the target.
STEPS TO REPRODUCE
(Note: derived from the actual playbook, but not tested verbatim)
EXPECTED RESULTS
On first run, the task may report changed.
On subsequent runs, the task should report unchanged.
After changing "REQUIRESSL" to "REQUIRE SSL", the same behavior should occur.
ACTUAL RESULTS
The task reports as changed on every run.
The task produces an error when changing REQUIRESSL to "REQUIRE SSL"
Changing the string "REQUIRESSL" to "REQUIRE SSL" results in:
The underlying problem here is probably that the SHOW GRANTS and GRANT USAGE commands use the syntax "REQUIRE SSL" while the module only accepts "REQUIRESSL".
Modified test case: changing the privileges to "redactedb.*:ALL" (without REQUIRESSL) also results in the task reporting "changed" on every run.
The text was updated successfully, but these errors were encountered: