dev
Jing Li 2022-10-21 15:12:46 +08:00
parent 32a6925725
commit 31874831f7
8 changed files with 99 additions and 84 deletions

View File

@ -46,9 +46,9 @@ class LinkosDeviceLogArchiveCommand extends Command
} }
match ($device->type) { match ($device->type) {
DeviceType::Soil => $linkosDeviceLogService->handleSoilMonitoringLog($device, $log->data, $log->reported_at), DeviceType::Soil => $linkosDeviceLogService->handleSoilDeviceData($device, $log->data, $log->reported_at),
DeviceType::WaterQuality => $linkosDeviceLogService->handleWaterQualityMonitoringLog($device, $log->data, $log->reported_at), DeviceType::Meteorological => $linkosDeviceLogService->handleMeteorologicalDeviceData($device, $log->data, $log->reported_at),
DeviceType::Meteorological => $linkosDeviceLogService->handleMeteorologicalMonitoringLog($device, $log->data, $log->reported_at), DeviceType::WaterQuality => $linkosDeviceLogService->handleWaterQualityDeviceData($device, $log->data, $log->reported_at),
}; };
} }
}); });

View File

@ -6,7 +6,7 @@ use App\Enums\WindDirection;
use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\Model;
class MeteorologicalMonitoringHourlyLog extends Model class MeteorologicalMonitoringLog extends Model
{ {
use HasFactory; use HasFactory;

View File

@ -5,7 +5,7 @@ namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\Model;
class SoilMonitoringHourlyLog extends Model class SoilMonitoringLog extends Model
{ {
use HasFactory; use HasFactory;

View File

@ -5,7 +5,7 @@ namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\Model;
class WaterQualityMonitoringHourlyLog extends Model class WaterQualityMonitoringLog extends Model
{ {
use HasFactory; use HasFactory;

View File

@ -6,14 +6,65 @@ use App\Enums\DeviceType;
use App\Exceptions\BizException; use App\Exceptions\BizException;
use App\Models\Device; use App\Models\Device;
use App\Models\LinkosDeviceLog; use App\Models\LinkosDeviceLog;
use App\Models\MeteorologicalMonitoringHourlyLog; use App\Models\MeteorologicalMonitoringLog;
use App\Models\SoilMonitoringHourlyLog; use App\Models\SoilMonitoringLog;
use App\Models\WaterQualityMonitoringHourlyLog; use App\Models\WaterQualityMonitoringLog;
use Carbon\Carbon; use Carbon\Carbon;
use Illuminate\Support\Arr; use Illuminate\Support\Arr;
class LinkosDeviceLogService class LinkosDeviceLogService
{ {
/**
* 土壤监测数据字段
*
* @var array<string,string>
*/
protected $soilMonitoringFields = [
'conductivity' => 'conductivity',
'humidity' => 'soil_humidity',
'temperature' => 'soil_temperature',
'n' => 'nitrogen_content',
'p' => 'phosphorus_content',
'k' => 'potassium_content',
];
/**
* 气象监测数据字段
*
* @var array<string,string>
*/
protected $meteorologicalMonitoringFields = [
'wind_speed' => 'wind_speed',
'wind_power' => 'wind_power',
'wind_direction' => 'wind_direction',
'wind_degree' => 'wind_degree',
'air_humidity' => 'box_humidity',
'air_temperature' => 'box_temperature',
'air_pressure' => 'box_pressure',
'co2' => 'box_carbon',
'noise' => 'box_noise',
'illumination' => 'box_illumination',
'accumulated_rainfall' => 'accumulate_rainfall',
'current_rainfall' => 'current_rainfall',
'moment_rainfall' => 'moment_rainfall',
'pm25' => 'pm25_concentration',
'pm10' => 'pm10_concentration',
];
/**
* 水质监测数据字段
*
* @var array<string,string>
*/
protected $waterQualityMonitoringFields = [
'conductivity' => 'conductivity',
'oxygen' => 'oxygen',
'chlorine' => 'chlorine',
'turbidity' => 'turbidity',
'temperature' => 'temp',
'ph' => 'ph',
];
/** /**
* 创建 Linkos 设备数据 * 创建 Linkos 设备数据
* *
@ -45,9 +96,9 @@ class LinkosDeviceLogService
if ($log->data) { if ($log->data) {
foreach ($devices as $device) { foreach ($devices as $device) {
match ($device->type) { match ($device->type) {
DeviceType::Soil => $this->handleSoilMonitoringLog($device, $log->data, $log->reported_at), DeviceType::Soil => $this->handleSoilDeviceData($device, $log->data, $log->reported_at),
DeviceType::WaterQuality => $this->handleWaterQualityMonitoringLog($device, $log->data, $log->reported_at), DeviceType::Meteorological => $this->handleMeteorologicalDeviceData($device, $log->data, $log->reported_at),
DeviceType::Meteorological => $this->handleMeteorologicalMonitoringLog($device, $log->data, $log->reported_at), DeviceType::WaterQuality => $this->handleWaterQualityDeviceData($device, $log->data, $log->reported_at),
}; };
} }
} }
@ -56,134 +107,98 @@ class LinkosDeviceLogService
} }
/** /**
* 处理气象监控数据 * 处理土壤设备数据
* *
* @param \App\Models\Device $device * @param \App\Models\Device $device
* @param array $data * @param array $data
* @param \Carbon\Carbon $monitoredAt * @param \Carbon\Carbon $reportedAt
* @return void * @return void
*/ */
public function handleMeteorologicalMonitoringLog(Device $device, array $data, Carbon $monitoredAt): void public function handleSoilDeviceData(Device $device, array $data, Carbon $reportedAt): void
{ {
$attributes = [ if (! Arr::hasAny($data, $this->soilMonitoringFields)) {
'wind_speed' => 'wind_speed',
'wind_power' => 'wind_power',
'wind_direction' => 'wind_direction',
'wind_degree' => 'wind_degree',
'air_humidity' => 'box_humidity',
'air_temperature' => 'box_temperature',
'air_pressure' => 'box_pressure',
'co2' => 'box_carbon',
'noise' => 'box_noise',
'illumination' => 'box_illumination',
'accumulated_rainfall' => 'accumulate_rainfall',
'current_rainfall' => 'current_rainfall',
'moment_rainfall' => 'moment_rainfall',
'pm25' => 'pm25_concentration',
'pm10' => 'pm10_concentration',
];
if (! Arr::hasAny($data, $attributes)) {
return; return;
} }
$hourlyLog = MeteorologicalMonitoringHourlyLog::firstOrCreate([ $log = SoilMonitoringLog::firstOrCreate([
'device_id' => $device->id, 'device_id' => $device->id,
'monitored_at' => $monitoredAt->startOfHour(), 'monitored_at' => $reportedAt->startOfHour(),
], [ ], [
'agricultural_base_id' => $device->agricultural_base_id, 'agricultural_base_id' => $device->agricultural_base_id,
]); ]);
foreach ($attributes as $key => $value) { foreach ($this->soilMonitoringFields as $attribute => $key) {
if (! array_key_exists($value, $data)) { if (! array_key_exists($key, $data)) {
continue; continue;
} }
$hourlyLog->{$key} = $data[$value]; $log->{$attribute} = $data[$key];
} }
$hourlyLog->save(); $log->save();
} }
/** /**
* 处理水质监控数据 * 处理气象设备数据
* *
* @param \App\Models\Device $device * @param \App\Models\Device $device
* @param array $data * @param array $data
* @param \Carbon\Carbon $monitoredAt * @param \Carbon\Carbon $reportedAt
* @return void * @return void
*/ */
public function handleWaterQualityMonitoringLog(Device $device, array $data, Carbon $monitoredAt): void public function handleMeteorologicalDeviceData(Device $device, array $data, Carbon $reportedAt): void
{ {
$attributes = [ if (! Arr::hasAny($data, $this->meteorologicalMonitoringFields)) {
'conductivity' => 'conductivity',
'oxygen' => 'oxygen',
'chlorine' => 'chlorine',
'turbidity' => 'turbidity',
'temperature' => 'temp',
'ph' => 'ph',
];
if (! Arr::hasAny($data, $attributes)) {
return; return;
} }
$hourlyLog = WaterQualityMonitoringHourlyLog::firstOrCreate([ $log = MeteorologicalMonitoringLog::firstOrCreate([
'device_id' => $device->id, 'device_id' => $device->id,
'monitored_at' => $monitoredAt->startOfHour(), 'monitored_at' => $reportedAt->startOfHour(),
], [ ], [
'agricultural_base_id' => $device->agricultural_base_id, 'agricultural_base_id' => $device->agricultural_base_id,
]); ]);
foreach ($attributes as $key => $value) { foreach ($this->meteorologicalMonitoringFields as $attribute => $key) {
if (! array_key_exists($value, $data)) { if (! array_key_exists($key, $data)) {
continue; continue;
} }
$hourlyLog->{$key} = $data[$value]; $log->{$attribute} = $data[$key];
} }
$hourlyLog->save(); $log->save();
} }
/** /**
* 处理土壤监控数据 * 处理水质设备数据
* *
* @param \App\Models\Device $device * @param \App\Models\Device $device
* @param array $data * @param array $data
* @param \Carbon\Carbon $monitoredAt * @param \Carbon\Carbon $reportedAt
* @return void * @return void
*/ */
public function handleSoilMonitoringLog(Device $device, array $data, Carbon $monitoredAt): void public function handleWaterQualityDeviceData(Device $device, array $data, Carbon $reportedAt): void
{ {
$attributes = [ if (! Arr::hasAny($data, $this->waterQualityMonitoringFields)) {
'conductivity' => 'conductivity',
'humidity' => 'soil_humidity',
'temperature' => 'soil_temperature',
'n' => 'nitrogen_content',
'p' => 'phosphorus_content',
'k' => 'potassium_content',
];
if (! Arr::hasAny($data, $attributes)) {
return; return;
} }
$hourlyLog = SoilMonitoringHourlyLog::firstOrCreate([ $log = WaterQualityMonitoringLog::firstOrCreate([
'device_id' => $device->id, 'device_id' => $device->id,
'monitored_at' => $monitoredAt->startOfHour(), 'monitored_at' => $reportedAt->startOfHour(),
], [ ], [
'agricultural_base_id' => $device->agricultural_base_id, 'agricultural_base_id' => $device->agricultural_base_id,
]); ]);
foreach ($attributes as $key => $value) { foreach ($this->waterQualityMonitoringFields as $attribute => $key) {
if (! array_key_exists($value, $data)) { if (! array_key_exists($key, $data)) {
continue; continue;
} }
$hourlyLog->{$key} = $data[$value]; $log->{$attribute} = $data[$key];
} }
$hourlyLog->save(); $log->save();
} }
} }

View File

@ -13,7 +13,7 @@ return new class extends Migration
*/ */
public function up() public function up()
{ {
Schema::create('soil_monitoring_hourly_logs', function (Blueprint $table) { Schema::create('soil_monitoring_logs', function (Blueprint $table) {
$table->id(); $table->id();
$table->unsignedBigInteger('device_id')->comment('设备ID'); $table->unsignedBigInteger('device_id')->comment('设备ID');
$table->unsignedBigInteger('agricultural_base_id')->comment('农业基地ID'); $table->unsignedBigInteger('agricultural_base_id')->comment('农业基地ID');
@ -38,6 +38,6 @@ return new class extends Migration
*/ */
public function down() public function down()
{ {
Schema::dropIfExists('soil_monitoring_hourly_logs'); Schema::dropIfExists('soil_monitoring_logs');
} }
}; };

View File

@ -13,7 +13,7 @@ return new class extends Migration
*/ */
public function up() public function up()
{ {
Schema::create('meteorological_monitoring_hourly_logs', function (Blueprint $table) { Schema::create('meteorological_monitoring_logs', function (Blueprint $table) {
$table->id(); $table->id();
$table->unsignedBigInteger('device_id')->comment('设备ID'); $table->unsignedBigInteger('device_id')->comment('设备ID');
$table->unsignedBigInteger('agricultural_base_id')->comment('农业基地ID'); $table->unsignedBigInteger('agricultural_base_id')->comment('农业基地ID');
@ -47,6 +47,6 @@ return new class extends Migration
*/ */
public function down() public function down()
{ {
Schema::dropIfExists('meteorological_monitoring_hourly_logs'); Schema::dropIfExists('meteorological_monitoring_logs');
} }
}; };

View File

@ -13,7 +13,7 @@ return new class extends Migration
*/ */
public function up() public function up()
{ {
Schema::create('water_quality_monitoring_hourly_logs', function (Blueprint $table) { Schema::create('water_quality_monitoring_logs', function (Blueprint $table) {
$table->id(); $table->id();
$table->unsignedBigInteger('device_id')->comment('设备ID'); $table->unsignedBigInteger('device_id')->comment('设备ID');
$table->unsignedBigInteger('agricultural_base_id')->comment('农业基地ID'); $table->unsignedBigInteger('agricultural_base_id')->comment('农业基地ID');
@ -38,6 +38,6 @@ return new class extends Migration
*/ */
public function down() public function down()
{ {
Schema::dropIfExists('water_quality_monitoring_hourly_logs'); Schema::dropIfExists('water_quality_monitoring_logs');
} }
}; };