You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

121 lines
4.2 KiB

  1. <?php
  2. namespace App\Http\Controllers;
  3. use Laravel\Lumen\Routing\Controller as BaseController;
  4. use Illuminate\Http\Request;
  5. use DB;
  6. use Quartz;
  7. use Log;
  8. use DateTime, DateTimeZone;
  9. class Api extends BaseController
  10. {
  11. public function account(Request $request) {
  12. $token = $request->input('token');
  13. if(!$token)
  14. return response(json_encode(['error' => 'no token provided']))->header('Content-Type', 'application/json');
  15. $db = DB::table('databases')->where('write_token','=',$token)->first();
  16. if(!$db)
  17. return response(json_encode(['error' => 'invalid token']))->header('Content-Type', 'application/json');
  18. return response(json_encode(['name' => $db->name]))->header('Content-Type', 'application/json');
  19. }
  20. public function query(Request $request) {
  21. $token = $request->input('token');
  22. if(!$token)
  23. return response(json_encode(['error' => 'no token provided']))->header('Content-Type', 'application/json');
  24. $db = DB::table('databases')->where('read_token','=',$token)->first();
  25. if(!$db)
  26. return response(json_encode(['error' => 'invalid token']))->header('Content-Type', 'application/json');
  27. $qz = new Quartz\DB(env('STORAGE_DIR').$db->name, 'r');
  28. if($date=$request->input('date')) {
  29. if($request->input('tz')) {
  30. $tz = $request->input('tz');
  31. } else {
  32. $tz = 'America/Los_Angeles';
  33. }
  34. $start = DateTime::createFromFormat('Y-m-d H:i:s', $date.' 00:00:00', new DateTimeZone($tz));
  35. $end = DateTime::createFromFormat('Y-m-d H:i:s', $date.' 23:59:59', new DateTimeZone($tz));
  36. } else {
  37. return response(json_encode(['error' => 'no date provided']))->header('Content-Type', 'application/json');
  38. }
  39. $results = $qz->queryRange($start, $end);
  40. $locations = [];
  41. $properties = [];
  42. foreach($results as $id=>$record) {
  43. $record->date->format('U.u');
  44. $locations[] = $record->data;
  45. $properties[] = $record->data->properties;
  46. }
  47. if($request->input('format') == 'linestring') {
  48. $response = array(
  49. 'type' => 'LineString',
  50. 'coordinates' => array(),
  51. 'properties' => $properties
  52. );
  53. foreach($locations as $loc) {
  54. $response['coordinates'][] = $loc->geometry->coordinates;
  55. }
  56. } else {
  57. $response = [
  58. 'locations' => $locations
  59. ];
  60. }
  61. return response(json_encode($response))->header('Content-Type', 'application/json');
  62. }
  63. public function input(Request $request) {
  64. $token = $request->input('token');
  65. if(!$token)
  66. return response(json_encode(['error' => 'no token provided']))->header('Content-Type', 'application/json');
  67. $db = DB::table('databases')->where('write_token','=',$token)->first();
  68. if(!$db)
  69. return response(json_encode(['error' => 'invalid token']))->header('Content-Type', 'application/json');
  70. if(!is_array($request->input('locations')))
  71. return response(json_encode(['error' => 'invalid input', 'error_description' => 'parameter "locations" must be an array of GeoJSON data with a "timestamp" property']))->header('Content-Type', 'application/json');
  72. $qz = new Quartz\DB(env('STORAGE_DIR').$db->name, 'w');
  73. $num = 0;
  74. foreach($request->input('locations') as $loc) {
  75. if(array_key_exists('properties', $loc) && array_key_exists('timestamp', $loc['properties'])) {
  76. try {
  77. if(preg_match('/^\d+\.\d+$/', $loc['properties']['timestamp']))
  78. $date = DateTime::createFromFormat('U.u', $loc['properties']['timestamp']);
  79. elseif(preg_match('/^\d+$/', $loc['properties']['timestamp']))
  80. $date = DateTime::createFromFormat('U', $loc['properties']['timestamp']);
  81. else
  82. $date = new DateTime($loc['properties']['timestamp']);
  83. if($date) {
  84. $num++;
  85. $qz->add($date, $loc);
  86. } else {
  87. Log::warning('Received invalid date: ' . $loc['properties']['timestamp']);
  88. }
  89. } catch(Exception $e) {
  90. Log::warning('Received invalid date: ' . $loc['properties']['timestamp']);
  91. }
  92. }
  93. }
  94. return response(json_encode(['result' => 'ok', 'saved' => $num]))->header('Content-Type', 'application/json');
  95. }
  96. }