'datetime', 'last_on' => 'datetime:Y-m-d H:i:s', 'passkey' => 'json', ]; /* RELATIONS */ public function system() { return $this->belongsTo(System::class); } public function systems() { return $this->belongsToMany(System::class) ->orderBy('name'); } /* GENERAL METHODS */ public function addresses(): Collection { return Address::FTN() ->join('systems',['systems.id'=>'addresses.system_id']) ->join('system_user',['system_user.system_id'=>'systems.id']) ->where('system_user.user_id',$this->id) ->where('systems.active',TRUE) ->ActiveFTN() ->get(); } /** * Is this user a ZC of a domain? * * @return bool */ public function isZC(): bool { return $this->zc()->count() > 0; } /** * Does this user have systems with points * * @return Collection */ public function points(): Collection { return $this ->systems ->pluck('addresses') ->flatten() ->where('point_id','>',0); } /** * Return the zones that this user is ZC for * * @return Collection */ public function zc(): Collection { $this->load('systems.addresses.nodes_hub'); return $this->systems->pluck('addresses')->flatten()->where('role_id',Address::NODE_ZC); } }