From faad2aedb8955d747cb9cc48897eb4d39116b81e Mon Sep 17 00:00:00 2001 From: Jacek Kowalski <Jacek@jacekk.info> Date: Sun, 14 Apr 2019 09:52:00 +0000 Subject: [PATCH] Use === comparisons in XHR error handlers --- proxy.php | 77 ++++++++++++++++++++++++++++++++++++-- 1 files changed, 72 insertions(+), 5 deletions(-) diff --git a/proxy.php b/proxy.php index ff9eb34..e764cb6 100644 --- a/proxy.php +++ b/proxy.php @@ -1,20 +1,87 @@ <?php -$base_proxy = 'http://www.ttss.krakow.pl/internetservice/services'; +function is_number($str) { + $str = (string)$str; + + return + ctype_digit($str) + OR + ( + substr($str, 0, 1) == '-' + AND + ctype_digit(substr($str, 1)) + ); +} + +$base_proxy = 'http://www.ttss.krakow.pl/internetservice'; $method = [ - '/lookup/autocomplete/json' => [ + '/services/lookup/autocomplete/json' => [ 'query' => function() { return TRUE; }, ], - '/passageInfo/stopPassages/stop' => [ + '/services/passageInfo/stopPassages/stop' => [ 'stop' => 'ctype_alnum', 'mode' => function($mode) { return in_array($mode, ['arrival', 'departure']); }, + #'startTime' => 'ctype_digit', + #'timeFrame' => 'ctype_digit', ], - '/routeInfo/routeStops' => [ - 'routeId' => 'ctype_alnum' + '/services/passageInfo/stopPassages/stopPoint' => [ + 'stopPoint' => 'is_number', + 'mode' => function($mode) { return in_array($mode, ['arrival', 'departure']); }, + #'startTime' => 'ctype_digit', + #'timeFrame' => 'ctype_digit', ], + '/services/tripInfo/tripPassages' => [ + 'tripId' => 'ctype_digit', + 'mode' => function($mode) { return in_array($mode, ['arrival', 'departure']); }, + #'vehicleId' => 'ctype_digit', + ], + '/services/routeInfo/routeStops' => [ + 'routeId' => 'ctype_alnum', + ], + '/services/stopInfo/stop' => [ + 'stop' => 'is_number', + ], + '/services/stopInfo/stopPoint' => [ + 'stopPoint' => 'is_number', + ], + + '/geoserviceDispatcher/services/stopinfo/stops' => [ + 'left' => 'is_number', + 'bottom' => 'is_number', + 'right' => 'is_number', + 'top' => 'is_number', + ], + '/geoserviceDispatcher/services/stopinfo/stopPoints' => [ + 'left' => 'is_number', + 'bottom' => 'is_number', + 'right' => 'is_number', + 'top' => 'is_number', + ], + '/geoserviceDispatcher/services/pathinfo/route' => [ + 'id' => 'is_number', + 'direction' => 'is_number', + ], + '/geoserviceDispatcher/services/pathinfo/vehicle' => [ + 'id' => 'is_number', + ], + '/geoserviceDispatcher/services/vehicleinfo/vehicles' => [ + 'lastUpdate' => 'ctype_digit', + 'positionType' => function($type) { return in_array($type, ['RAW', 'CORRECTED']); }, + 'colorType' => function($type) { return in_array($type, ['ROUTE_BASED']); }, + ], +]; +$rewrite = [ + '/lookup/autocomplete/json' => '/services/lookup/autocomplete/json', + '/passageInfo/stopPassages/stop' => '/services/passageInfo/stopPassages/stop', + '/routeInfo/routeStops' => '/services/routeInfo/routeStops', + '/internetservice/geoserviceDispatcher/services/pathinfo/vehicle' => '/geoserviceDispatcher/services/pathinfo/vehicle', ]; $path = $_SERVER['PATH_INFO']; +if(isset($rewrite[$path])) { + $path = $rewrite[$path]; +} + if(!isset($method[$path])) { header('HTTP/1.1 403 Forbidden'); die('Forbidden'); -- Gitblit v1.9.1