summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLuke Kanies <luke@puppetlabs.com>2011-04-27 23:04:20 +0100
committerDaniel Pittman <daniel@puppetlabs.com>2011-05-03 12:56:11 -0700
commit48903f58e535dabd55b6895eae1dc1967553391a (patch)
tree9b8b08de2f32da39aa0c5fcac382bee945aafa6e
parent50d18e1fda174a04e5251207f3a39e3ae6cbb891 (diff)
downloadpuppet-48903f58e535dabd55b6895eae1dc1967553391a.tar.gz
puppet-48903f58e535dabd55b6895eae1dc1967553391a.tar.xz
puppet-48903f58e535dabd55b6895eae1dc1967553391a.zip
(#7278) Improve utility of the Catalog select action
This extends the catalog select action to be able to return more than a single type, as well as supporting both programmatic and human focused rendering of the return value. Reviewed-By: Daniel Pittman <daniel@puppetlabs.com>
-rw-r--r--lib/puppet/face/catalog/select.rb18
1 files changed, 17 insertions, 1 deletions
diff --git a/lib/puppet/face/catalog/select.rb b/lib/puppet/face/catalog/select.rb
index ba27117bc..a8ecd82fa 100644
--- a/lib/puppet/face/catalog/select.rb
+++ b/lib/puppet/face/catalog/select.rb
@@ -2,9 +2,25 @@
Puppet::Face.define(:catalog, '0.0.1') do
action :select do
when_invoked do |host, type, options|
+ # REVISIT: Eventually, type should have a default value that triggers
+ # the non-specific behaviour. For now, though, this will do.
+ # --daniel 2011-05-03
catalog = Puppet::Resource::Catalog.indirection.find(host)
- catalog.resources.reject { |res| res.type != type }.each { |res| puts res }
+ if type == '*'
+ catalog.resources
+ else
+ type = type.downcase
+ catalog.resources.reject { |res| res.type.downcase != type }
+ end
+ end
+
+ when_rendering :for_humans do |value|
+ if value.nil? then
+ "no matching resources found"
+ else
+ value.map {|x| x.to_s }.join("\n")
+ end
end
end
end