|
|
@ -7,11 +7,12 @@ use Illuminate\Database\Eloquent\Factories\HasFactory;
|
|
|
|
use Illuminate\Database\Eloquent\SoftDeletes;
|
|
|
|
use Illuminate\Database\Eloquent\SoftDeletes;
|
|
|
|
use Illuminate\Foundation\Auth\User as Authenticatable;
|
|
|
|
use Illuminate\Foundation\Auth\User as Authenticatable;
|
|
|
|
use Illuminate\Notifications\Notifiable;
|
|
|
|
use Illuminate\Notifications\Notifiable;
|
|
|
|
|
|
|
|
use Laravel\Sanctum\HasApiTokens;
|
|
|
|
use Spatie\Permission\Traits\HasRoles;
|
|
|
|
use Spatie\Permission\Traits\HasRoles;
|
|
|
|
|
|
|
|
|
|
|
|
class User extends Authenticatable
|
|
|
|
class User extends Authenticatable
|
|
|
|
{
|
|
|
|
{
|
|
|
|
use HasFactory, Notifiable, HasRoles, SoftDeletes;
|
|
|
|
use HasFactory, Notifiable, HasRoles, SoftDeletes, HasApiTokens;
|
|
|
|
|
|
|
|
|
|
|
|
static $roles = ['DEVELOPER', 'ADMIN', 'USER', 'SUSPENDED'];
|
|
|
|
static $roles = ['DEVELOPER', 'ADMIN', 'USER', 'SUSPENDED'];
|
|
|
|
|
|
|
|
|
|
|
@ -58,6 +59,7 @@ class User extends Authenticatable
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return $this->hasMany(Post::class);
|
|
|
|
return $this->hasMany(Post::class);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function postsPercent()
|
|
|
|
public function postsPercent()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (Post::count() == 0) {
|
|
|
|
if (Post::count() == 0) {
|
|
|
@ -65,10 +67,12 @@ class User extends Authenticatable
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $this->posts()->count() * 100 / Post::count();
|
|
|
|
return $this->posts()->count() * 100 / Post::count();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function products()
|
|
|
|
public function products()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return $this->hasMany(Product::class);
|
|
|
|
return $this->hasMany(Product::class);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function productsPercent()
|
|
|
|
public function productsPercent()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
@ -77,10 +81,12 @@ class User extends Authenticatable
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $this->products()->count() * 100 / Product::count();
|
|
|
|
return $this->products()->count() * 100 / Product::count();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function tickets()
|
|
|
|
public function tickets()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return $this->hasMany(Ticket::class);
|
|
|
|
return $this->hasMany(Ticket::class);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function ticketsPercent()
|
|
|
|
public function ticketsPercent()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (Ticket::count() == 0) {
|
|
|
|
if (Ticket::count() == 0) {
|
|
|
@ -88,6 +94,7 @@ class User extends Authenticatable
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $this->tickets()->count() * 100 / Ticket::count();
|
|
|
|
return $this->tickets()->count() * 100 / Ticket::count();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function comments()
|
|
|
|
public function comments()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return $this->morphMany(Comment::class, 'commentator');
|
|
|
|
return $this->morphMany(Comment::class, 'commentator');
|
|
|
@ -106,10 +113,13 @@ class User extends Authenticatable
|
|
|
|
return $this->hasMany(AdminLog::class, 'user_id', 'id');
|
|
|
|
return $this->hasMany(AdminLog::class, 'user_id', 'id');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function accesses(){
|
|
|
|
public function accesses()
|
|
|
|
|
|
|
|
{
|
|
|
|
return $this->hasMany(Access::class);
|
|
|
|
return $this->hasMany(Access::class);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
public function hasAnyAccess($name){
|
|
|
|
|
|
|
|
|
|
|
|
public function hasAnyAccess($name)
|
|
|
|
|
|
|
|
{
|
|
|
|
if ($this->hasRole('SUSPENDED')) {
|
|
|
|
if ($this->hasRole('SUSPENDED')) {
|
|
|
|
return false;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -118,7 +128,9 @@ class User extends Authenticatable
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $this->accesses()->where('route', 'LIKE', '%.' . $name . '.%')->count() > 0;
|
|
|
|
return $this->accesses()->where('route', 'LIKE', '%.' . $name . '.%')->count() > 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
public function hasAnyAccesses($array){
|
|
|
|
|
|
|
|
|
|
|
|
public function hasAnyAccesses($array)
|
|
|
|
|
|
|
|
{
|
|
|
|
if ($this->hasRole('SUSPENDED')) {
|
|
|
|
if ($this->hasRole('SUSPENDED')) {
|
|
|
|
return false;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -132,7 +144,8 @@ class User extends Authenticatable
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function hasAccess($route){
|
|
|
|
public function hasAccess($route)
|
|
|
|
|
|
|
|
{
|
|
|
|
if ($this->hasRole('SUSPENDED')) {
|
|
|
|
if ($this->hasRole('SUSPENDED')) {
|
|
|
|
return false;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|