coolify/app/Models/User.php

130 lines
3.5 KiB
PHP
Raw Normal View History

2023-03-17 15:33:48 +01:00
<?php
namespace App\Models;
2023-06-12 12:00:01 +02:00
use App\Notifications\Channels\SendsEmail;
use App\Notifications\TrnsactionalEmails\ResetPassword;
2023-03-17 15:33:48 +01:00
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Foundation\Auth\User as Authenticatable;
use Illuminate\Notifications\Notifiable;
2023-06-01 12:15:33 +02:00
use Laravel\Fortify\TwoFactorAuthenticatable;
use Laravel\Sanctum\HasApiTokens;
2023-03-17 15:33:48 +01:00
2023-06-12 12:00:01 +02:00
class User extends Authenticatable implements SendsEmail
2023-03-17 15:33:48 +01:00
{
2023-06-01 12:15:33 +02:00
use HasApiTokens, HasFactory, Notifiable, TwoFactorAuthenticatable;
2023-03-17 15:33:48 +01:00
protected $fillable = [
'id',
2023-03-17 15:33:48 +01:00
'name',
'email',
'password',
];
protected $hidden = [
'password',
'remember_token',
];
protected $casts = [
'email_verified_at' => 'datetime',
];
protected static function boot()
{
parent::boot();
2023-06-09 15:55:21 +02:00
static::created(function (User $user) {
$team = [
'name' => $user->name . "'s Team",
'personal_team' => true,
];
if ($user->id === 0) {
$team['id'] = 0;
$team['name'] = 'Root Team';
}
$new_team = Team::create($team);
$user->teams()->attach($new_team, ['role' => 'owner']);
});
}
public function teams()
{
return $this->belongsToMany(Team::class)->withPivot('role');
}
2023-07-28 10:55:26 +02:00
public function getRecepients($notification)
2023-06-12 12:00:01 +02:00
{
return $this->email;
}
2023-07-28 10:55:26 +02:00
public function sendPasswordResetNotification($token): void
{
$this->notify(new ResetPassword($token));
}
2023-07-14 11:27:08 +02:00
public function isAdmin()
{
2023-07-13 22:03:27 +02:00
return $this->pivot->role === 'admin' || $this->pivot->role === 'owner';
}
2023-07-13 22:03:27 +02:00
public function isAdminFromSession()
2023-06-08 11:43:14 +02:00
{
2023-06-09 15:55:21 +02:00
if (auth()->user()->id === 0) {
return true;
}
$teams = $this->teams()->get();
$is_part_of_root_team = $teams->where('id', 0)->first();
$is_admin_of_root_team = $is_part_of_root_team &&
($is_part_of_root_team->pivot->role === 'admin' || $is_part_of_root_team->pivot->role === 'owner');
if ($is_part_of_root_team && $is_admin_of_root_team) {
return true;
}
$role = $teams->where('id', session('currentTeam')->id)->first()->pivot->role;
return $role === 'admin' || $role === 'owner';
2023-06-08 11:43:14 +02:00
}
2023-06-08 11:43:14 +02:00
public function isInstanceAdmin()
{
2023-05-22 12:00:59 +02:00
$found_root_team = auth()->user()->teams->filter(function ($team) {
if ($team->id == 0) {
return true;
}
return false;
});
return $found_root_team->count() > 0;
2023-04-25 09:38:05 +02:00
}
2023-07-14 11:27:08 +02:00
public function personalTeam()
{
2023-07-13 22:03:27 +02:00
return $this->teams()->where('personal_team', true)->first();
}
2023-06-09 15:55:21 +02:00
public function currentTeam()
{
return $this->teams()->where('team_id', session('currentTeam')->id)->first();
}
public function otherTeams()
{
2023-05-22 22:30:33 +02:00
$team_id = session('currentTeam')->id;
return auth()->user()->teams->filter(function ($team) use ($team_id) {
return $team->id != $team_id;
});
}
2023-06-09 15:55:21 +02:00
public function role()
{
if ($this->teams()->where('team_id', 0)->first()) {
return 'admin';
}
return $this->teams()->where('team_id', session('currentTeam')->id)->first()->pivot->role;
}
2023-05-10 19:26:28 +02:00
public function resources()
{
2023-05-22 22:30:33 +02:00
$team_id = session('currentTeam')->id;
2023-05-10 19:26:28 +02:00
$data = Application::where('team_id', $team_id)->get();
return $data;
}
}