|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162 |
-
-
- use strict;
- use warnings;
-
- use CGI qw(:cgi);
- use DateTime;
- use HTML::TreeBuilder;
- use LWP::UserAgent;
- use XML::Writer;
-
-
- our $SearchURL = "http://www2.broxbourne.gov.uk/planningsearch/webform1.aspx";
-
-
- my $query = CGI->new();
-
-
- my $epoch = DateTime->new(year => 2000, month => 1, day => 1);
- my $querydate = DateTime->new(year => $query->param("year"),
- month => $query->param("month"),
- day => $query->param("day"));
- $querydate = $querydate->delta_days($epoch)->delta_days;
-
-
- our $UA = LWP::UserAgent->new(env_proxy => 1);
-
-
- my $state = get_state(do_post());
-
-
-
-
- $state = get_state(do_post_back($state, 'DateSelector1$Calendar1', $querydate));
- $state = get_state(do_post_back($state, 'DateSelector2$Calendar1', $querydate));
-
-
- print $query->header(-type => "text/xml");
-
-
- my $Writer = XML::Writer->new(DATA_MODE => 1);
-
-
- $Writer->xmlDecl("UTF-8");
- $Writer->startTag("planning");
- $Writer->dataElement("authority_name", "Borough of Broxbourne");
- $Writer->dataElement("authority_short_name", "Broxbourne");
- $Writer->startTag("applications");
-
-
- my $args = {
- "Srch" => "rb1",
- "__VIEWSTATE" => $state,
- "btnSearch" => "Search",
- "tbReference" => "",
- "tbRef2" => ""
- };
-
-
- my $page = do_post($args);
-
-
- while ($page)
- {
- my $table = $page->look_down("_tag" => "table", "id" => "DataGrid1");
-
-
- $state = get_state($page);
-
-
-
-
- undef $page;
-
-
-
- if ($table)
- {
-
- foreach my $row ($table->look_down("_tag" => "tr"))
- {
- my @cells = $row->look_down("_tag" => "td");
-
- if ($cells[0]->look_down("_tag" => "input"))
- {
- my $reference = $cells[1]->as_trimmed_text;
- my $date = $cells[2]->as_trimmed_text;
- my $address = $cells[3]->as_trimmed_text;
- my $description = $cells[4]->as_trimmed_text;
- my $postcode;
-
- if ($address =~ /\s+([A-Z]+\d+\s+\d+[A-Z]+)$/)
- {
- $postcode = $1;
- }
-
- $Writer->startTag("application");
- $Writer->dataElement("council_reference", $reference);
- $Writer->dataElement("address", $address);
- $Writer->dataElement("postcode", $postcode);
- $Writer->dataElement("description", $description);
- $Writer->dataElement("date_received", $date);
- $Writer->endTag("application");
- }
- elsif ($cells[0]->attr("colspan") && $cells[0]->attr("colspan") eq "5")
- {
- foreach my $link ($cells[0]->look_down("_tag" => "a"))
- {
- if ($link->as_trimmed_text eq ">" &&
- $link->attr("href") =~ /^javascript:__doPostBack\('([^\']*)','([^\']*)'\)$/)
- {
- $page = do_post_back($state, $1, $2);
- }
- }
- }
- }
- }
- }
-
-
- $Writer->endTag("applications");
- $Writer->endTag("planning");
- $Writer->end();
-
- exit 0;
-
-
- sub get_state
- {
- my $page = shift;
- my $viewstate = $page->look_down("_tag" => "input", "name" => "__VIEWSTATE");
-
- return $viewstate->attr("value");
- }
-
-
- sub do_post_back
- {
- my $state = shift;
- my $target = shift;
- my $argument = shift;
-
- $target =~ s/\$/:/g;
-
- my $args = {
- "__EVENTTARGET" => $target,
- "__EVENTARGUMENT" => $argument,
- "__VIEWSTATE" => $state
- };
-
- return do_post($args);
- }
-
-
- sub do_post
- {
- my $response = $UA->post($SearchURL, @_);
-
- die $response->status_line unless $response->is_success;
-
- return HTML::TreeBuilder->new_from_content($response->content);
- }
|