summaryrefslogtreecommitdiff
path: root/httemplate/misc
diff options
context:
space:
mode:
authormark <mark>2012-01-13 10:17:48 +0000
committermark <mark>2012-01-13 10:17:48 +0000
commit05e987f7432f98a85546270354cd59445756f110 (patch)
tree7220bea85f69f97b4004f3c3ecee008d74a23d7a /httemplate/misc
parent6b8acf1157b5ec40877fbced43e80ad90d91fe2e (diff)
missing file from #15381
Diffstat (limited to 'httemplate/misc')
-rw-r--r--httemplate/misc/xmlhttp-cust_main-censustract.html119
1 files changed, 8 insertions, 111 deletions
diff --git a/httemplate/misc/xmlhttp-cust_main-censustract.html b/httemplate/misc/xmlhttp-cust_main-censustract.html
index 97b7f5a4c..4b00898da 100644
--- a/httemplate/misc/xmlhttp-cust_main-censustract.html
+++ b/httemplate/misc/xmlhttp-cust_main-censustract.html
@@ -1,117 +1,14 @@
<% objToJson($return) %>
<%init>
-my $DEBUG = 0;
-
-my $url='http://www.ffiec.gov/Geocode/default.aspx';
-
-my $sub = $cgi->param('sub');
-
-my $return = {};
-my $error = '';
-
-use LWP::UserAgent;
-use HTTP::Request;
-use HTTP::Request::Common qw( GET POST );
-use HTML::TokeParser;
-
-if ( $sub eq 'censustract' ) {
-
- my %arg = $cgi->param('arg');
- warn join('', map "$_: $arg{$_}\n", keys %arg )
- if $DEBUG;
-
- my $ua = new LWP::UserAgent;
- my $res = $ua->request( GET( $url ) );
-
- warn $res->as_string
- if $DEBUG > 1;
-
- unless ($res->code eq '200') {
-
- $error = $res->message;
-
- } else {
-
- my $content = $res->content;
- my $p = new HTML::TokeParser \$content;
- my $viewstate;
- my $eventvalidation;
- while (my $token = $p->get_tag('input') ) {
- if ($token->[1]->{name} eq '__VIEWSTATE') {
- $viewstate = $token->[1]->{value};
- }
- if ($token->[1]->{name} eq '__EVENTVALIDATION') {
- $eventvalidation = $token->[1]->{value};
- }
- last if $viewstate && $eventvalidation;
- }
-
- unless ($viewstate && $eventvalidation ) {
-
- $error = "either no __VIEWSTATE or __EVENTVALIDATION found";
-
- } else {
-
- my($zip5, $zip4) = split('-',$arg{zip});
-
- $arg{year} ||= '2011';
- #ugh workaround a mess at ffiec
- $arg{year} = " $arg{year}" if $arg{year} ne '2011';
- my @ffiec_args = (
- __VIEWSTATE => $viewstate,
- __EVENTVALIDATION => $eventvalidation,
- ddlbYear => $arg{year},
- ddlbYear => '2011', #' 2009',
- txtAddress => $arg{address},
- txtCity => $arg{city},
- ddlbState => $arg{state},
- txtZipCode => $zip5,
- btnSearch => 'Search',
- );
- warn join("\n", @ffiec_args )
- if $DEBUG;
-
- push @{ $ua->requests_redirectable }, 'POST';
- $res = $ua->request( POST( $url, \@ffiec_args ) );
- warn $res->as_string
- if $DEBUG > 1;
-
- unless ($res->code eq '200') {
-
- $error = $res->message;
-
- } else {
-
- my @id = qw( MSACode StateCode CountyCode TractCode );
- $content = $res->content;
- warn $res->content if $DEBUG > 1;
- $p = new HTML::TokeParser \$content;
- my $prefix = 'UcGeoResult11_lb';
- my $compare =
- sub { my $t=shift; scalar( grep { lc($t) eq lc("$prefix$_")} @id ) };
-
- while (my $token = $p->get_tag('span') ) {
- next unless ( $token->[1]->{id} && &$compare( $token->[1]->{id} ) );
- $token->[1]->{id} =~ /^$prefix(\w+)$/;
- $return->{lc($1)} = $p->get_trimmed_text("/span");
- }
-
- $error = "No census tract found" unless $return->{tractcode};
- $return->{tractcode} .= ' '
- unless $error || $JSON::VERSION >= 2; #broken JSON 1 workaround
-
- } #unless ($res->code eq '200')
-
- } #unless ($viewstate)
-
- } #unless ($res->code eq '200')
-
- $error = "FFIEC Geocoding error: $error" if $error;
- $return->{'error'} = $error;
-
- $return;
-
+my %arg = $cgi->param('arg');
+my $year = delete($arg{'year'});
+my $return = get_censustract(\%arg, $year);
+if ( $return =~ /^\d/ ) {
+ $return = { 'censustract' => $return };
+}
+else {
+ $return = { 'error' => $return };
}
</%init>