More security/sanitizing fixes
[busui.git] / trip.php
blob:a/trip.php -> blob:b/trip.php
<?php <?php
include('common.inc.php'); include ('include/common.inc.php');
$tripid = filter_var($_REQUEST['tripid'],FILTER_SANITIZE_NUMBER_INT); $tripid = filter_var($_REQUEST['tripid'], FILTER_SANITIZE_NUMBER_INT);
$stopid = filter_var($_REQUEST['stopid'],FILTER_SANITIZE_NUMBER_INT); $stopid = filter_var($_REQUEST['stopid'], FILTER_SANITIZE_NUMBER_INT);
$routeid = filter_var($_REQUEST['routeid'],FILTER_SANITIZE_NUMBER_INT); $routeid = filter_var($_REQUEST['routeid'], FILTER_SANITIZE_NUMBER_INT);
if ($_REQUEST['routeid']) { $routetrips = Array();
$url = $APIurl."/json/routetrips?route_id=".$routeid; if ($_REQUEST['routeid'] && !$_REQUEST['tripid']) {
$trips = json_decode(getPage($url)); $tripid = 0;
debug(print_r($trips,true)); $url = $APIurl . "/json/routetrips?route_id=" . $routeid;
foreach ($trips as $trip) $routetrips = json_decode(getPage($url));
{ foreach ($routetrips as $trip) {
if ($trip[0] < midnight_seconds()) { if ($trip[2] > midnight_seconds()) {
$tripid = $trip[1]; $tripid = $trip[1];
break; break;
} }
} }
if (!($tripid > 0)) $tripid = $trips[0][1]; if ($tripid == 0) $tripid = $routetrips[0][1];
} }
$url = $APIurl."/json/triprows?trip=".$tripid; $url = $APIurl . "/json/triprows?trip=" . $tripid;
$trips = array_flatten(json_decode(getPage($url))); $trips = array_flatten(json_decode(getPage($url)));
debug(print_r($trips,true)); if (sizeof($routetrips) == 0) {
include_header("Stops on ". $trips[1]->route_short_name . ' '. $trips[1]->route_long_name,"trip"); $routeid = $trips[1]->route_id;
if (isMetricsOn()) { $url = $APIurl . "/json/routetrips?route_id=" . $trips[1]->route_id;
// Create a new Instance of the tracker $routetrips = json_decode(getPage($url));
$owa = new owa_php(); }
// Set the ID of the site being tracked include_header("Stops on " . $trips[1]->route_short_name . ' ' . $trips[1]->route_long_name, "trip");
$owa->setSiteId($owaSiteID); trackEvent("Route/Trip View","View Route", $trips[1]->route_short_name . ' ' . $trips[1]->route_long_name, $trips[1]->route_id);
// Create a new event object $url = $APIurl . "/json/tripstoptimes?trip=" . $tripid;
$event = $owa->makeEvent();  
// Set the Event Type, in this case a "video_play"  
$event->setEventType('view_trip');  
// Set a property  
$event->set('trip_id',$tripid);  
$event->set('route_id',$routeid);  
$event->set('stop_id',$stopid);  
// Track the event  
$owa->trackEvent($event);  
}  
timePlaceSettings();  
echo ' <ul data-role="listview" data-inset="true">';  
   
   
$url = $APIurl."/json/tripstoptimes?trip=".$tripid;  
   
$json = json_decode(getPage($url)); $json = json_decode(getPage($url));
debug(print_r($json,true));  
$stops = $json[0]; $stops = $json[0];
$times = $json[1]; $times = $json[1];
foreach ($stops as $key => $row) $viaPoints = Array();
{ foreach ($stops as $stop) {
echo '<li>'; if (!startsWith($stop[5], "Wj")) {
echo '<h3><a href="stop.php?stopid='.$row[0].'">'.bracketsMeanNewLine($row[1]); $viaPoints[] = $stop[1];
if ($row[0] == $stopid) echo "<br><small> Current Location</small>"; }
echo '</a></h3>'; }
echo '<p class="ui-li-aside">'.midnight_seconds_to_time($times[$key]).'</p>'; echo '<p><h2>Via:</h2> ' . implode(", ", $viaPoints) . '</small></p>';
echo '</li>'; echo '<p><h2>Other Trips:</h2> ';
  foreach ($routetrips as $othertrip) {
  echo '<a href="trip.php?tripid=' . $othertrip[1] . "&routeid=" . $routeid . '">' . midnight_seconds_to_time($othertrip[0]) . '</a> ';
  }
  flush(); @ob_flush();
  echo '</p><p><h2>Other directions/timing periods:</h2> ';
  $url = $APIurl . "/json/routesearch?routeshortname=" . rawurlencode($trips[1]->route_short_name);
  $json = json_decode(getPage($url));
  foreach ($json as $row) {
  if ($row[0] != $routeid) echo '<a href="trip.php?routeid=' . $row[0] . '">' . $row[2] . ' (' . ucwords($row[3]) . ')</a> ';
  }
  flush(); @ob_flush();
  echo ' <ul data-role="listview" data-inset="true">';
  echo '<li data-role="list-divider">' . midnight_seconds_to_time($times[0]) . '-' . midnight_seconds_to_time($times[sizeof($times) - 1]) . ' ' . $trips[1]->route_long_name . '</li>';
  $stopsGrouped = Array();
  foreach ($stops as $key => $row) {
  if (($stops[$key][1] != $stops[$key + 1][1]) || $key + 1 >= sizeof($stops)) {
  echo '<li>';
  if (!startsWith($row[5], "Wj")) echo '<img src="css/images/time.png" alt="Timing Point" class="ui-li-icon">';
  if (sizeof($stopsGrouped) > 0) {
  // print and empty grouped stops
  // subsequent duplicates
  $stopsGrouped["stop_ids"][] = $row[0];
  $stopsGrouped["endTime"] = $times[$key];
  echo '<a href="stop.php?stopids=' . implode(",", $stopsGrouped['stop_ids']) . '">';
  echo '<p class="ui-li-aside">' . midnight_seconds_to_time($stopsGrouped['startTime']) . ' to ' . midnight_seconds_to_time($stopsGrouped['endTime']) . '</p>';
  echo bracketsMeanNewLine($row[1]);
  echo '</a></li>';
  flush(); @ob_flush();
  $stopsGrouped = Array();
  }
  else {
  // just a normal stop
  echo '<a href="stop.php?stopid=' . $row[0] . (startsWith($row[5], "Wj") ? '&stopcode=' . $row[5] : "") . '">';
  echo '<p class="ui-li-aside">' . midnight_seconds_to_time($times[$key]) . '</p>';
  echo bracketsMeanNewLine($row[1]);
  echo '</a></li>';
  flush(); @ob_flush();
  }
  }
  else {
  // this is a duplicated line item
  if ($key - 1 <= 0 || ($stops[$key][1] != $stops[$key - 1][1])) {
  // first duplicate
  $stopsGrouped = Array(
  "name" => $row[1],
  "startTime" => $times[$key],
  "stop_ids" => Array(
  $row[0]
  )
  );
  }
  else {
  // subsequent duplicates
  $stopsGrouped["stop_ids"][] = $row[0];
  $stopsGrouped["endTime"] = $times[$key];
  }
  }
} }
echo '</ul>'; echo '</ul>';
include_footer(); include_footer();
?> ?>