mirror of
https://github.com/ConnectedHumber/Air-Quality-Web
synced 2024-11-25 06:53:00 +00:00
[server] Add device-info api call
This commit is contained in:
parent
a0130a72c9
commit
575a6b1dd6
3 changed files with 128 additions and 0 deletions
77
logic/Actions/DeviceInfo.php
Normal file
77
logic/Actions/DeviceInfo.php
Normal file
|
@ -0,0 +1,77 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace AirQuality\Actions;
|
||||||
|
|
||||||
|
use \SBRL\TomlConfig;
|
||||||
|
use \AirQuality\Repositories\IDeviceRepository;
|
||||||
|
use \AirQuality\ApiResponseSender;
|
||||||
|
|
||||||
|
use \AirQuality\Validator;
|
||||||
|
use \AirQuality\PerfFormatter;
|
||||||
|
|
||||||
|
class DeviceInfo implements IAction {
|
||||||
|
/** @var TomlConfig */
|
||||||
|
private $settings;
|
||||||
|
/** @var IDeviceRepository */
|
||||||
|
private $device_repo;
|
||||||
|
|
||||||
|
/** @var IMeasurementTypeRepository */
|
||||||
|
private $type_repo;
|
||||||
|
|
||||||
|
/** @var ApiResponseSender */
|
||||||
|
private $sender;
|
||||||
|
|
||||||
|
/** @var Validator */
|
||||||
|
private $validator;
|
||||||
|
|
||||||
|
public function __construct(
|
||||||
|
TomlConfig $in_settings,
|
||||||
|
IDeviceRepository $in_device_repo,
|
||||||
|
ApiResponseSender $in_sender) {
|
||||||
|
$this->settings = $in_settings;
|
||||||
|
$this->device_repo = $in_device_repo;
|
||||||
|
$this->sender = $in_sender;
|
||||||
|
|
||||||
|
$this->validator = new Validator($_GET);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function handle() : bool {
|
||||||
|
global $start_time;
|
||||||
|
|
||||||
|
$start_handle = microtime(true);
|
||||||
|
|
||||||
|
// 1: Validate params
|
||||||
|
$this->validator->is_numberish("device-id");
|
||||||
|
$this->validator->run();
|
||||||
|
|
||||||
|
// 2: Pull data from database
|
||||||
|
$data = $this->device_repo->get_device_info_ext(
|
||||||
|
$_GET["device-id"]
|
||||||
|
);
|
||||||
|
|
||||||
|
// 2.5: Validate data from database
|
||||||
|
if(empty($data)) {
|
||||||
|
$this->sender->send_error_plain(404, "Error: No data could be found for that device id.", [
|
||||||
|
[ "x-time-taken: ", PerfFormatter::format_perf_data($start_time, $start_handle, null) ]
|
||||||
|
]);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 3: Serialise data
|
||||||
|
$start_encode = microtime(true);
|
||||||
|
$response = json_encode($data);
|
||||||
|
|
||||||
|
// 4: Send response
|
||||||
|
|
||||||
|
// Send a cache-control header, but only in production mode
|
||||||
|
if($this->settings->get("env.mode") == "production") {
|
||||||
|
header("cache-control: public, max-age=" . $this->settings->get("cache.max-age"));
|
||||||
|
}
|
||||||
|
|
||||||
|
header("content-length: " . strlen($response));
|
||||||
|
header("content-type: application/json");
|
||||||
|
header("x-time-taken: " . PerfFormatter::format_perf_data($start_time, $start_handle, $start_encode));
|
||||||
|
echo($response);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
|
@ -10,4 +10,13 @@ interface IDeviceRepository {
|
||||||
* @return array A list of devices and their basic information.
|
* @return array A list of devices and their basic information.
|
||||||
*/
|
*/
|
||||||
public function get_all_devices($only_with_location);
|
public function get_all_devices($only_with_location);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets a bunch of information about a device.
|
||||||
|
* This method returns _considerably_ more information than the above one
|
||||||
|
* that lists a bunch of devices, but only works for 1 device at a time.
|
||||||
|
* @param int $device_id The id of the device to get information for.
|
||||||
|
* @return array The extended information available on the given device.
|
||||||
|
*/
|
||||||
|
public function get_device_info_ext($device_id);
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,6 +14,18 @@ class MariaDBDeviceRepository implements IDeviceRepository {
|
||||||
public static $column_lat = "device_latitude";
|
public static $column_lat = "device_latitude";
|
||||||
public static $column_long = "device_longitude";
|
public static $column_long = "device_longitude";
|
||||||
|
|
||||||
|
public static $table_name_type = "device_types";
|
||||||
|
public static $column_type_id = "device_type";
|
||||||
|
public static $column_type_processor = "processor";
|
||||||
|
public static $column_type_connection = "Connection";
|
||||||
|
public static $column_type_particle_sensor = "particle_sensor";
|
||||||
|
public static $column_type_temp_sensor = "temp_sensor";
|
||||||
|
public static $column_type_power = "power";
|
||||||
|
public static $column_type_software = "Software";
|
||||||
|
public static $column_type_notes = "Other";
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// ------------------------------------------------------------------------
|
// ------------------------------------------------------------------------
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -51,4 +63,34 @@ class MariaDBDeviceRepository implements IDeviceRepository {
|
||||||
|
|
||||||
return $this->database->query($sql)->fetchAll();
|
return $this->database->query($sql)->fetchAll();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function get_device_info_ext($device_id) {
|
||||||
|
$s = $this->get_static;
|
||||||
|
|
||||||
|
$query_result = $this->database->query(
|
||||||
|
"SELECT
|
||||||
|
{$s("table_name")}.{$s("column_device_id")} AS id,
|
||||||
|
{$s("table_name")}.{$s("column_device_name")} AS name,
|
||||||
|
{$s("table_name")}.{$s("column_lat")} AS latitude,
|
||||||
|
{$s("table_name")}.{$s("column_long")} AS longitude,
|
||||||
|
{$s("table_name_type")}.*
|
||||||
|
FROM {$s("table_name")}
|
||||||
|
JOIN {$s("table_name_type")} ON
|
||||||
|
{$s("table_name")}.{$s("column_device_type")} = {$s("table_name_type")}.{$s("column_type_id")};"
|
||||||
|
)->fetch(); // gets the next row from the query
|
||||||
|
|
||||||
|
$result = [];
|
||||||
|
foreach($query_result as $key => $value) {
|
||||||
|
// Hack! Filter out some useless columns
|
||||||
|
// We do this so that we can return everything we know about the
|
||||||
|
// device in a manner that means we don't need to alter this code
|
||||||
|
// if additional columns are added later.
|
||||||
|
|
||||||
|
if($key == self::$column_type_id)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
$result[strtolower($key)] = $value;
|
||||||
|
}
|
||||||
|
return $result;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue