summaryrefslogtreecommitdiff
path: root/lib/puppet/parser/functions/parsejson.rb
diff options
context:
space:
mode:
authorKen Barber <ken@bob.sh>2011-08-05 08:25:03 +0100
committerKen Barber <ken@bob.sh>2011-08-05 08:25:03 +0100
commit681a1c7971d78c53dc9a0747ae4d983ff6b0d670 (patch)
tree3d56e35ffd165eb6d15bd54a06c41f8aa706fa1c /lib/puppet/parser/functions/parsejson.rb
parent35fefe186546427963d8c8a446fa98875d65ccad (diff)
downloadpuppet-stdlib-681a1c7971d78c53dc9a0747ae4d983ff6b0d670.tar.gz
puppet-stdlib-681a1c7971d78c53dc9a0747ae4d983ff6b0d670.tar.bz2
Prep for stdlib merge
* Renamed load_yaml & load_json to parseyaml & parsejson * Renamed is_valid_* functions and remove the 'valid_'
Diffstat (limited to 'lib/puppet/parser/functions/parsejson.rb')
-rw-r--r--lib/puppet/parser/functions/parsejson.rb26
1 files changed, 26 insertions, 0 deletions
diff --git a/lib/puppet/parser/functions/parsejson.rb b/lib/puppet/parser/functions/parsejson.rb
new file mode 100644
index 0000000..cf3b12c
--- /dev/null
+++ b/lib/puppet/parser/functions/parsejson.rb
@@ -0,0 +1,26 @@
+#
+# parsejson.rb
+#
+
+module Puppet::Parser::Functions
+ newfunction(:parsejson, :type => :rvalue, :doc => <<-EOS
+This function accepts JSON as a string and converts into the correct Puppet
+structure.
+ EOS
+ ) do |arguments|
+
+ if (arguments.size != 1) then
+ raise(Puppet::ParseError, "parsejson(): Wrong number of arguments "+
+ "given #{arguments.size} for 1")
+ end
+
+ json = arguments[0]
+
+ require 'json'
+
+ JSON.load(json)
+
+ end
+end
+
+# vim: set ts=2 sw=2 et :