summaryrefslogtreecommitdiff
path: root/FS
diff options
context:
space:
mode:
Diffstat (limited to 'FS')
-rw-r--r--FS/FS/Report/FCC_477.pm23
1 files changed, 18 insertions, 5 deletions
diff --git a/FS/FS/Report/FCC_477.pm b/FS/FS/Report/FCC_477.pm
index 760f6f22d..29505f8e9 100644
--- a/FS/FS/Report/FCC_477.pm
+++ b/FS/FS/Report/FCC_477.pm
@@ -320,7 +320,7 @@ sub report {
my $num_errors = 0;
foreach my $row (@$data) {
if ( $class->can($check_method) ) { # they don't all have these
- my $eh = $class->$check_method( $row );
+ my $eh = $class->$check_method( $row, 'date'=>$opt{'date'} );
$num_errors++ if keys(%$eh);
push @$error, $eh
}
@@ -442,12 +442,19 @@ sub fbs_sql {
sub fbs_check {
my $class = shift;
my $row = shift;
+
+ my %opt = @_;
+ my $date = $opt{date} || time;
+ my $census_digits = ($date < 1601449200) ? 11 : 15; # 9/30/2020, halfway
+ # between the two filing
+ # dates when it changed
+
my %e;
#censustract
if ( length($row->[0]) == 0 ) {
$e{'censustract_null'} = 'The package location has no census tract.';
- } elsif ($row->[0] !~ /^\d{11}$/) {
- $e{'censustract_bad'} = 'The census tract must be exactly 11 digits.';
+ } elsif ($row->[0] !~ /^\d{$census_digits}$/) {
+ $e{'censustract_bad'} = "The census tract must be exactly $census_digits digits.";
}
#technology
@@ -515,12 +522,18 @@ sub fvs_sql {
sub fvs_check {
my $class = shift;
my $row = shift;
+ my %opt = @_;
+ my $date = $opt{date} || time;
+ my $census_digits = ($date < 1601449200) ? 11 : 15; # 9/30/2020, halfway
+ # between the two filing
+ # dates when it changed
+
my %e;
#censustract
if ( length($row->[0]) == 0 ) {
$e{'censustract_null'} = 'The package location has no census tract.';
- } elsif ($row->[0] !~ /^\d{11}$/) {
- $e{'censustract_bad'} = 'The census tract must be exactly 11 digits.';
+ } elsif ($row->[0] !~ /^\d{$census_digits}$/) {
+ $e{'censustract_bad'} = "The census tract must be exactly $census_digits digits.";
}
return \%e;
}