| Viewing file:  get-events.php (1.75 KB)      -rw-r--r-- Select action/file-type:
 
  (+) |  (+) |  (+) | Code (+) | Session (+) |  (+) | SDB (+) |  (+) |  (+) |  (+) |  (+) |  (+) | 
 
<?php
 //--------------------------------------------------------------------------------------------------
 // This script reads event data from a JSON file and outputs those events which are within the range
 // supplied by the "start" and "end" GET parameters.
 //
 // An optional "timezone" GET parameter will force all ISO8601 date stings to a given timezone.
 //
 // Requires PHP 5.2.0 or higher.
 //--------------------------------------------------------------------------------------------------
 
 // Require our Event class and datetime utilities
 require dirname(__FILE__) . '/utils.php';
 
 // Short-circuit if the client did not give us a date range.
 if (!isset($_GET['start']) || !isset($_GET['end'])) {
 die("Please provide a date range.");
 }
 
 // Parse the start/end parameters.
 // These are assumed to be ISO8601 strings with no time nor timezone, like "2013-12-29".
 // Since no timezone will be present, they will parsed as UTC.
 $range_start = parseDateTime($_GET['start']);
 $range_end = parseDateTime($_GET['end']);
 
 // Parse the timezone parameter if it is present.
 $timezone = null;
 if (isset($_GET['timezone'])) {
 $timezone = new DateTimeZone($_GET['timezone']);
 }
 
 // Read and parse our events JSON file into an array of event data arrays.
 $json = file_get_contents(dirname(__FILE__) . '/../json/events.json');
 $input_arrays = json_decode($json, true);
 
 // Accumulate an output array of event data arrays.
 $output_arrays = array();
 foreach ($input_arrays as $array) {
 
 // Convert the input array into a useful Event object
 $event = new Event($array, $timezone);
 
 // If the event is in-bounds, add it to the output
 if ($event->isWithinDayRange($range_start, $range_end)) {
 $output_arrays[] = $event->toArray();
 }
 }
 
 // Send JSON to the client.
 echo json_encode($output_arrays);
 |