f2be14402f
* PirepCancelled Event (Cron Expired Pirep Deletion) While deleting frozen in progress pireps we should at least send a PirepCancelled event for those who are listening. (or we may have a new PirepDeleted event to be issued in such cases, I think PirepCancelled is enough though) * StyleFix * Another StyleFix * Missing Log Of course it will not be possible to write log entries without the Log itself.
42 lines
1.1 KiB
PHP
42 lines
1.1 KiB
PHP
<?php
|
|
|
|
namespace App\Cron\Hourly;
|
|
|
|
use App\Contracts\Listener;
|
|
use App\Events\CronHourly;
|
|
use App\Events\PirepCancelled;
|
|
use App\Models\Enums\PirepState;
|
|
use App\Models\Pirep;
|
|
use Carbon\Carbon;
|
|
use Illuminate\Support\Facades\Log;
|
|
|
|
/**
|
|
* Remove expired live flights
|
|
*/
|
|
class RemoveExpiredLiveFlights extends Listener
|
|
{
|
|
/**
|
|
* Remove expired live flights that haven't had an update in the live time
|
|
*
|
|
* @param CronHourly $event
|
|
*
|
|
* @throws \Exception
|
|
*/
|
|
public function handle(CronHourly $event): void
|
|
{
|
|
if (setting('acars.live_time') === 0) {
|
|
return;
|
|
}
|
|
|
|
$date = Carbon::now('UTC')->subHours(setting('acars.live_time'));
|
|
$pireps = Pirep::where('updated_at', '<', $date)
|
|
->where('state', PirepState::IN_PROGRESS)
|
|
->get();
|
|
foreach ($pireps as $pirep) {
|
|
event(new PirepCancelled($pirep));
|
|
Log::info('Cron: Deleting Expired Live PIREP id='.$pirep->id.', state='.PirepState::label($pirep->state));
|
|
$pirep->delete();
|
|
}
|
|
}
|
|
}
|