Imported Upstream version 1.5.1
[routino] / web / www / routino / visualiser.cgi
1 #!/usr/bin/perl
2 #
3 # Routino data visualiser CGI
4 #
5 # Part of the Routino routing software.
6 #
7 # This file Copyright 2008-2010 Andrew M. Bishop
8 #
9 # This program is free software: you can redistribute it and/or modify
10 # it under the terms of the GNU Affero General Public License as published by
11 # the Free Software Foundation, either version 3 of the License, or
12 # (at your option) any later version.
13 #
14 # This program is distributed in the hope that it will be useful,
15 # but WITHOUT ANY WARRANTY; without even the implied warranty of
16 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17 # GNU Affero General Public License for more details.
18 #
19 # You should have received a copy of the GNU Affero General Public License
20 # along with this program.  If not, see <http://www.gnu.org/licenses/>.
21 #
22
23 # Use the directory paths script
24 require "paths.pl";
25
26 # Use the perl CGI module
27 use CGI ':cgi';
28
29 # Create the query and get the parameters
30
31 $query=new CGI;
32
33 @rawparams=$query->param;
34
35 # Legal CGI parameters with regexp validity check
36
37 %legalparams=(
38               "latmin" => "[-0-9.]+",
39               "latmax" => "[-0-9.]+",
40               "lonmin" => "[-0-9.]+",
41               "lonmax" => "[-0-9.]+",
42               "data"   => "(junctions|super|oneway|speed|weight|height|width|length)"
43              );
44
45 # Validate the CGI parameters, ignore invalid ones
46
47 foreach $key (@rawparams)
48   {
49    foreach $test (keys (%legalparams))
50      {
51       if($key =~ m%^$test$%)
52         {
53          $value=$query->param($key);
54
55          if($value =~ m%^$legalparams{$test}$%)
56            {
57             $cgiparams{$key}=$value;
58             last;
59            }
60         }
61      }
62   }
63
64 # Parameters to limit range selected
65
66 %limits=(
67          "junctions" => 0.1,
68          "speed"     => 0.2,
69          "super"     => 0.2,
70          "oneway"    => 0.2,
71          "weight"    => 0.3,
72          "height"    => 0.3,
73          "width"     => 0.3,
74          "length"    => 0.3
75         );
76
77 # Check the parameters
78
79 $latmin=$cgiparams{"latmin"};
80 $latmax=$cgiparams{"latmax"};
81 $lonmin=$cgiparams{"lonmin"};
82 $lonmax=$cgiparams{"lonmax"};
83 $data  =$cgiparams{"data"};
84
85 if($latmin eq "" || $latmax eq "" || $lonmin eq "" || $lonmax eq "" || $data eq "")
86   {
87    print header(-status => '500 Invalid CGI parameters');
88    exit;
89   }
90
91 if(($latmax-$latmin)>$limits{$data} || ($lonmax-$lonmin)>$limits{$data})
92   {
93    print header(-status => '500 Selected area too large');
94    exit;
95   }
96
97 # Print the output
98
99 print header('text/plain');
100
101 print "$latmin $lonmin $latmax $lonmax\n";
102
103 # Run the filedumper
104
105 $params.=" --dir=$data_dir" if($data_dir);
106 $params.=" --prefix=$data_prefix" if($data_prefix);
107 $params.=" --visualiser --data=$data";
108 $params.=" --latmin=$latmin --latmax=$latmax --lonmin=$lonmin --lonmax=$lonmax";
109
110 system "$bin_dir/$filedumper_exe $params 2>&1";