Skip to content
Snippets Groups Projects
Server.php 4.99 KiB
Newer Older
Tibo's avatar
Tibo committed
<?php

namespace App;

use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Collection as DatabaseCollection;
use Illuminate\Support\Collection;
Tibo's avatar
Tibo committed

Thibault Debatty's avatar
Thibault Debatty committed
/**
 * App\Server
 *
 * @property int $id
 * @property int $organization_id
 * @property \Illuminate\Support\Carbon|null $created_at
 * @property \Illuminate\Support\Carbon|null $updated_at
 * @property string $name
 * @property string $token
 * @property string $read_token
 * @property-read \App\Organization $organization
 * @method static \Illuminate\Database\Eloquent\Builder|Server newModelQuery()
 * @method static \Illuminate\Database\Eloquent\Builder|Server newQuery()
 * @method static \Illuminate\Database\Eloquent\Builder|Server query()
 * @method static \Illuminate\Database\Eloquent\Builder|Server whereCreatedAt($value)
 * @method static \Illuminate\Database\Eloquent\Builder|Server whereId($value)
 * @method static \Illuminate\Database\Eloquent\Builder|Server whereName($value)
 * @method static \Illuminate\Database\Eloquent\Builder|Server whereOrganizationId($value)
 * @method static \Illuminate\Database\Eloquent\Builder|Server whereReadToken($value)
 * @method static \Illuminate\Database\Eloquent\Builder|Server whereToken($value)
 * @method static \Illuminate\Database\Eloquent\Builder|Server whereUpdatedAt($value)
 * @mixin \Eloquent
 */
Tibo's avatar
Tibo committed
class Server extends Model
{
Tibo's avatar
Tibo committed
    protected $fillable = ["token"];
    
    // don't show tokens when serializing to json
    protected $hidden = ['token', 'read_token'];
    
    // add attributes when serializing to json
    // https://laravel.com/docs/8.x/eloquent-serialization#appending-values-to-json
    protected $appends = ['url', 'status', 'failing_sensors', 'last_record_time'];
    
    public function getUrlAttribute() : string
    {
        return action("ServerController@show", ["server" => $this]);
    }
    
    public function getStatusAttribute() : array
    {
        return $this->status()->jsonSerialize();
    }
    
    public function getFailingSensorsAttribute() : array
    {
        $failing_sensors = [];
        
        foreach ($this->getSensorsNOK() as $sensor) {
            $failing_sensors[] = $sensor->name();
        }
        
        return $failing_sensors;
    }
    
Thibault Debatty's avatar
Thibault Debatty committed
    public function getLastRecordTimeAttribute() : int
    {
        return $this->info()->lastRecordTime()->timestamp;
    }
Tibo's avatar
Tibo committed
    private $info = null;
Tibo's avatar
Tibo committed
    public function __construct(array $attributes = array())
    {
Tibo's avatar
Tibo committed
        $attributes["token"] = str_random(32);
        parent::__construct($attributes);
    }

Tibo's avatar
Tibo committed
    public function organization()
    {
Tibo's avatar
Tibo committed
        return $this->belongsTo("App\Organization");
    }
    
    public function records()
    {
        return $this->hasMany(Record::class);
    }
Tibo's avatar
Tibo committed

    public function lastRecord(string $label) : ?Record
Tibo's avatar
Tibo committed
    {
                ->where("label", $label)
                ->orderBy("time", "desc")->first();
Tibo's avatar
Tibo committed
    }

Tibo's avatar
Tibo committed
    /**
     * Get the last day of data.
Tibo's avatar
Tibo committed
     */
    public function lastRecords(string $label) : DatabaseCollection
    {
        $start = time() - 24 * 3600;
        return $this->records()
                ->where("label", $label)
                ->where("time", ">", $start)
                ->orderBy("time")
                ->get();
    public function hasData() : bool
    {
        return true;
        //return false;
        //return $this->lastRecord() != null;
Tibo's avatar
Tibo committed
    public function info() : ServerInfo
Tibo's avatar
Tibo committed
    {
Tibo's avatar
Tibo committed
        if (is_null($this->info)) {
            $this->info = new ServerInfo($this);
Tibo's avatar
Tibo committed
        }
Tibo's avatar
Tibo committed
        return $this->info;
Tibo's avatar
Tibo committed
    }
Tibo's avatar
Tibo committed

Tibo's avatar
Tibo committed
    /**
Tibo's avatar
Tibo committed
     */
Tibo's avatar
Tibo committed
    public function status() : Status
Tibo's avatar
Tibo committed
    {
        return Status::max($this->lastReports());
Tibo's avatar
Tibo committed
    }

    public function getSensorsNOK() : array
Tibo's avatar
Tibo committed
    {
Tibo's avatar
Tibo committed
        $sensorsNOK = [];
Tibo's avatar
Tibo committed
        foreach ($this->reports() as $sensor) {
Tibo's avatar
Tibo committed
            if ($sensor->status()->code() > 0) {
Tibo's avatar
Tibo committed
                $sensorsNOK[] = $sensor;
            }
        }
        return $sensorsNOK;
    }
Tibo's avatar
Tibo committed
    
    public function reports()
Tibo's avatar
Tibo committed
    {
        return $this->hasMany(Report::class);
    }
    
    
    /**
     * Get the last report for each label.
     */
    public function lastReports()
    {
        $reports = new Collection();
        foreach (AgentScheduler::get()->agentLabel() as $label) {
            $reports->push($this->lastReport($label));
    public function lastReport(string $label) : ?Report
    {
        $start = time() - 24 * 3600;
        return $this->reports()
                ->where("label", $label)
                ->where("time", ">", $start)
                ->orderByDesc("time")
                ->first();
Tibo's avatar
Tibo committed
    {
        return $this->hasMany(StatusChange::class);
Tibo's avatar
Tibo committed
    }
    public function lastChanges($count = 10)
    {
        return $this->changes()->orderBy("time", "desc")->limit($count)->get();
    }
    
    public function lastChange() : ?StatusChange
Tibo's avatar
Tibo committed
    {
        return $this->changes()->latest("time")->first();
Tibo's avatar
Tibo committed
    }
Tibo's avatar
Tibo committed
}