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;
|
2023-12-18 13:00:04 +11:00
|
|
|
use Illuminate\Support\Collection;
|
2023-06-26 12:32:38 +12:00
|
|
|
use Laravel\Sanctum\HasApiTokens;
|
2018-11-15 21:45:49 +11:00
|
|
|
|
2023-08-02 22:42:59 +10:00
|
|
|
use App\Traits\{ScopeActive,UserSwitch};
|
2021-09-27 22:50:47 +10:00
|
|
|
|
2021-06-20 23:03:20 +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
|
|
|
{
|
2023-08-02 22:42:59 +10:00
|
|
|
use HasFactory,Notifiable,HasApiTokens,UserSwitch,ScopeActive;
|
2021-06-20 23:03:20 +10:00
|
|
|
|
|
|
|
/**
|
|
|
|
* 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-06-20 23:03:20 +10:00
|
|
|
];
|
|
|
|
|
2021-10-26 23:19:55 +11:00
|
|
|
/* RELATIONS */
|
|
|
|
|
2023-08-02 22:42:59 +10:00
|
|
|
public function system()
|
|
|
|
{
|
|
|
|
return $this->belongsTo(System::class);
|
|
|
|
}
|
|
|
|
|
2021-10-26 23:19:55 +11:00
|
|
|
public function systems()
|
|
|
|
{
|
|
|
|
return $this->belongsToMany(System::class);
|
|
|
|
}
|
|
|
|
|
2021-06-20 23:03:20 +10:00
|
|
|
/* GENERAL METHODS */
|
|
|
|
|
2024-04-26 16:18:40 +10:00
|
|
|
public function addresses(Domain $o=NULL): Collection
|
2023-12-19 11:45:11 +11:00
|
|
|
{
|
|
|
|
return Address::select('addresses.*')
|
|
|
|
->join('systems',['systems.id'=>'addresses.system_id'])
|
|
|
|
->join('system_user',['system_user.system_id'=>'systems.id'])
|
2024-04-26 16:18:40 +10:00
|
|
|
->when(! is_null($o),function($query) use ($o) {
|
|
|
|
return $query
|
|
|
|
->join('zones',['zones.id'=>'addresses.zone_id'])
|
|
|
|
->where('zones.domain_id',$o->id);
|
|
|
|
})
|
2023-12-19 11:45:11 +11:00
|
|
|
->where('system_user.user_id',$this->id)
|
2024-05-24 11:04:25 +10:00
|
|
|
->activeFTN()
|
2023-12-19 11:45:11 +11:00
|
|
|
->with(['zone.domain'])
|
|
|
|
->get();
|
|
|
|
}
|
|
|
|
|
2022-12-11 21:46:08 +11:00
|
|
|
/**
|
|
|
|
* Is this user a ZC of a domain?
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function isZC(): bool
|
|
|
|
{
|
2023-12-18 13:00:04 +11:00
|
|
|
return $this->zc()->count() > 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2024-06-15 15:29:00 +10:00
|
|
|
* Does this user have systems with points
|
|
|
|
*
|
2023-12-18 13:00:04 +11:00
|
|
|
* @return Collection
|
|
|
|
*/
|
|
|
|
public function points(): Collection
|
|
|
|
{
|
2024-06-15 15:29:00 +10:00
|
|
|
return $this
|
|
|
|
->systems
|
|
|
|
->pluck('addresses')
|
|
|
|
->flatten()
|
|
|
|
->where('point_id','>',0);
|
2023-12-18 13:00:04 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the zones that this user is ZC for
|
|
|
|
*
|
|
|
|
* @return Collection
|
|
|
|
*/
|
|
|
|
public function zc(): Collection
|
|
|
|
{
|
2024-05-09 21:22:30 +10:00
|
|
|
$this->load('systems.addresses.nodes_hub');
|
2024-04-26 16:18:40 +10:00
|
|
|
|
2024-05-09 21:22:30 +10:00
|
|
|
return $this->systems->pluck('addresses')->flatten()->where('role_id',Address::NODE_ZC);
|
2022-12-11 21:46:08 +11:00
|
|
|
}
|
2018-11-15 21:45:49 +11:00
|
|
|
}
|