App-Spoor
view release on metacpan or search on metacpan
lib/App/Spoor/OutputFormatter.pm view on Meta::CPAN
This module is used to convert structured data into a formagt suitable for staorage in a file or display on the terminal.
Quick summary of what the module does.
Perhaps a little code snippet.
use App::Spoor::OutputFormatter;
my $foo = App::Spoor::OutputFormatter->new();
...
=head1 SUBROUTINES/METHODS
=head2 print
Returns a CSV representation of an array of report representations or mailbox event representations. It can optionally
write this output to a file - if no filehandle is provided, output defaults to STDOUT.
use App::Spoor::Formatter;
# Write reports as csv to STDOUT
@reports_data = (
{ ... },
{ ... },
);
App::Spoor::Formatter::print('report', \@reports_data);
# Write mailbox events as csv to STDOUT
@mailbox_events_data = (
{ ... },
{ ... },
);
App::Spoor::Formatter::print('mailbox_event', \@mailbox_events_data);
# Write to a file instead
open my $fh, '>', '/tmp/out.csv'
App::Spoor::Formatter::print('mailbox_event', \@mailbox_events_data, $fh);
close $fh
=cut
sub print {
my $output_type = shift;
if ($output_type eq 'report') {
__print_reports(@_);
} elsif ($output_type eq 'mailbox_event') {
__print_mailbox_events(@_);
}
}
sub __print_reports {
my $records = shift;
my $output_handle = shift // *STDOUT;
my @transformed_record;
my @headers = ('id', 'event time', 'host', 'event type', 'mailbox address');
my $csv = Text::CSV->new({ eol => $/ });
$csv->print($output_handle, \@headers);
foreach my $record_hash (@{$records}) {
@transformed_record = (
$record_hash->{id},
time2str('%Y-%m-%d %H:%M:%S %z', $record_hash->{event_time}, 'UTC'),
$record_hash->{host},
$record_hash->{type},
$record_hash->{mailbox_address}
);
$csv->print($output_handle, \@transformed_record);
}
}
sub __print_mailbox_events {
my $records = shift;
my $output_handle = shift // *STDOUT;
my @transformed_record;
my @headers = ('id', 'event time', 'host', 'event type', 'mailbox address', 'ip');
my $csv = Text::CSV->new({ eol => $/ });
$csv->print($output_handle, \@headers);
foreach my $record_hash (@{$records}) {
@transformed_record = (
$record_hash->{id},
time2str('%Y-%m-%d %H:%M:%S %z', $record_hash->{event_time}, 'UTC'),
$record_hash->{host},
$record_hash->{type},
$record_hash->{mailbox_address},
$record_hash->{ip_actor}{ip_address}
);
$csv->print($output_handle, \@transformed_record);
}
}
=head1 AUTHOR
Rory McKinley, C<< <rorymckinley at capefox.co> >>
=head1 BUGS
Please report any bugs or feature requests to C<bug-. at rt.cpan.org>, or through
the web interface at L<https://rt.cpan.org/NoAuth/ReportBug.html?Queue=.>. I will be notified, and then you'll
automatically be notified of progress on your bug as I make changes.
=head1 SUPPORT
You can find documentation for this module with the perldoc command.
perldoc App::Spoor::OutputFormatter
You can also look for information at:
=over 4
=item * RT: CPAN's request tracker (report bugs here)
L<https://rt.cpan.org/NoAuth/Bugs.html?Dist=.>
=item * AnnoCPAN: Annotated CPAN documentation
L<http://annocpan.org/dist/.>
=item * CPAN Ratings
L<https://cpanratings.perl.org/d/.>
=item * Search CPAN
L<https://metacpan.org/release/.>
=back
=head1 LICENSE AND COPYRIGHT
( run in 2.199 seconds using v1.01-cache-2.11-cpan-8f98c5d2c55 )