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 )