Skip to content
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

Reset keys when they change or Splunk secret changes #98

Open
peterchenadded opened this issue Sep 10, 2021 · 2 comments
Open

Reset keys when they change or Splunk secret changes #98

peterchenadded opened this issue Sep 10, 2021 · 2 comments
Assignees
Labels
question Further information is requested

Comments

@peterchenadded
Copy link

At the moment changing Splunk.secret will break everything and rerunning ansible playbook will always force configs to be updated and splunk restarted even though the password values are exactly the same.

Should update the tasks related to passwords to do the following

  1. Run a shell command that
  • runs btool to get the value for the key
  • if value is empty exit 1
  • elif value starts with $ use show-decrypted command to decrypt it and return value
  • else return value
  • register the value into pass_result
  1. Run a ini_file
  • run only when pass_result not same as password in inventory
  • set the password

This should auto update password if it or Splunk.secret has changed.

@mason-splunk
Copy link
Contributor

mason-splunk commented Sep 14, 2021

The role does not currently support changing the splunk.secret file because as you found out, the splunk.secret file is used in the password hashing process for several different passwords. The role provides the configure splunk.secret option in case you want to use a common splunk.secret file across several hosts during a new installation, which allows you to deploy pre-hashed passwords that are in your VCS via configure_apps.yml. This practice is what we recommend to deploy passwords securely across multiple Splunk hosts. See: https://docs.splunk.com/Documentation/Splunk/8.2.2/Security/Deploysecurepasswordsacrossmultipleservers

The issue that you encountered is also why the configure_splunk_secret.yml task is only called during install_splunk.yml and not during upgrade_splunk.yml - because changing splunk.secret without also updating the passwords in the .conf files and restarting splunk will cause password decryption errors.

Can I ask what your use case is for changing splunk.secret after installation?

Your suggested workaround for the issue could work if we wanted to add a new task specifically for rotating splunk.secret but shouldn't be necessary for something like a password rotation. It's also not safe for us to assume that everyone is using Ansible to manage the passwords in their configuration files, since as I mentioned earlier, you can pre-hash the password in the config files, and then deploy the configs as part of an app. So, in that scenario, there is no variable storing the password in Ansible to compare the decrypted output against.

@mason-splunk mason-splunk self-assigned this Sep 14, 2021
@mason-splunk mason-splunk added the question Further information is requested label Sep 14, 2021
@peterchenadded
Copy link
Author

Thanks for the detailed response @mason-splunk

The use cases are below

  1. People want to use different secrets on different servers - better security
  2. The secret is exposed and everything needs to be rotated - at the moment it is tedious as would need to manually re-encrypt everything
  3. People that want to store the plain text password using ansible vault. This would already be the case for splunk.secret and admin password.

Current logic is really only for those using a single secret and storing the prehashed password in ansible.

Actually the plain text password is also needed for below command to work (test in Splunk 8.0.7)

  1. splunk edit cluster-config -mode slave

It seems to be trying to connect to the master with the hashed password.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
question Further information is requested
Projects
None yet
Development

No branches or pull requests

2 participants