summaryrefslogtreecommitdiffstats
path: root/lib/puppet/indirector/report/processor.rb
blob: 80570d9c39ae0de74c0b4fe50b76e940e8d1770c (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
48
require 'puppet/transaction/report'
require 'puppet/indirector/code'
require 'puppet/reports'

class Puppet::Transaction::Report::Processor < Puppet::Indirector::Code
    desc "Puppet's report processor.  Processes the report with each of
        the report types listed in the 'reports' setting."

    def initialize
        Puppet.settings.use(:main, :reporting, :metrics)
    end

    def save(request)
        process(request.instance)
    end

    private

    # Process the report with each of the configured report types.
    # LAK:NOTE This isn't necessarily the best design, but it's backward
    # compatible and that's good enough for now.
    def process(report)
        return if Puppet[:reports] == "none"

        reports().each do |name|
            if mod = Puppet::Reports.report(name)
                # We have to use a dup because we're including a module in the
                # report.
                newrep = report.dup
                begin
                    newrep.extend(mod)
                    newrep.process
                rescue => detail
                    puts detail.backtrace if Puppet[:trace]
                    Puppet.err "Report #{name} failed: #{detail}"
                end
            else
                Puppet.warning "No report named '#{name}'"
            end
        end
    end

    # Handle the parsing of the reports attribute.
    def reports
        # LAK:NOTE See http://snurl.com/21zf8  [groups_google_com]
        x = Puppet[:reports].gsub(/(^\s+)|(\s+$)/, '').split(/\s*,\s*/)
    end
end