Files
meranie/app/Http/Controllers/MeasurementController.php
2021-01-11 15:22:46 +01:00

103 lines
2.4 KiB
PHP

<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use Carbon\Carbon;
class MeasurementController extends Controller
{
/**
* Display a listing of the resource.
*
* @return \Illuminate\Http\Response
*/
public function index()
{
// for t in ('temperature','humidity','pressure')
$a = [];
foreach (['temperature','humidity','pressure'] as $type) {
$q = sprintf("select * from bme280_value where host='balkon' and type='%s' order by time desc limit 1",$type);
$result = \InfluxDB::query($q);
$points = $result->getPoints();
foreach ($points as $p) {
$a[$type] = $p["value"];
$a["time"] = Carbon::createFromFormat("Y-m-d\TH:i:s.u+",$p["time"],'UTC')->toATOMString();
}
}
$q = sprintf("select * from esp32_value where host='balkon' and type='voltage' order by time desc limit 1",$type);
$result = \InfluxDB::query($q);
$points = $result->getPoints();
foreach ($points as $p) {
$a["voltage"] = $p["value"];
}
return response()->json($a);
}
/**
* Show the form for creating a new resource.
*
* @return \Illuminate\Http\Response
*/
public function create()
{
//
}
/**
* Store a newly created resource in storage.
*
* @param \Illuminate\Http\Request $request
* @return \Illuminate\Http\Response
*/
public function store(Request $request)
{
//
}
/**
* Display the specified resource.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function show($id)
{
//
}
/**
* Show the form for editing the specified resource.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function edit($id)
{
//
}
/**
* Update the specified resource in storage.
*
* @param \Illuminate\Http\Request $request
* @param int $id
* @return \Illuminate\Http\Response
*/
public function update(Request $request, $id)
{
//
}
/**
* Remove the specified resource from storage.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function destroy($id)
{
//
}
}