only log update message when we're actually updating
[scpubgit/System-Introspector-Report.git] / lib / System / Introspector / Report / Publish / MediaWiki.pm
CommitLineData
499ebcdd 1package System::Introspector::Report::Publish::MediaWiki;
2use Moo;
0331d9cd 3use Try::Tiny;
72599a55 4use Log::Contextual qw( :log );
499ebcdd 5use aliased 'System::Introspector::Report::Publish::MediaWiki::Connection';
6
7has page_options => (
8 is => 'ro',
9 default => sub { {} },
10 init_arg => 'page',
11);
12
499ebcdd 13has connection => (is => 'ro', lazy => 1, builder => 1, handles => {
14 get_page => 'get',
15 put_page => 'put',
16});
17
7a479e54 18has api_uri => (is => 'ro', required => 1);
19has username => (is => 'ro', required => 1);
20has password => (is => 'ro', required => 1);
21has allow_create => (is => 'ro', default => sub { 0 });
22has http_auth => (is => 'ro');
23has http_realm => (is => 'ro');
0331d9cd 24
25sub _build_producer { Producer->new }
26
27sub _build_connection {
28 my ($self) = @_;
29 return Connection->new(
7a479e54 30 api_uri => $self->api_uri,
31 username => $self->username,
32 password => $self->password,
33 allow_create => $self->allow_create,
0331d9cd 34 $self->http_auth ? (
35 http_auth => 1,
36 http_realm => $self->http_realm,
37 ) : (),
38 );
39}
499ebcdd 40
41sub publish {
42 my ($self, $reports) = @_;
43 my $pages = $self->page_options;
72599a55 44 log_info { "Pushing reports to MediaWiki at '%s'", $self->api_uri };
499ebcdd 45 for my $page (sort keys %$pages) {
46 $self->_publish_page($reports, $page, $pages->{$page});
47 }
72599a55 48 log_info { "Finished pushing to MediaWiki" };
499ebcdd 49 return 1;
50}
51
52sub _sort_reports {
53 my ($self, $reports, $included) = @_;
54 my @matchers = map {
55 $self->_prepare_matcher_from($_);
56 } ref($included) ? @{$included} : $included;
57 my @grouped;
58 for my $report (@$reports) {
59 my ($group_idx) = grep {
60 $self->_match_id($report, $matchers[$_]);
61 } 0 .. $#matchers;
62 if (defined $group_idx) {
63 push @{$grouped[$group_idx]}, $report;
64 }
65 }
66 return [ map { (@$_) } @grouped ];
67}
68
7a479e54 69sub _publish_dynamic {
70 my ($self, $reports, $page_name, $key, $options) = @_;
71 my %reports_by_key;
72 for my $report (@$reports) {
73 my $value = $report->{meta}{$key};
74 next unless defined $value;
75 push @{ $reports_by_key{$value} ||= [] }, $report;
76 }
77 for my $value (keys %reports_by_key) {
78 (my $effective_page = $page_name)
79 =~ s{\%\(meta:\Q$key\E\)}{$value};
80 my $assoc = $reports_by_key{$value};
81 $self->_publish_page($assoc, $effective_page, $options);
82 }
83 return 1;
84}
85
499ebcdd 86sub _publish_page {
21e7cc98 87 my ($self, $reports, $page_name, $options) = @_;
7a479e54 88 if ($page_name =~ m{\%\(meta:(.+?)\)}) {
89 return $self->_publish_dynamic($reports, $page_name, $1, $options);
90 }
499ebcdd 91 my $sorted = $self->_sort_reports($reports, $options->{report} || []);
7a479e54 92 unless (scalar @$sorted) {
1acc31a2 93 log_trace { "Skipping page '$page_name': No reports to publish" };
7a479e54 94 return 1;
95 }
7a479e54 96 my $do_create = $options->{create};
97 return try {
0331d9cd 98 my $page = $self->get_page($page_name);
7a479e54 99 if ($page->is_new and not $do_create) {
1acc31a2 100 log_trace { "Skipping page '$page_name': Does not yet exist" };
7a479e54 101 return 1;
102 }
103 my $is_changed = $page->update($sorted);
104 unless ($is_changed) {
1acc31a2 105 log_trace { "Not pushing page '$page_name': No changes" };
7a479e54 106 return 1;
107 }
ac3652dc 108 log_debug { "Updating page '$page_name'" };
0331d9cd 109 $self->put_page($page);
7a479e54 110 return 1;
0331d9cd 111 }
112 catch {
72599a55 113 log_error { "Error during page update: $_" };
7a479e54 114 return 1;
0331d9cd 115 };
499ebcdd 116}
117
118with $_ for qw(
119 System::Introspector::Report::Publish::API
120);
121
1221;