aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--app/Resources/views/default/TrainSchedule.html.twig24
-rw-r--r--src/AppBundle/Controller/TrainScheduleController.php85
2 files changed, 88 insertions, 21 deletions
diff --git a/app/Resources/views/default/TrainSchedule.html.twig b/app/Resources/views/default/TrainSchedule.html.twig
index a2c8572..efc94ec 100644
--- a/app/Resources/views/default/TrainSchedule.html.twig
+++ b/app/Resources/views/default/TrainSchedule.html.twig
@@ -4,25 +4,21 @@
<table class="table">
<thead class="thead">
<tr class="tr">
- <th>Track</th>
- <th>Train type</th>
- <th>Train number</th>
- <th>Destination name</th>
- <th>Arrival</th>
- <th>Departure</th>
- <th>Delay</th>
+ <th>Name</th>
+ <th>Time</th>
+ <th>Date</th>
+ <th>Destination</th>
+ <th>AQI</th>
</tr>
</thead>
<tbody class="tbody">
<tr class="tr">
{% for table in data %}
- <td class="td">{{ table.Track }}</td>
- <td class="td">{{ table.TrainType }}</td>
- <td class="td">{{ table.TrainNumber }}</td>
- <td class="td">{{ table.DestinationName }}</td>
- <td class="td">{{ table.ScheduledArrival }}</td>
- <td class="td">{{ table.ScheduledDeparture }}</td>
- <td class="td">{{ table.DepartureDelay }}</td>
+ <td class="td">{{ table.name }}</td>
+ <td class="td">{{ table.time }}</td>
+ <td class="td">{{ table.date }}</td>
+ <td class="td">{{ table.finalStop }}</td>
+ <td class="td">{{ table.direction }}</td>
</tr>
</tbody>
{% endfor %}
diff --git a/src/AppBundle/Controller/TrainScheduleController.php b/src/AppBundle/Controller/TrainScheduleController.php
index 927be0c..d3a936c 100644
--- a/src/AppBundle/Controller/TrainScheduleController.php
+++ b/src/AppBundle/Controller/TrainScheduleController.php
@@ -9,8 +9,8 @@
namespace AppBundle\Controller;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
-use SoapClient;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
+use AppBundle\Utils\Aqi;
class TrainScheduleController extends Controller
{
@@ -20,12 +20,83 @@ class TrainScheduleController extends Controller
public function GetSchedule()
{
- $client = new SoapClient( "http://traindata.dsb.dk/stationdeparture/Service.asmx?WSDL" );
- $params = array( 'request' => array( 'UICNumber' => '8600617' ) );
- $response = $client->GetStationQueue( $params );
- $data = $response->GetStationQueueResult->Trains->Queue;
- $parametersToTwig = array("data" => $data);
+ $url = "http://xmlopen.rejseplanen.dk/bin/rest.exe/multiDepartureBoard?id1=008600617&date=08.12.17&time=00%3A00&useBus=0&format=json";
- return $this->render('default/TrainSchedule.html.twig',$parametersToTwig);
+ // Get cURL resource
+ $curl = curl_init();
+ curl_setopt($curl, CURLOPT_URL, $url);
+ curl_setopt($curl, CURLOPT_HTTPHEADER, array('Content-type: application/json')); // Assuming you're requesting JSON
+ curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
+ // Send the request & save response to $resp
+ $resp = curl_exec($curl);
+ // Close request to clear up some resources
+ curl_close($curl);
+
+ $trains = json_decode($resp, true);
+ $trains = $trains['MultiDepartureBoard']['Departure'];
+
+ // Get cURL resource
+ $curl = curl_init();
+ curl_setopt($curl, CURLOPT_URL, "https://pollutometerapi.azurewebsites.net/api/Readings/lastweek");
+ curl_setopt($curl, CURLOPT_HTTPHEADER, array('Content-type: application/json')); // Assuming you're requesting JSON
+ curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
+ // Send the request & save response to $resp
+ $resp = curl_exec($curl);
+ // Close request to clear up some resources
+ curl_close($curl);
+
+ $readings = json_decode($resp, true);
+
+
+ for ($i = 0; $i < count($trains); $i++) {
+ $closest = 5301590400;
+ $time = $trains[$i]['time'];
+ $date = $trains[$i]['date'];
+ $datesplit = explode(".", $date);
+ $datetime = $datesplit[0] . "." . $datesplit[1] . ".20" . $datesplit[2] . " " . $time;
+ $trainTimeStamp = strtotime($datetime) + 3600;
+
+ foreach ($readings as $reading) {
+ if (abs($reading['TimeStamp'] - $trainTimeStamp) < abs($closest - $trainTimeStamp))
+ $closest = $reading['TimeStamp'];
+ }
+
+ $closestReading = $readings[0];
+ foreach ($readings as $reading)
+ {
+ if($reading['TimeStamp'] == $closest) $closestReading = $reading;
+ }
+ $trains[$i]['direction'] = $this->getAqi($closestReading);
+ }
+
+ $parametersToTwig = array("data" => $trains);
+
+ return $this->render('default/TrainSchedule.html.twig', $parametersToTwig);
+ }
+
+ private function getAqi(array $data)
+ {
+ $aqi = new Aqi();
+
+ $table = array(
+ 'Co' => array('breakpoints' => [0, 4.4, 4.5, 9.4, 9.5, 12.4, 12.5, 15.4, 15.5, 30.4, 30.5, 40.4, 40.5, 50.4],
+ 'aq' => [0, 50, 51, 100, 101, 150, 151, 200, 201, 300, 301, 400, 401, 500]),
+ 'So' => array('breakpoints' => [0.000, 0.034, 0.035, 0.144, 0.145, 0.224, 0.225, 0.304, 0.305, 0.604, 0.605, 0.804, 0.805, 1.004],
+ 'aq' => [0, 50, 51, 100, 101, 150, 151, 200, 201, 300, 301, 400, 401, 500]),
+ 'No' => array('breakpoints' => [0,0.05,0.08,0.10,0.15,0.20,0.25 ,0.31,0.65, 1.24, 1.25, 1.64, 1.65, 2.04],
+ 'aq' => [0 ,50 ,51 ,100 ,101 ,150 ,151,200,201, 300, 301, 400, 401, 500])
+ );
+
+ $tableObj = json_decode(json_encode($table));
+
+ $arr = [];
+ $CO = is_nan($aqi->calculateAQI("Co", $data['Co'], $tableObj)) ? 0 : $aqi->calculateAQI("Co", $data['Co'], $tableObj);
+ $SO = is_nan($aqi->calculateAQI("So", $data['So'], $tableObj)) ? 0 : $aqi->calculateAQI("So", $data['So'], $tableObj);
+ $NO = is_nan($aqi->calculateAQI("No", $data['No'], $tableObj)) ? 0 : $aqi->calculateAQI("No", $data['No'], $tableObj);
+
+ array_push($arr, $CO, $SO, $NO);
+ $max = max($arr);
+
+ return $max;
}
} \ No newline at end of file