Skip to content

Commit

Permalink
Converge quorum member auth
Browse files Browse the repository at this point in the history
The current code for authenticating to quorum members generates a
change event for every puppet run due to the exec having not being
`refreshonly` or having any conditionals. This cases the pcsd tokens
file to be updated regularly as well.

The proposed change splits up the authentication so that it's done
once per quorum member, rather than doing them all in one go. It
also adds a conditional check to see if any authentication token
is already present in the pcsd tokens file, and skips the exec if so.

This is convergent, but comes with two minor costs:
- if quorum member hostnames overlap (e.g. `foo` and `foobar`),
  then the condition will match perhaps incorrectly and one
  hostname may not get added
- If for any reason the authentication token becomes invalid,
  puppet will not correct it, and manual intervention will be
  required (in the form of a `pcs cluster auth` or `pcs host auth`
  command)

A `pcs host deauth` command would be handled correctly, and puppet
would do a corrective re-auth.

Fixes voxpupuli#500
  • Loading branch information
optiz0r committed Jun 28, 2022
1 parent 5f48a6c commit 3a30432
Showing 1 changed file with 13 additions and 14 deletions.
27 changes: 13 additions & 14 deletions manifests/init.pp
Original file line number Diff line number Diff line change
Expand Up @@ -589,25 +589,24 @@
# list the members to join.
# TODO - verify that this is safe when quorum_members is a list of IP
# addresses
$node_string = join($quorum_members, ' ')

# Define the pcs host command, this changed with 0.10.0 as per #513
$pcs_auth_command = versioncmp($pcs_version, '0.10.0') ? {
-1 => 'pcs cluster auth',
default => 'pcs host auth',
}

# Attempt to authorize all members. The command will return successfully
# if they were already authenticated so it's safe to run every time this
# is applied.
# TODO - make it run only once
exec { 'authorize_members':
command => "${pcs_auth_command} ${node_string} ${auth_credential_string}",
path => $exec_path,
require => [
Service['pcsd'],
User['hacluster'],
],
# Attempt to authorize each member
$quorum_members.each |$node| {
exec { "authorize_member_${node}":
command => "${pcs_auth_command} ${node} ${auth_credential_string}",
unless => "grep '${node}' /var/lib/pcsd/tokens",
path => $exec_path,
require => [
Service['pcsd'],
User['hacluster'],
],
}
}
}

Expand Down Expand Up @@ -636,7 +635,7 @@
command => "pcs cluster setup --force ${pcs_cluster_setup_namearg} ${cluster_name} ${node_string}",
path => $exec_path,
onlyif => 'test ! -f /etc/corosync/corosync.conf',
require => Exec['authorize_members'],
require => Exec[$quorum_members.map |$node| {"authorize_member_${node}"}],
}
# We need to do this so the temporary cluster doesn't delete our authkey
if $enable_secauth {
Expand All @@ -655,7 +654,7 @@
onlyif => $qdevice_token_check,
require => [
Package[$package_quorum_device],
Exec['authorize_members'],
Exec[$quorum_members.map |$node| {"authorize_member_${node}"}],
Exec['pcs_cluster_temporary'],
],
}
Expand Down

0 comments on commit 3a30432

Please sign in to comment.