NAME
Finance::AMEX::Transaction::EPTRN - Parse AMEX Transaction/Invoice Level Reconciliation (EPTRN)
VERSION
version 0.005
SYNOPSIS
use Finance::AMEX::Transaction;
my $eptrn = Finance::AMEX::Transaction->new(file_type => 'EPTRN');
open my $fh, '<', '/path to EPTRN file' or die "cannot open EPTRN file: $!";
while (my $record = $eptrn->getline($fh)) {
if ($record->type eq 'TRAILER') {
print $record->FILE_CREATION_DATE . "\n";
}
}
DESCRIPTION
This module parses AMEX Transaction/Invoice Level Reconciliation (EPTRN) files and returns objects which are appropriate for the line that it was asked to parse.
You would not normally be calling this module directly, it is merely a router to the correct object type that is returned to Finance::AMEX::Transaction's getline method.
Object returned are one of:
- Finance::AMEX::Transaction::EPTRN::Header
-
Header Rows
print $record->type; # HEADER
- Finance::AMEX::Transaction::EPTRN::Summary
-
Summary Rows
print $record->type; # SUMMARY
- Finance::AMEX::Transaction::EPTRN::Detail::ChargeSummary
-
Summary of Charge (SOC) Detail Rows
print $record->type; # SOC_DETAIL
- Finance::AMEX::Transaction::EPTRN::Detail::RecordSummary
-
Record of Charge (ROC) Detail Rows
print $record->type; # ROC_DETAIL
- Finance::AMEX::Transaction::EPTRN::Detail::Chargeback
-
Chargeback Detail Rows
print $record->type; # CHARGEBACK_DETAIL
- Finance::AMEX::Transaction::EPTRN::Detail::Adjustment
-
Adjustment Detail Rows
print $record->type; # ADJUSTMENT_DETAIL
- Finance::AMEX::Transaction::EPTRN::Detail::Other
-
Other Fees and Revenues Detail Rows
print $record->type; # OTHER_DETAIL
- Finance::AMEX::Transaction::EPTRN::Trailer
-
Trailer Rows
print $record->type; # TRAILER
- Finance::AMEX::Transaction::EPTRN::Unknown
-
Unknown lines.
print $record->type; # UNKNOWN
METHODS
new
Returns a Finance::AMEX::Transaction::EPTRN object.
my $eptrn = Finance::AMEX::Transaction::EPTRN->new;
parse_line
Returns one of the Finance::AMEX::Transaction::EPTRN::Header, Finance::AMEX::Transaction::EPTRN::Summary, Finance::AMEX::Transaction::EPTRN::Detail::ChargeSummary, Finance::AMEX::Transaction::EPTRN::Detail::RecordSummary, Finance::AMEX::Transaction::EPTRN::Detail::Chargeback, Finance::AMEX::Transaction::EPTRN::Detail::Adjustment, Finance::AMEX::Transaction::EPTRN::Detail::Other, Finance::AMEX::Transaction::EPTRN::Trailer, or Finance::AMEX::Transaction::EPTRN::Unknown records depending on the contents of the line.
my $record = $eptrn->parse_line('line from a eptrn file');
file_format
This is included for compatibility, it will always return the string 'N/A'.
file_version
This is included for compatibility, it will always return the string 'N/A'.
line_indicator
Returns one of the line types for the EPTRN format. You wouldn't normally need to call this.
my $line_type = $eptrn->line_indicator('line from a eptrn file');
NAME
Finance::AMEX::Transaction::EPTRN - Parse AMEX Transaction/Invoice Level Reconciliation (EPTRN)
AUTHOR
Tom Heady <cpan@punch.net>
COPYRIGHT AND LICENSE
This software is copyright (c) 2022 by ZipRecruiter/Tom Heady.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.