Class: Puppet::ResourceApi::ResourceShim

Inherits:
Object
  • Object
show all
Defined in:
lib/puppet/resource_api/glue.rb

Overview

A trivial class to provide the functionality required to push data through the existing type/provider parts of puppet

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(resource_hash, typename, namevars, attr_def, catalog = nil) ⇒ ResourceShim

Returns a new instance of ResourceShim.



11
12
13
14
15
16
17
# File 'lib/puppet/resource_api/glue.rb', line 11

def initialize(resource_hash, typename, namevars, attr_def, catalog = nil)
  @values = resource_hash.dup.freeze # whatevs
  @typename = typename
  @namevars = namevars
  @attr_def = attr_def
  @catalog = catalog
end

Instance Attribute Details

#attr_defObject (readonly)

Returns the value of attribute attr_def.



9
10
11
# File 'lib/puppet/resource_api/glue.rb', line 9

def attr_def
  @attr_def
end

#catalogObject (readonly)

Returns the value of attribute catalog.



9
10
11
# File 'lib/puppet/resource_api/glue.rb', line 9

def catalog
  @catalog
end

#namevarsObject (readonly)

Returns the value of attribute namevars.



9
10
11
# File 'lib/puppet/resource_api/glue.rb', line 9

def namevars
  @namevars
end

#typenameObject (readonly)

Returns the value of attribute typename.



9
10
11
# File 'lib/puppet/resource_api/glue.rb', line 9

def typename
  @typename
end

#valuesObject (readonly)

Returns the value of attribute values.



9
10
11
# File 'lib/puppet/resource_api/glue.rb', line 9

def values
  @values
end

Instance Method Details

#filtered_keysObject

attribute names that are not title, namevars, or rsapi_custom_insync_trigger



63
64
65
# File 'lib/puppet/resource_api/glue.rb', line 63

def filtered_keys
  values.keys.reject { |k| k == :title || k == :rsapi_custom_insync_trigger || !attr_def[k] || (attr_def[k][:behaviour] == :namevar && @namevars.size == 1) }
end

#prune_parameters(*_args) ⇒ Object



23
24
25
26
# File 'lib/puppet/resource_api/glue.rb', line 23

def prune_parameters(*_args)
  # puts "not pruning #{args.inspect}" if args.length > 0
  self
end

#titleObject



19
20
21
# File 'lib/puppet/resource_api/glue.rb', line 19

def title
  values[:title] || values[@namevars.first]
end

#to_hashObject



58
59
60
# File 'lib/puppet/resource_api/glue.rb', line 58

def to_hash
  values
end

#to_hiera_hashObject

Required to enable ‘puppet device –resource … –to_yaml` workflow



41
42
43
# File 'lib/puppet/resource_api/glue.rb', line 41

def to_hiera_hash
  to_hierayaml
end

#to_hierayamlObject

Convert our resource to yaml for Hiera purposes.



46
47
48
49
# File 'lib/puppet/resource_api/glue.rb', line 46

def to_hierayaml
  attributes = Hash[filtered_keys.map { |k| [k.to_s, values[k]] }]
  YAML.dump('type' => { title => attributes }).split("\n").drop(2).join("\n") + "\n"
end

#to_jsonObject



51
52
53
54
55
56
# File 'lib/puppet/resource_api/glue.rb', line 51

def to_json(*)
  attrs = filtered_keys.map { |k| [k.to_s, values[k]] unless values[k].nil? }
  attributes = Hash[*attrs.compact.flatten]
  resource = { title => attributes }
  resource.to_json
end

#to_manifestObject



28
29
30
31
32
33
34
35
36
37
38
# File 'lib/puppet/resource_api/glue.rb', line 28

def to_manifest
  (["#{@typename} { #{Puppet::Parameter.format_value_for_display(title)}: "] + filtered_keys.map do |k|
    cs = ' '
    ce = ''
    if attr_def[k] && attr_def[k][:behaviour] && attr_def[k][:behaviour] == :read_only
      cs = '#'
      ce = ' # Read Only'
    end
    "#{cs} #{k} => #{Puppet::Parameter.format_value_for_display(values[k])},#{ce}" unless values[k].nil?
  end + ['}']).compact.join("\n")
end