Class: Puppet::ResourceApi::SimpleProvider
- Inherits:
-
Object
- Object
- Puppet::ResourceApi::SimpleProvider
- Defined in:
- lib/puppet/resource_api/simple_provider.rb
Overview
This class provides a default implementation for set(), when your resource does not benefit from batching. Instead of processing changes yourself, the create, update, and delete functions, are called for you, with proper logging already set up. Note that your type needs to use ensure in the conventional way with values of prsesent and absent to signal presence and absence of resources.
Class Method Summary collapse
Instance Method Summary collapse
- #create(_context, _name, _should) ⇒ Object
- #delete(_context, _name) ⇒ Object
- #set(context, changes) ⇒ Object
- #update(_context, _name, _should) ⇒ Object
Class Method Details
.build_name(namevars, resource_hash) ⇒ Object
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
70 71 72 73 74 75 76 |
# File 'lib/puppet/resource_api/simple_provider.rb', line 70 def self.build_name(namevars, resource_hash) if namevars.size > 1 Hash[namevars.map { |attr| [attr, resource_hash[attr]] }] else resource_hash[namevars[0]] end end |
Instance Method Details
#create(_context, _name, _should) ⇒ Object
57 58 59 |
# File 'lib/puppet/resource_api/simple_provider.rb', line 57 def create(_context, _name, _should) raise "#{self.class} has not implemented `create`" end |
#delete(_context, _name) ⇒ Object
65 66 67 |
# File 'lib/puppet/resource_api/simple_provider.rb', line 65 def delete(_context, _name) raise "#{self.class} has not implemented `delete`" end |
#set(context, changes) ⇒ Object
12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 |
# File 'lib/puppet/resource_api/simple_provider.rb', line 12 def set(context, changes) namevars = context.type.namevars changes.each do |name, change| is = if context.type.feature?('simple_get_filter') change.key?(:is) ? change[:is] : (get(context, [name]) || []).find { |r| SimpleProvider.build_name(namevars, r) == name } else change.key?(:is) ? change[:is] : (get(context) || []).find { |r| SimpleProvider.build_name(namevars, r) == name } end context.type.check_schema(is) unless change.key?(:is) should = change[:should] raise 'SimpleProvider cannot be used with a Type that is not ensurable' unless context.type.ensurable? is_ensure = is.nil? ? 'absent' : is[:ensure].to_s should_ensure = should.nil? ? 'absent' : should[:ensure].to_s name_hash = if namevars.length > 1 # pass a name_hash containing the values of all namevars name_hash = {} namevars.each do |namevar| name_hash[namevar] = change[:should][namevar] end name_hash else name end if is_ensure == 'absent' && should_ensure == 'present' context.creating(name) do create(context, name_hash, should) end elsif is_ensure == 'present' && should_ensure == 'absent' context.deleting(name) do delete(context, name_hash) end elsif is_ensure == 'present' context.updating(name) do update(context, name_hash, should) end end end end |
#update(_context, _name, _should) ⇒ Object
61 62 63 |
# File 'lib/puppet/resource_api/simple_provider.rb', line 61 def update(_context, _name, _should) raise "#{self.class} has not implemented `update`" end |