More security/sanitizing fixes
[busui.git] / trip.php
blob:a/trip.php -> blob:b/trip.php
<?php <?php
include('common.inc.php');  
$tripid = filter_var($_REQUEST['tripid'],FILTER_SANITIZE_NUMBER_INT); /*
$stopid = filter_var($_REQUEST['stopid'],FILTER_SANITIZE_NUMBER_INT); * Copyright 2010,2011 Alexander Sadleir
$routeid = filter_var($_REQUEST['routeid'],FILTER_SANITIZE_NUMBER_INT);  
if ($_REQUEST['routeid']) { Licensed under the Apache License, Version 2.0 (the "License");
$url = $APIurl."/json/routetrips?route_id=".$routeid; you may not use this file except in compliance with the License.
$trips = json_decode(getPage($url)); You may obtain a copy of the License at
debug(print_r($trips,true));  
foreach ($trips as $trip) http://www.apache.org/licenses/LICENSE-2.0
{  
if ($trip[0] < midnight_seconds()) { Unless required by applicable law or agreed to in writing, software
$tripid = $trip[1]; distributed under the License is distributed on an "AS IS" BASIS,
break; 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.
  */
  include ('include/common.inc.php');
  $routetrips = Array();
  if (isset($routeid) && !isset($tripid)) {
  $trip = getRouteNextTrip($routeid);
  $tripid = $trip['trip_id'];
  } else {
  $trip = getTrip($tripid);
  $routeid = $trip["route_id"];
  }
   
  include_header("Stops on " . $trip['route_short_name'] . ' ' . $trip['route_long_name'], "trip");
  trackEvent("Route/Trip View", "View Route", $trip['route_short_name'] . ' ' . $trip['route_long_name'], $routeid);
  echo '<span class="content-secondary">';
  echo '<a href="' . $trip['route_url'] . '">View Original Timetable/Map</a>';
  echo '<h2>Via:</h2> <small>' . viaPointNames($tripid) . '</small>';
  echo '<h2>Other Trips:</h2> ';
  $routeTrips = getRouteTrips($routeid);
  foreach ($routeTrips as $key => $othertrip) {
  if ($othertrip['trip_id'] != $tripid) {
  echo '<a href="trip.php?tripid=' . $othertrip['trip_id'] . "&amp;routeid=" . $routeid . '">' . str_replace(" ", ":00", str_replace(":00", " ", $othertrip['arrival_time'])) . '</a> ';
  } else {
  // skip this trip but look forward/back
  if ($key - 1 > 0)
  $prevTrip = $routeTrips[$key - 1]['trip_id'];
  if ($key + 1 < sizeof($routeTrips))
  $nextTrip = $routeTrips[$key + 1]['trip_id'];
  }
  }
  flush();
  @ob_flush();
  echo '<h2>Other directions/timing periods:</h2> ';
  $otherDir = 0;
  foreach (getRoutesByNumber($trip['route_short_name']) as $row) {
  if ($row['route_id'] != $routeid) {
  echo '<a href="trip.php?routeid=' . $row['route_id'] . '">' . $row['route_long_name'] . ' (' . ucwords($row['service_id']) . ')</a> ';
  $otherDir++;
  }
  }
  if ($otherDir == 0)
  echo "None";
  echo '</span><span class="content-primary">';
  flush();
  @ob_flush();
  echo "<div class='ui-header' style='overflow: visible; height: 1.5em'>";
  if ($nextTrip)
  echo '<a href="trip.php?tripid=' . $nextTrip . "&amp;routeid=" . $routeid . '" data-icon="arrow-r" class="ui-btn-right">Next Trip</a>';
  if ($prevTrip)
  echo '<a href="trip.php?tripid=' . $prevTrip . "&amp;routeid=" . $routeid . '" data-icon="arrow-l" class="ui-btn-left">Previous Trip</a>';
  echo "</div>";
  echo ' <ul data-role="listview" data-inset="true">';
  $stopsGrouped = Array();
  $tripStopTimes = getTimeInterpolatedTrip($tripid);
  echo '<li data-role="list-divider">' . $tripStopTimes[0]['arrival_time'] . ' to ' . $tripStopTimes[sizeof($tripStopTimes) - 1]['arrival_time'] . ' ' . $trip['route_long_name'] . ' (' . ucwords($tripStopTimes[0]['service_id']) . ')</li>';
  foreach ($tripStopTimes as $key => $tripStopTime) {
  if ($key + 1 > sizeof($tripStopTimes) || ($tripStopTimes[$key]["stop_name"] != $tripStopTimes[$key + 1]["stop_name"])) {
  echo '<li>';
   
  if (sizeof($stopsGrouped) > 0) {
  // print and empty grouped stops
  // subsequent duplicates
  $stopsGrouped["stop_ids"][] = $tripStopTime['stop_id'];
  $stopsGrouped["endTime"] = $tripStopTime['arrival_time'];
  echo '<a href="stop.php?stopids=' . implode(",", $stopsGrouped['stop_ids']) . '">';
  echo '<p class="ui-li-aside">' . $stopsGrouped['startTime'] . ' to ' . $stopsGrouped['endTime'];
  if (isset($_SESSION['lat']) && isset($_SESSION['lon'])) {
  echo '<br>' . distance($tripStopTime['stop_lat'], $tripStopTime['stop_lon'], $_SESSION['lat'], $_SESSION['lon'], true) . 'm away';
} }
} echo '</p>';
if (!($tripid > 0)) $tripid = $trips[0][1]; echo $tripStopTime["stop_name"];
} echo '</a></li>';
$url = $APIurl."/json/triprows?trip=".$tripid; flush();
$trips = array_flatten(json_decode(getPage($url))); @ob_flush();
debug(print_r($trips,true)); $stopsGrouped = Array();
include_header("Stops on ". $trips[1]->route_short_name . ' '. $trips[1]->route_long_name,"trip"); } else {
if (isMetricsOn()) { // just a normal stop
// Create a new Instance of the tracker echo '<a href="stop.php?stopid=' . $tripStopTime['stop_id'] . (startsWith($tripStopTime['stop_code'], "Wj") ? '&amp;stopcode=' . $tripStopTime['stop_code'] : "") . '">';
$owa = new owa_php(); echo '<p class="ui-li-aside">' . $tripStopTime['arrival_time'];
// Set the ID of the site being tracked if (isset($_SESSION['lat']) && isset($_SESSION['lon'])) {
$owa->setSiteId($owaSiteID); echo '<br>' . distance($tripStopTime['stop_lat'], $tripStopTime['stop_lon'], $_SESSION['lat'], $_SESSION['lon'], true) . 'm away';
// Create a new event object }
$event = $owa->makeEvent(); echo '</p>';
// Set the Event Type, in this case a "video_play" echo $tripStopTime['stop_name'];
$event->setEventType('view_trip'); echo '</a></li>';
// Set a property flush();
$event->set('trip_id',$tripid); @ob_flush();
$event->set('route_id',$routeid); }
$event->set('stop_id',$stopid); } else {
// Track the event // this is a duplicated line item
$owa->trackEvent($event); if ($key - 1 <= 0 || ($tripStopTimes[$key]['stop_name'] != $tripStopTimes[$key - 1]['stop_name'])) {
  // first duplicate
  $stopsGrouped = Array(
  "name" => $tripStopTime['stop_name'],
  "startTime" => $tripStopTime['arrival_time'],
  "stop_ids" => Array(
  $tripStopTime['stop_id']
  )
  );
  } else {
  // subsequent duplicates
  $stopsGrouped["stop_ids"][] = $tripStopTime['stop_id'];
  $stopsGrouped["endTime"] = $tripStopTime['arrival_time'];
  }
} }
timePlaceSettings();  
echo ' <ul data-role="listview" data-inset="true">';  
   
   
$url = $APIurl."/json/tripstoptimes?trip=".$tripid;  
   
$json = json_decode(getPage($url));  
debug(print_r($json,true));  
$stops = $json[0];  
$times = $json[1];  
foreach ($stops as $key => $row)  
{  
echo '<li>';  
echo '<h3><a href="stop.php?stopid='.$row[0].'">'.bracketsMeanNewLine($row[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 '</li>';  
} }
echo '</ul>'; echo '</ul>';
  echo '</span>';
include_footer(); include_footer();
?> ?>