Add a pacemaker::resource::remote define in order to be able to create pacemaker remotes. Leverage the existing common functions when adding it. Change-Id: Ic0488f4fc63e35b9aede60fae1e2cab34b1fbdd5
230 lines
7.2 KiB
Ruby
230 lines
7.2 KiB
Ruby
require_relative '../pcmk_common'
|
|
|
|
Puppet::Type.type(:pcmk_resource).provide(:default) do
|
|
desc 'A base resource definition for a pacemaker resource'
|
|
|
|
### overloaded methods
|
|
def create
|
|
resource_params = @resource[:resource_params]
|
|
meta_params = @resource[:meta_params]
|
|
op_params = @resource[:op_params]
|
|
clone_params = @resource[:clone_params]
|
|
group_params = @resource[:group_params]
|
|
master_params = @resource[:master_params]
|
|
location_rule = @resource[:location_rule]
|
|
|
|
# We need to probe the existance of both location and resource
|
|
# because we do not know why we're being created (if for both or
|
|
# only for one)
|
|
did_location_exist = location_exists?
|
|
did_resource_exist = resource_exists?
|
|
Puppet.debug("Create: resource exists #{did_resource_exist} location exists #{did_location_exist}")
|
|
|
|
suffixes = 0
|
|
if clone_params then suffixes +=1 end
|
|
if master_params then suffixes +=1 end
|
|
if group_params then suffixes +=1 end
|
|
if suffixes > 1
|
|
raise(Puppet::Error, "May only define one of clone_params, "+
|
|
"master_params and group_params")
|
|
end
|
|
|
|
# Build the 'pcs resource create' command. Check out the pcs man page :-)
|
|
cmd = 'resource create ' + @resource[:name]+' ' +@resource[:resource_type]
|
|
if @resource[:resource_type] == 'remote'
|
|
@resource[:remote_address] ? cmd += ' server=' + @resource[:remote_address] :
|
|
cmd += " reconnect_interval=#{@resource[:reconnect_interval]}"
|
|
end
|
|
if not_empty_string(resource_params)
|
|
cmd += ' ' + resource_params
|
|
end
|
|
if not_empty_string(meta_params)
|
|
cmd += ' meta ' + meta_params
|
|
end
|
|
if not_empty_string(op_params)
|
|
cmd += ' op ' + op_params
|
|
end
|
|
if clone_params
|
|
cmd += ' --clone'
|
|
if not_empty_string(clone_params)
|
|
cmd += ' ' + clone_params
|
|
end
|
|
end
|
|
if not_empty_string(group_params)
|
|
cmd += ' --group ' + group_params
|
|
end
|
|
if master_params
|
|
cmd += ' --master'
|
|
if not_empty_string(master_params)
|
|
cmd += ' ' + master_params
|
|
end
|
|
end
|
|
|
|
# If both the resource and the location do not exist, we create them both
|
|
# if a location_rule is specified otherwise only the resource
|
|
if not did_location_exist and not did_resource_exist
|
|
if location_rule
|
|
pcs('create', @resource[:name], "#{cmd} --disabled", @resource[:tries],
|
|
@resource[:try_sleep], @resource[:verify_on_create], @resource[:post_success_sleep])
|
|
location_rule_create(location_rule)
|
|
pcs('create', @resource[:name], "resource enable #{@resource[:name]}", @resource[:tries],
|
|
@resource[:try_sleep], @resource[:verify_on_create], @resource[:post_success_sleep])
|
|
else
|
|
pcs('create', @resource[:name], cmd, @resource[:tries],
|
|
@resource[:try_sleep], @resource[:verify_on_create], @resource[:post_success_sleep])
|
|
end
|
|
# If the location_rule already existed, we only create the resource
|
|
elsif did_location_exist and not did_resource_exist
|
|
pcs('create', @resource[:name], cmd, @resource[:tries],
|
|
@resource[:try_sleep], @resource[:verify_on_create], @resource[:post_success_sleep])
|
|
# The location_rule does not exist and the resource does exist
|
|
elsif not did_location_exist and did_resource_exist
|
|
if location_rule
|
|
location_rule_create(location_rule)
|
|
end
|
|
else
|
|
raise Puppet::Error, "Invalid create: #{name} resource exists #{did_resource_exist} "
|
|
"location exists #{did_location_exist} - location_rule #{location_rule}"
|
|
end
|
|
end
|
|
|
|
def destroy
|
|
# Any corresponding location rules will be deleted by
|
|
# pcs automatically, if present
|
|
cmd = 'resource delete ' + @resource[:name]
|
|
pcs('delete', @resource[:name], cmd, @resource[:tries],
|
|
@resource[:try_sleep], @resource[:verify_on_create], @resource[:post_success_sleep])
|
|
end
|
|
|
|
def exists?
|
|
did_location_exist = location_exists?
|
|
did_resource_exist = resource_exists?
|
|
Puppet.debug("Exists: resource exists #{did_resource_exist} location exists #{did_location_exist}")
|
|
if did_resource_exist and did_location_exist
|
|
return true
|
|
end
|
|
return false
|
|
end
|
|
|
|
def resource_exists?
|
|
cmd = 'resource show ' + @resource[:name] + ' > /dev/null 2>&1'
|
|
ret = pcs('show', @resource[:name], cmd, @resource[:tries],
|
|
@resource[:try_sleep], @resource[:verify_on_create], @resource[:post_success_sleep])
|
|
return ret == false ? false : true
|
|
end
|
|
|
|
def location_exists?
|
|
# If no location_rule is specified then we treat it as if it
|
|
# always exists
|
|
if not @resource[:location_rule]
|
|
return true
|
|
end
|
|
constraint_name = 'location-' + @resource[:name]
|
|
if @resource[:clone_params]
|
|
constraint_name += '-clone'
|
|
elsif @resource[:master_params]
|
|
constraint_name += '-master'
|
|
end
|
|
cmd = "constraint list | grep #{constraint_name} > /dev/null 2>&1"
|
|
ret = pcs('show', @resource[:name], cmd, @resource[:tries],
|
|
@resource[:try_sleep], @resource[:verify_on_create], @resource[:post_success_sleep])
|
|
return ret == false ? false : true
|
|
end
|
|
|
|
def location_rule_create(location_rule)
|
|
# The name that pcs will create is location-<name>[-{clone,master}]
|
|
location_cmd = 'constraint location ' + @resource[:name]
|
|
if clone_params
|
|
location_cmd += '-clone'
|
|
elsif master_params
|
|
location_cmd += '-master'
|
|
end
|
|
location_cmd += ' rule'
|
|
if location_rule['resource_discovery']
|
|
location_cmd += " resource-discovery=#{location_rule['resource_discovery']}"
|
|
end
|
|
if location_rule['score']
|
|
location_cmd += " score=#{location_rule['score']}"
|
|
end
|
|
if location_rule['score_attribute']
|
|
location_cmd += " score-attribure=#{location_rule['score_attribute']}"
|
|
end
|
|
if location_rule['expression']
|
|
location_cmd += " " + location_rule['expression'].join(' ')
|
|
end
|
|
Puppet.debug("location_rule_create: #{location_cmd}")
|
|
pcs('create', @resource[:name], location_cmd, @resource[:tries],
|
|
@resource[:try_sleep], @resource[:verify_on_create], @resource[:post_success_sleep])
|
|
end
|
|
|
|
|
|
### property methods
|
|
|
|
# It isn't an easy road if you want to make these true
|
|
# puppet-like resource properties. Here is a start if you are feeling brave:
|
|
# https://github.com/cwolferh/puppet-pacemaker/blob/pcmk_resource_improvements_try0/lib/puppet/provider/pcmk_resource/default.rb#L64
|
|
def resource_params
|
|
@resource[:resource_params]
|
|
end
|
|
|
|
def resource_params=(value)
|
|
end
|
|
|
|
def op_params
|
|
@resource[:op_params]
|
|
end
|
|
|
|
def op_params=(value)
|
|
end
|
|
|
|
def meta_params
|
|
@resource[:meta_params]
|
|
end
|
|
|
|
def meta_params=(value)
|
|
end
|
|
|
|
def group_params
|
|
@resource[:group_params]
|
|
end
|
|
|
|
def group_params=(value)
|
|
end
|
|
|
|
def master_params
|
|
@resource[:master_params]
|
|
end
|
|
|
|
def master_params=(value)
|
|
end
|
|
|
|
def clone_params
|
|
@resource[:clone_params]
|
|
end
|
|
|
|
def clone_params=(value)
|
|
end
|
|
|
|
def location_rule
|
|
@resource[:location_rule]
|
|
end
|
|
|
|
def location_rule=(value)
|
|
end
|
|
|
|
def reconnect_interval
|
|
@resource[:reconnect_interval]
|
|
end
|
|
|
|
def reconnect_interval=(value)
|
|
end
|
|
|
|
def remote_address
|
|
@resource[:remote_address]
|
|
end
|
|
|
|
def remote_address=(value)
|
|
end
|
|
|
|
end
|