|
@ -41,6 +41,12 @@ class TripComplete extends Job implements SelfHandling, ShouldQueue |
|
|
// Load the data from the start and end times
|
|
|
// Load the data from the start and end times
|
|
|
$start = new DateTime($this->_data['properties']['start']); |
|
|
$start = new DateTime($this->_data['properties']['start']); |
|
|
$end = new DateTime($this->_data['properties']['end']); |
|
|
$end = new DateTime($this->_data['properties']['end']); |
|
|
|
|
|
|
|
|
|
|
|
if($end->format('U') - $start->format('U') < 15) { |
|
|
|
|
|
Log::info("Skipping trip since it was too short"); |
|
|
|
|
|
return; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
$results = $qz->queryRange($start, $end); |
|
|
$results = $qz->queryRange($start, $end); |
|
|
$features = []; |
|
|
$features = []; |
|
|
foreach($results as $id=>$record) { |
|
|
foreach($results as $id=>$record) { |
|
@ -67,26 +73,26 @@ class TripComplete extends Job implements SelfHandling, ShouldQueue |
|
|
|
|
|
|
|
|
// If there are no start/end coordinates in the request, use the first and last coordinates
|
|
|
// If there are no start/end coordinates in the request, use the first and last coordinates
|
|
|
if(count($features)) { |
|
|
if(count($features)) { |
|
|
if(!array_key_exists('start-coordinates', $this->_data['properties'])) { |
|
|
|
|
|
$this->_data['properties']['start-coordinates'] = $features[0]->geometry->coordinates; |
|
|
|
|
|
|
|
|
if(!array_key_exists('start_location', $this->_data['properties'])) { |
|
|
|
|
|
$this->_data['properties']['start_location'] = $features[0]; |
|
|
} |
|
|
} |
|
|
if(!array_key_exists('end-coordinates', $this->_data['properties'])) { |
|
|
|
|
|
$this->_data['properties']['end-coordinates'] = $features[count($features)-1]->geometry->coordinates; |
|
|
|
|
|
|
|
|
if(!array_key_exists('end_location', $this->_data['properties'])) { |
|
|
|
|
|
$this->_data['properties']['end_location'] = $features[count($features)-1]; |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
$startAdr = false; |
|
|
$startAdr = false; |
|
|
if(array_key_exists('start-coordinates', $this->_data['properties'])) { |
|
|
|
|
|
|
|
|
if(array_key_exists('start_location', $this->_data['properties'])) { |
|
|
// Reverse geocode the start and end location to get an h-adr
|
|
|
// Reverse geocode the start and end location to get an h-adr
|
|
|
$startAdr = [ |
|
|
$startAdr = [ |
|
|
'type' => 'h-adr', |
|
|
'type' => 'h-adr', |
|
|
'properties' => [ |
|
|
'properties' => [ |
|
|
'latitude' => $this->_data['properties']['start-coordinates'][1], |
|
|
|
|
|
'longitude' => $this->_data['properties']['start-coordinates'][0], |
|
|
|
|
|
|
|
|
'latitude' => $this->_data['properties']['start_location']['geometry']['coordinates'][1], |
|
|
|
|
|
'longitude' => $this->_data['properties']['start_location']['geometry']['coordinates'][0], |
|
|
] |
|
|
] |
|
|
]; |
|
|
]; |
|
|
Log::info('Looking up start location'); |
|
|
Log::info('Looking up start location'); |
|
|
$start = self::geocode($this->_data['properties']['start-coordinates'][1], $this->_data['properties']['start-coordinates'][0]); |
|
|
|
|
|
|
|
|
$start = self::geocode($startAdr['properties']['latitude'], $startAdr['properties']['longitude']); |
|
|
if($start) { |
|
|
if($start) { |
|
|
$startAdr['properties']['locality'] = $start->locality; |
|
|
$startAdr['properties']['locality'] = $start->locality; |
|
|
$startAdr['properties']['region'] = $start->region; |
|
|
$startAdr['properties']['region'] = $start->region; |
|
@ -98,16 +104,16 @@ class TripComplete extends Job implements SelfHandling, ShouldQueue |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
$endAdr = false; |
|
|
$endAdr = false; |
|
|
if(array_key_exists('end-coordinates', $this->_data['properties'])) { |
|
|
|
|
|
|
|
|
if(array_key_exists('end_location', $this->_data['properties'])) { |
|
|
$endAdr = [ |
|
|
$endAdr = [ |
|
|
'type' => 'h-adr', |
|
|
'type' => 'h-adr', |
|
|
'properties' => [ |
|
|
'properties' => [ |
|
|
'latitude' => $this->_data['properties']['end-coordinates'][1], |
|
|
|
|
|
'longitude' => $this->_data['properties']['end-coordinates'][0], |
|
|
|
|
|
|
|
|
'latitude' => $this->_data['properties']['end_location']['geometry']['coordinates'][1], |
|
|
|
|
|
'longitude' => $this->_data['properties']['end_location']['geometry']['coordinates'][0], |
|
|
] |
|
|
] |
|
|
]; |
|
|
]; |
|
|
Log::info('Looking up end location'); |
|
|
Log::info('Looking up end location'); |
|
|
$end = self::geocode($this->_data['properties']['end-coordinates'][1], $this->_data['properties']['end-coordinates'][0]); |
|
|
|
|
|
|
|
|
$end = self::geocode($endAdr['properties']['latitude'], $endAdr['properties']['longitude']); |
|
|
if($end) { |
|
|
if($end) { |
|
|
$endAdr['properties']['locality'] = $end->locality; |
|
|
$endAdr['properties']['locality'] = $end->locality; |
|
|
$endAdr['properties']['region'] = $end->region; |
|
|
$endAdr['properties']['region'] = $end->region; |
|
@ -129,11 +135,6 @@ class TripComplete extends Job implements SelfHandling, ShouldQueue |
|
|
$endDate->setTimeZone(new DateTimeZone($end->timezone)); |
|
|
$endDate->setTimeZone(new DateTimeZone($end->timezone)); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if($endDate->format('U') - $startDate->format('U') < 15) { |
|
|
|
|
|
Log::info("Skipping trip since it was too short"); |
|
|
|
|
|
return; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
$params = [ |
|
|
$params = [ |
|
|
'h' => 'entry', |
|
|
'h' => 'entry', |
|
|
'published' => $endDate->format('c'), |
|
|
'published' => $endDate->format('c'), |
|
@ -144,9 +145,6 @@ class TripComplete extends Job implements SelfHandling, ShouldQueue |
|
|
'start' => $startDate->format('c'), |
|
|
'start' => $startDate->format('c'), |
|
|
'end' => $endDate->format('c'), |
|
|
'end' => $endDate->format('c'), |
|
|
'route' => 'route.json' |
|
|
'route' => 'route.json' |
|
|
// TODO: avgpace for runs
|
|
|
|
|
|
// TODO: avgspeed for bike rides
|
|
|
|
|
|
// TODO: avg heart rate if available
|
|
|
|
|
|
] |
|
|
] |
|
|
] |
|
|
] |
|
|
]; |
|
|
]; |
|
@ -215,6 +213,11 @@ class TripComplete extends Job implements SelfHandling, ShouldQueue |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// TODO: avgpace for runs
|
|
|
|
|
|
// TODO: avgspeed for bike rides
|
|
|
|
|
|
// TODO: avg heart rate if available
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// echo "Micropub Params\n";
|
|
|
// echo "Micropub Params\n";
|
|
|
// print_r($params);
|
|
|
// print_r($params);
|
|
|
|
|
|
|
|
|