diff options
author | Jesse Wolfe <jes5199@gmail.com> | 2011-03-29 15:07:05 -0700 |
---|---|---|
committer | Jesse Wolfe <jes5199@gmail.com> | 2011-03-29 15:07:05 -0700 |
commit | 4413c3e6787deb947daf2e40887ebe39f91bc1ab (patch) | |
tree | 2162cba23e7b2f534edf7c1736dccdde02c52bc6 /lib/puppet/parser | |
parent | 1a7f0dc6c4bfe4ce716ddfd918be181c8d682229 (diff) | |
parent | 49059568d0e4e00bbc35d6f9b2a6cd23e7d00f46 (diff) | |
download | puppet-4413c3e6787deb947daf2e40887ebe39f91bc1ab.tar.gz puppet-4413c3e6787deb947daf2e40887ebe39f91bc1ab.tar.xz puppet-4413c3e6787deb947daf2e40887ebe39f91bc1ab.zip |
Merge branch 'feature/2.6.next/5909' of https://github.com/bodepd/puppet into next
Diffstat (limited to 'lib/puppet/parser')
-rw-r--r-- | lib/puppet/parser/functions/create_resources.rb | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/lib/puppet/parser/functions/create_resources.rb b/lib/puppet/parser/functions/create_resources.rb new file mode 100644 index 000000000..430f110b4 --- /dev/null +++ b/lib/puppet/parser/functions/create_resources.rb @@ -0,0 +1,47 @@ +Puppet::Parser::Functions::newfunction(:create_resources, :doc => ' +Converts a hash into a set of resources and adds them to the catalog. +Takes two parameters: + create_resource($type, $resources) + Creates resources of type $type from the $resources hash. Assumes that + hash is in the following form: + {title=>{parameters}} + This is currently tested for defined resources, classes, as well as native types +') do |args| + raise ArgumentError, ("create_resources(): wrong number of arguments (#{args.length}; must be 2)") if args.length != 2 + #raise ArgumentError, 'requires resource type and param hash' if args.size < 2 + # figure out what kind of resource we are + type_of_resource = nil + type_name = args[0].downcase + if type_name == 'class' + type_of_resource = :class + else + if resource = Puppet::Type.type(type_name.to_sym) + type_of_resource = :type + elsif resource = find_definition(type_name.downcase) + type_of_resource = :define + else + raise ArgumentError, "could not create resource of unknown type #{type_name}" + end + end + # iterate through the resources to create + args[1].each do |title, params| + raise ArgumentError, 'params should not contain title' if(params['title']) + case type_of_resource + when :type + res = resource.hash2resource(params.merge(:title => title)) + catalog.add_resource(res) + when :define + p_resource = Puppet::Parser::Resource.new(type_name, title, :scope => self, :source => resource) + params.merge(:name => title).each do |k,v| + p_resource.set_parameter(k,v) + end + resource.instantiate_resource(self, p_resource) + compiler.add_resource(self, p_resource) + when :class + klass = find_hostclass(title) + raise ArgumentError, "could not find hostclass #{title}" unless klass + klass.ensure_in_catalog(self, params) + compiler.catalog.add_class([title]) + end + end +end |