Escape GET variables centrally
[busui.git] / include / common.inc.php
blob:a/include/common.inc.php -> blob:b/include/common.inc.php
<?php <?php
   
  /*
  * Copyright 2010,2011 Alexander Sadleir
   
  Licensed under the Apache License, Version 2.0 (the "License");
  you may not use this file except in compliance with the License.
  You may obtain a copy of the License at
   
  http://www.apache.org/licenses/LICENSE-2.0
   
  Unless required by applicable law or agreed to in writing, software
  distributed under the License is distributed on an "AS IS" BASIS,
  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  See the License for the specific language governing permissions and
  limitations under the License.
  */
   
date_default_timezone_set('Australia/ACT'); date_default_timezone_set('Australia/ACT');
$debugOkay = Array( $debugOkay = Array(
"session", "session",
"json", "json",
"phperror", "phperror",
"awsotp", "awsotp",
//"squallotp", //"squallotp",
"vanilleotp", //"vanilleotp",
"database", "database",
"other" "other"
); );
  $GTFSREnabled = true;
$cloudmadeAPIkey = "daa03470bb8740298d4b10e3f03d63e6"; $cloudmadeAPIkey = "daa03470bb8740298d4b10e3f03d63e6";
$googleMapsAPIkey = "ABQIAAAA95XYXN0cki3Yj_Sb71CFvBTPaLd08ONybQDjcH_VdYtHHLgZvRTw2INzI_m17_IoOUqH3RNNmlTk1Q"; $googleMapsAPIkey = "ABQIAAAA95XYXN0cki3Yj_Sb71CFvBTPaLd08ONybQDjcH_VdYtHHLgZvRTw2INzI_m17_IoOUqH3RNNmlTk1Q";
$otpAPIurl = 'http://localhost:8080/opentripplanner-api-webapp/'; $otpAPIurl = 'http://localhost:8080/opentripplanner-api-webapp/';
if (isDebug("awsotp") || php_uname('n') == "maxious.xen.prgmr.com") { if (isDebug("awsotp") || php_uname('n') == "maxious.xen.prgmr.com" || strstr(php_uname('n'),"actbus")) {
$otpAPIurl = 'http://bus-main.lambdacomplex.org:8080/opentripplanner-api-webapp/'; $otpAPIurl = 'http://bus-main.lambdacomplex.org:8080/opentripplanner-api-webapp/';
} }
if (isDebug("dotcloudotp") || php_uname('n') == "actbus-www") { if (isDebug("dotcloudotp") || php_uname('n') == "actbus-www") {
$otpAPIurl = 'http://otp.actbus.dotcloud.com/opentripplanner-api-webapp/'; $otpAPIurl = 'http://otp.actbus.dotcloud.com/opentripplanner-api-webapp/';
} }
if (isDebug("squallotp")) { if (isDebug("squallotp")) {
$otpAPIurl = 'http://10.0.1.108:5080/opentripplanner-api-webapp/'; $otpAPIurl = 'http://10.0.1.108:5080/opentripplanner-api-webapp/';
} }
if (isDebug("vanilleotp")) { if (isDebug("vanilleotp")) {
$otpAPIurl = 'http://10.0.1.135:8080/opentripplanner-api-webapp/'; $otpAPIurl = 'http://10.0.1.135:8080/opentripplanner-api-webapp/';
} }
if (isDebug("phperror")) error_reporting(E_ALL ^ E_NOTICE); if (isDebug("phperror"))
  error_reporting(E_ALL ^ E_NOTICE);
  $basePath = "";
  if (strstr($_SERVER['PHP_SELF'], "labs/")
  || strstr($_SERVER['PHP_SELF'], "myway/")
  || strstr($_SERVER['PHP_SELF'], "lib/")
  || strstr($_SERVER['PHP_SELF'], "geo/")
  || strstr($_SERVER['PHP_SELF'], "include/")
  || strstr($_SERVER['PHP_SELF'], "rtpis/")) {
  $basePath = "../";
  }
   
  function isDebugServer() {
   
  return php_sapi_name() == "cli" || strstr(php_uname('n'),"actbus") || isset($_SERVER['SERVER_NAME']) && ( $_SERVER['SERVER_NAME'] == "azusa" || $_SERVER['SERVER_NAME'] == "vanille"
  || $_SERVER['SERVER_NAME'] == "localhost" || $_SERVER['SERVER_NAME'] == "127.0.0.1" || $_SERVER['SERVER_NAME'] == "192.168.1.8" || $_SERVER['SERVER_NAME'] == "192.168.178.24");
  }
   
include_once ("common-geo.inc.php"); include_once ("common-geo.inc.php");
include_once ("common-net.inc.php"); include_once ("common-net.inc.php");
include_once ("common-transit.inc.php"); include_once ("common-transit.inc.php");
  if (!strstr($_SERVER['PHP_SELF'], "feedback")) {
  include_once ("common-db.inc.php");
  }
   
  include_once ("common-request.inc.php");
include_once ("common-session.inc.php"); include_once ("common-session.inc.php");
include_once ("common-db.inc.php"); include_once ("common-auth.inc.php");
include_once ("common-template.inc.php"); include_once ("common-template.inc.php");
include_once ("common-request.inc.php");  
  function isAnalyticsOn() {
function isDebugServer() $user_agent = $_SERVER['HTTP_USER_AGENT'];
{ return !isDebugServer() && !preg_match('/cloudkick/i', $user_agent) && !preg_match('/googlebot/i', $user_agent) &&
return $_SERVER['SERVER_NAME'] == "10.0.1.154" || $_SERVER['SERVER_NAME'] == "localhost" || $_SERVER['SERVER_NAME'] == "127.0.0.1" || !$_SERVER['SERVER_NAME']; !preg_match('/baidu/i', $user_agent);
} }
function isAnalyticsOn()  
{ function isDebug($debugReason = "other") {
return !isDebugServer(); global $debugOkay;
} return in_array($debugReason, $debugOkay, false) && isDebugServer();
function isDebug($debugReason = "other") }
{  
global $debugOkay; function debug($msg, $debugReason = "other") {
return in_array($debugReason, $debugOkay, false) && isDebugServer(); if (isDebug($debugReason))
} echo "\n<!-- " . date(DATE_RFC822) . "\n $msg -->\n";
function debug($msg, $debugReason = "other") }
{ function isIOSDevice() {
if (isDebug($debugReason)) echo "\n<!-- " . date(DATE_RFC822) . "\n $msg -->\n"; return strstr($_SERVER['HTTP_USER_AGENT'], 'iPhone') || strstr($_SERVER['HTTP_USER_AGENT'], 'iPod') || strstr($_SERVER['HTTP_USER_AGENT'], 'iPad');
} }
function isJQueryMobileDevice() function isJQueryMobileDevice() {
{ // http://forum.jquery.com/topic/what-is-the-best-way-to-detect-all-useragents-which-can-handle-jquery-mobile#14737000002087897
// http://forum.jquery.com/topic/what-is-the-best-way-to-detect-all-useragents-which-can-handle-jquery-mobile#14737000002087897 $user_agent = $_SERVER['HTTP_USER_AGENT'];
$user_agent = $_SERVER['HTTP_USER_AGENT']; return preg_match('/iphone/i', $user_agent) || preg_match('/android/i', $user_agent) || preg_match('/webos/i', $user_agent) || preg_match('/ios/i', $user_agent) || preg_match('/bada/i', $user_agent) || preg_match('/maemo/i', $user_agent) || preg_match('/meego/i', $user_agent) || preg_match('/fennec/i', $user_agent) || (preg_match('/symbian/i', $user_agent) && preg_match('/s60/i', $user_agent) && $browser['majorver'] >= 5) || (preg_match('/symbian/i', $user_agent) && preg_match('/platform/i', $user_agent) && $browser['majorver'] >= 3) || (preg_match('/blackberry/i', $user_agent) && $browser['majorver'] >= 5) || (preg_match('/opera mobile/i', $user_agent) && $browser['majorver'] >= 10) || (preg_match('/opera mini/i', $user_agent) && $browser['majorver'] >= 5);
return preg_match('/iphone/i', $user_agent) || preg_match('/android/i', $user_agent) || preg_match('/webos/i', $user_agent) || preg_match('/ios/i', $user_agent) || preg_match('/bada/i', $user_agent) || preg_match('/maemo/i', $user_agent) || preg_match('/meego/i', $user_agent) || preg_match('/fennec/i', $user_agent) || (preg_match('/symbian/i', $user_agent) && preg_match('/s60/i', $user_agent) && $browser['majorver'] >= 5) || (preg_match('/symbian/i', $user_agent) && preg_match('/platform/i', $user_agent) && $browser['majorver'] >= 3) || (preg_match('/blackberry/i', $user_agent) && $browser['majorver'] >= 5) || (preg_match('/opera mobile/i', $user_agent) && $browser['majorver'] >= 10) || (preg_match('/opera mini/i', $user_agent) && $browser['majorver'] >= 5); }
}  
function isFastDevice()  
{ function array_flatten($a, $f = array()) {
$ua = $_SERVER['HTTP_USER_AGENT']; if (!$a || !is_array($a))
$fastDevices = Array( return '';
"Mozilla/5.0 (X11;", foreach ($a as $k => $v) {
"Mozilla/5.0 (Windows;", if (is_array($v))
"Mozilla/5.0 (iP", $f = array_flatten($v, $f);
"Mozilla/5.0 (Linux; U; Android", else
"Mozilla/4.0 (compatible; MSIE" $f[$k] = $v;
); }
$slowDevices = Array( return $f;
"J2ME", }
"MIDP",  
"Opera/", function remove_spaces($string) {
"Mozilla/2.0 (compatible;", return str_replace(' ', '', $string);
"Mozilla/3.0 (compatible;" }
);  
return true; function object2array($object) {
} if (is_object($object)) {
function array_flatten($a, $f = array()) foreach ($object as $key => $value) {
{ $array[$key] = $value;
if (!$a || !is_array($a)) return ''; }
foreach ($a as $k => $v) { } else {
if (is_array($v)) $f = array_flatten($v, $f); $array = $object;
else $f[$k] = $v; }
} return $array;
return $f; }
}  
function remove_spaces($string) function startsWith($haystack, $needle, $case = true) {
{ if ($case) {
return str_replace(' ', '', $string); return (strcmp(substr($haystack, 0, strlen($needle)), $needle) === 0);
} }
function object2array($object) return (strcasecmp(substr($haystack, 0, strlen($needle)), $needle) === 0);
{ }
if (is_object($object)) {  
foreach ($object as $key => $value) { function endsWith($haystack, $needle, $case = true) {
$array[$key] = $value; if ($case) {
} return (strcmp(substr($haystack, strlen($haystack) - strlen($needle)), $needle) === 0);
} }
else { return (strcasecmp(substr($haystack, strlen($haystack) - strlen($needle)), $needle) === 0);
$array = $object; }
}  
return $array; function sksort(&$array, $subkey = "id", $sort_ascending = false) {
} if (count($array))
function startsWith($haystack, $needle, $case = true) $temp_array[key($array)] = array_shift($array);
{ foreach ($array as $key => $val) {
if ($case) { $offset = 0;
return (strcmp(substr($haystack, 0, strlen($needle)) , $needle) === 0); $found = false;
} foreach ($temp_array as $tmp_key => $tmp_val) {
return (strcasecmp(substr($haystack, 0, strlen($needle)) , $needle) === 0); if (!$found and strtolower($val[$subkey]) > strtolower($tmp_val[$subkey])) {
} $temp_array = array_merge((array) array_slice($temp_array, 0, $offset), array(
  $key => $val
function endsWith($haystack, $needle, $case = true) ), array_slice($temp_array, $offset));
{ $found = true;
if ($case) { }
return (strcmp(substr($haystack, strlen($haystack) - strlen($needle)) , $needle) === 0); $offset++;
} }
return (strcasecmp(substr($haystack, strlen($haystack) - strlen($needle)) , $needle) === 0); if (!$found)
} $temp_array = array_merge($temp_array, array(
function bracketsMeanNewLine($input) $key => $val
{ ));
return str_replace(")", "</small>", str_replace("(", "<br><small>", $input)); }
} if ($sort_ascending)
function sksort(&$array, $subkey = "id", $sort_ascending = false) $array = array_reverse($temp_array);
{ else
if (count($array)) $temp_array[key($array) ] = array_shift($array); $array = $temp_array;
foreach ($array as $key => $val) { }
$offset = 0;  
$found = false; function sktimesort(&$array, $subkey = "id", $sort_ascending = false) {
foreach ($temp_array as $tmp_key => $tmp_val) { if (count($array))
if (!$found and strtolower($val[$subkey]) > strtolower($tmp_val[$subkey])) { $temp_array[key($array)] = array_shift($array);
$temp_array = array_merge((array)array_slice($temp_array, 0, $offset) , array( foreach ($array as $key => $val) {
$key => $val $offset = 0;
) , array_slice($temp_array, $offset)); $found = false;
$found = true; foreach ($temp_array as $tmp_key => $tmp_val) {
} if (!$found and strtotime($val[$subkey]) > strtotime($tmp_val[$subkey])) {
$offset++; $temp_array = array_merge((array) array_slice($temp_array, 0, $offset), array(
} $key => $val
if (!$found) $temp_array = array_merge($temp_array, array( ), array_slice($temp_array, $offset));
$key => $val $found = true;
)); }
} $offset++;
if ($sort_ascending) $array = array_reverse($temp_array); }
else $array = $temp_array; if (!$found)
} $temp_array = array_merge($temp_array, array(
function sktimesort(&$array, $subkey = "id", $sort_ascending = false) $key => $val
{ ));
if (count($array)) $temp_array[key($array) ] = array_shift($array); }
foreach ($array as $key => $val) { if ($sort_ascending && isset($temp_array))
$offset = 0; $array = array_reverse($temp_array);
$found = false; else
foreach ($temp_array as $tmp_key => $tmp_val) { $array = $temp_array;
if (!$found and strtotime($val[$subkey]) > strtotime($tmp_val[$subkey])) { }
$temp_array = array_merge((array)array_slice($temp_array, 0, $offset) , array(  
$key => $val function r_implode($glue, $pieces) {
) , array_slice($temp_array, $offset)); foreach ($pieces as $r_pieces) {
$found = true; if (is_array($r_pieces)) {
} $retVal[] = r_implode($glue, $r_pieces);
$offset++; } else {
} $retVal[] = $r_pieces;
if (!$found) $temp_array = array_merge($temp_array, array( }
$key => $val }
)); return implode($glue, $retVal);
} }
if ($sort_ascending) $array = array_reverse($temp_array);  
else $array = $temp_array;  
}  
function r_implode( $glue, $pieces )  
{  
foreach( $pieces as $r_pieces )  
{  
if( is_array( $r_pieces ) )  
{  
$retVal[] = r_implode( $glue, $r_pieces );  
}  
else  
{  
$retVal[] = $r_pieces;  
}  
}  
return implode( $glue, $retVal );  
}  
?>