clrghouz/app/Models/User.php

130 lines
2.6 KiB
PHP
Raw Normal View History

2018-11-15 21:45:49 +11:00
<?php
2021-05-03 22:53:40 +10:00
namespace App\Models;
2018-11-15 21:45:49 +11:00
use Illuminate\Contracts\Auth\MustVerifyEmail;
2021-05-03 22:53:40 +10:00
use Illuminate\Database\Eloquent\Factories\HasFactory;
2018-11-15 21:45:49 +11:00
use Illuminate\Foundation\Auth\User as Authenticatable;
2021-05-03 22:53:40 +10:00
use Illuminate\Notifications\Notifiable;
use Illuminate\Support\Collection;
use Laravel\Sanctum\HasApiTokens;
2018-11-15 21:45:49 +11:00
use App\Traits\{ScopeActive,UserSwitch};
2021-09-27 22:50:47 +10:00
/**
* Class User
*
* User Roles:
* + Site Admin
* + ZC - For Domain/Zone
* + RC - For sub portion of a Domain/Zone (aka Region)
* + Host Admin - For sub portion of a Region
* + Hub Admin - For a sub portion of a Hosts system
* + Sysop - Individual system
* + Guest
*
* @package App\Models
*/
2021-06-13 23:00:26 +10:00
class User extends Authenticatable implements MustVerifyEmail
2018-11-15 21:45:49 +11:00
{
use HasFactory,Notifiable,HasApiTokens,UserSwitch,ScopeActive;
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
'name',
'email',
'password',
];
/**
* The attributes that should be hidden for arrays.
*
* @var array
*/
protected $hidden = [
'password',
'remember_token',
];
/**
* The attributes that should be cast to native types.
*
* @var array
*/
protected $casts = [
'email_verified_at' => 'datetime',
2024-04-25 15:27:45 +10:00
'last_on' => 'datetime:Y-m-d H:i:s',
'passkey' => 'json',
];
2021-10-26 23:19:55 +11:00
/* RELATIONS */
public function system()
{
return $this->belongsTo(System::class);
}
2021-10-26 23:19:55 +11:00
public function systems()
{
return $this->belongsToMany(System::class);
}
/* GENERAL METHODS */
public function addresses(Domain $o=NULL): Collection
{
return Address::select('addresses.*')
->join('systems',['systems.id'=>'addresses.system_id'])
->join('system_user',['system_user.system_id'=>'systems.id'])
->when(! is_null($o),function($query) use ($o) {
return $query
->join('zones',['zones.id'=>'addresses.zone_id'])
->where('zones.domain_id',$o->id);
})
->where('system_user.user_id',$this->id)
->activeFTN()
->with(['zone.domain'])
->get();
}
/**
* Is this user a ZC of a domain?
*
* @return bool
*/
public function isZC(): bool
{
return $this->zc()->count() > 0;
}
/**
* @return Collection
* @deprecated not used - but if it is, probably could use Address::points()?
*/
public function points(): Collection
{
$result = collect();
foreach($this->systems->pluck('addresses')->flatten()->where('role','>',Address::NODE_HC) as $ao)
$result = $result->merge($ao->children());
return $result;
}
/**
* 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);
}
2018-11-15 21:45:49 +11:00
}