summaryrefslogtreecommitdiff
path: root/lib/puppet/parser/functions/couchdblookup.rb
blob: 132c488c1e10513684aded864f923d685ac95bc5 (plain)
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
35
36
37
38
39
40
41
42
43
44
45
46
47
#
# A basic function to retrieve data in couchdb
#


module Puppet::Parser::Functions
  newfunction(:couchdblookup, :type => :rvalue) do |args|
    require 'json'
    require 'open-uri'

    raise Puppet::ParseError, ("couchdblookup(): wrong number of arguments (#{args.length}; must be 2 or 3)") unless args.length.between?(2, 3)

    url = args[0]
    key = args[1]
    default = args[2] if args.length >= 3

    begin
      json = JSON.parse(open(URI.parse(url)).read)
    rescue OpenURI::HTTPError, JSON::ParserError => error
      raise Puppet::ParseError, "couchdblookup(): fetching URL #{url} failed with status #{error.message}"
    end

    result = nil

    if json.has_key?("rows")

      if json['rows'].length > 1
        arr = json['rows'].collect do |x|
          x[key] if x.is_a?(Hash) and x.has_key?(key)
        end
        arr.compact!
        result = arr unless arr.empty?

      elsif json['rows'].length == 1
        hash = json['rows'].pop
        result = hash[key] if hash.is_a?(Hash)
      end

    elsif json.has_key?(key)
      result = json[key]
    end

    result or default or raise Puppet::ParseError, "couchdblookup(): key '#{key}' not found in JSON object !"

  end
end