only log update message when we're actually updating
[scpubgit/System-Introspector-Report.git] / bin / system-introspector-report
CommitLineData
499ebcdd 1#!/usr/bin/env perl
2use strictures;
3use Getopt::Long;
4use Pod::Usage;
0331d9cd 5use Try::Tiny;
499ebcdd 6use System::Introspector::Report::Source;
7use System::Introspector::Report::Config;
72599a55 8use Log::Contextual qw( set_logger );
9use Log::Contextual::SimpleLogger;
499ebcdd 10
11GetOptions(
12 's|storage=s' => \my $storage_dir,
13 'c|config=s' => \my $config_file,
14 'r|report=s' => \my @report_types,
15 'p|publish=s' => \my @publish_types,
16 'a|all' => \my $all_reports,
72599a55 17 'v|verbose+' => \my $log_verbose,
499ebcdd 18 'h|help' => sub { pod2usage(0) },
19) or pod2usage(2);
20
21die "$0 requires --storage (-s) to be specified\n"
22 unless defined $storage_dir;
23
24die "$0 requires --config (-c) to be specified\n"
2956c871 25 unless defined $config_file;
499ebcdd 26
72599a55 27my @additional_log_levels = qw( debug trace );
28my $logger = Log::Contextual::SimpleLogger->new({
29 levels => [
30 qw( error fatal info ),
31 grep { defined }
32 @additional_log_levels[0 .. (($log_verbose || 0) - 1)],
33 ],
34});
35set_logger $logger;
36
499ebcdd 37my $config = System::Introspector::Report::Config
38 ->new(config_file => $config_file);
39
40my $source = System::Introspector::Report::Source
41 ->new_from_root($storage_dir);
42
43my @types = $all_reports
44 ? $config->report_types
45 : map [$_, {}], @report_types;
46my @reports = $source->generate(@types);
47
48for my $publisher ($config->publishers(@publish_types)) {
0331d9cd 49 try {
50 $publisher->publish(\@reports);
51 }
52 catch {
53 print "Error during publish: $_\n";
54 };
499ebcdd 55}
56
57__END__
58
59=head1 NAME
60
61system-introspector-report - Generate System::Introspector reports
62
63=cut