File: parsejson.rb

package info (click to toggle)
puppet-module-puppetlabs-stdlib 9.4.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,448 kB
  • sloc: ruby: 3,522; sh: 46; makefile: 2
file content (34 lines) | stat: -rw-r--r-- 877 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
# frozen_string_literal: true

require 'puppet/util/json'
#
# parsejson.rb
#
module Puppet::Parser::Functions
  newfunction(:parsejson, type: :rvalue, doc: <<-DOC
    @summary
      This function accepts JSON as a string and converts it into the correct
      Puppet structure.

    @return
      convert JSON into Puppet structure

    > *Note:*
      The optional second argument can be used to pass a default value that will
      be returned if the parsing of the JSON string failed or if the JSON parse
      evaluated to nil.
  DOC
  ) do |arguments|
    raise ArgumentError, 'Wrong number of arguments. 1 or 2 arguments should be provided.' unless arguments.length >= 1

    begin
      Puppet::Util::Json.load(arguments[0]) || arguments[1]
    rescue StandardError => e
      raise e unless arguments[1]

      arguments[1]
    end
  end
end

# vim: set ts=2 sw=2 et :