1 package FS::Report::FCC_477;
2 use base qw( FS::Report );
5 use vars qw( @upload @download @technology @part2aoption @part2boption
8 use FS::Record qw( dbh );
12 FS::Report::FCC_477 - Routines for FCC Form 477 reports
54 'Terrestrial Fixed Wireless',
55 'Terrestrial Mobile Wireless',
56 'Electric Power Line',
63 'unswitched UNE loops',
80 #from the select at http://www.ffiec.gov/census/default.aspx
82 '01' => 'ALABAMA (AL)',
83 '02' => 'ALASKA (AK)',
84 '04' => 'ARIZONA (AZ)',
85 '05' => 'ARKANSAS (AR)',
86 '06' => 'CALIFORNIA (CA)',
87 '08' => 'COLORADO (CO)',
89 '09' => 'CONNECTICUT (CT)',
90 '10' => 'DELAWARE (DE)',
91 '11' => 'DISTRICT OF COLUMBIA (DC)',
92 '12' => 'FLORIDA (FL)',
93 '13' => 'GEORGIA (GA)',
94 '15' => 'HAWAII (HI)',
97 '17' => 'ILLINOIS (IL)',
98 '18' => 'INDIANA (IN)',
100 '20' => 'KANSAS (KS)',
101 '21' => 'KENTUCKY (KY)',
103 '22' => 'LOUISIANA (LA)',
104 '23' => 'MAINE (ME)',
105 '24' => 'MARYLAND (MD)',
106 '25' => 'MASSACHUSETTS (MA)',
107 '26' => 'MICHIGAN (MI)',
108 '27' => 'MINNESOTA (MN)',
110 '28' => 'MISSISSIPPI (MS)',
111 '29' => 'MISSOURI (MO)',
112 '30' => 'MONTANA (MT)',
113 '31' => 'NEBRASKA (NE)',
114 '32' => 'NEVADA (NV)',
115 '33' => 'NEW HAMPSHIRE (NH)',
117 '34' => 'NEW JERSEY (NJ)',
118 '35' => 'NEW MEXICO (NM)',
119 '36' => 'NEW YORK (NY)',
120 '37' => 'NORTH CAROLINA (NC)',
121 '38' => 'NORTH DAKOTA (ND)',
124 '40' => 'OKLAHOMA (OK)',
125 '41' => 'OREGON (OR)',
126 '42' => 'PENNSYLVANIA (PA)',
127 '44' => 'RHODE ISLAND (RI)',
128 '45' => 'SOUTH CAROLINA (SC)',
129 '46' => 'SOUTH DAKOTA (SD)',
131 '47' => 'TENNESSEE (TN)',
132 '48' => 'TEXAS (TX)',
134 '50' => 'VERMONT (VT)',
135 '51' => 'VIRGINIA (VA)',
136 '53' => 'WASHINGTON (WA)',
138 '54' => 'WEST VIRGINIA (WV)',
139 '55' => 'WISCONSIN (WI)',
140 '56' => 'WYOMING (WY)',
141 '72' => 'PUERTO RICO (PR)',
144 sub restore_fcc477map {
146 FS::Record::scalar_sql('',"select formvalue from fcc477map where formkey = ?",$key);
153 local $SIG{HUP} = 'IGNORE';
154 local $SIG{INT} = 'IGNORE';
155 local $SIG{QUIT} = 'IGNORE';
156 local $SIG{TERM} = 'IGNORE';
157 local $SIG{TSTP} = 'IGNORE';
158 local $SIG{PIPE} = 'IGNORE';
160 my $oldAutoCommit = $FS::UID::AutoCommit;
161 local $FS::UID::AutoCommit = 0;
164 # lame (should be normal FS::Record access)
166 my $sql = "delete from fcc477map where formkey = ?";
167 my $sth = dbh->prepare($sql) or die dbh->errstr;
168 $sth->execute($key) or do {
169 warn "WARNING: Error removing FCC 477 form defaults: " . $sth->errstr;
170 $dbh->rollback if $oldAutoCommit;
173 $sql = "insert into fcc477map (formkey,formvalue) values (?,?)";
174 $sth = dbh->prepare($sql) or die dbh->errstr;
175 $sth->execute($key,$value) or do {
176 warn "WARNING: Error setting FCC 477 form defaults: " . $sth->errstr;
177 $dbh->rollback if $oldAutoCommit;
180 $dbh->commit or die $dbh->errstr if $oldAutoCommit;
185 sub parse_technology_option {
190 for (my $i = 0; $i < scalar(@technology); $i++) {
191 my $value = $cgi->param("part1_technology_option_$i"); #lame
192 save_fcc477map("part1_technology_option_$i",$value)
193 if $save && $value =~ /^\d+$/;
194 push @result, $value =~ /^\d+$/ ? $value : 0;
206 # $states{$num} =~ /\((\w\w)\)$/ or return '';