HEX
Server: nginx/1.18.0
System: Linux test-ipsremont 5.4.0-214-generic #234-Ubuntu SMP Fri Mar 14 23:50:27 UTC 2025 x86_64
User: ips (1000)
PHP: 8.0.30
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/ipsremont-demo/app/Observers/RepairObserver.php
<?php

namespace App\Observers;

use App\Models\Repair\Repair;
use App\Repository\Service\ServiceLastActionRepository;
use App\Services\Log\LogService;
use App\Services\Status\StatusService;
use App\Services\WorkCompleteCertificate\WorkCompleteCertificateService;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Support\Facades\Log;

class RepairObserver extends BaseObserver
{

    public function created(Model $model)
    {
        /** @var Repair $model */
        LogService::created($model);

        ServiceLastActionRepository::add('Создал наряд №' . $model->id);
    }

    public function updated(Model $model)
    {
        /** @var Repair $model */
        $statusChanged = $model->status !== $model->getOriginal('status');

        if ($statusChanged) {
            switch ($model->status) {
                case Repair::STATUS_COMPLETED:
                    if (empty($model->category_id)) {
                        Log::channel('debugLog')->debug(json_encode(debug_backtrace(), JSON_THROW_ON_ERROR));
                    }

                    WorkCompleteCertificateService::createFromRepair($model);

                    break;
            }

            StatusService::repairStatusChanged($model);
        }

        LogService::updated($model);

        ServiceLastActionRepository::add('Обновил наряд №' . $model->id);
    }

}