2015-12-06 13:58:49 -05:00
|
|
|
<?php
|
2016-12-07 22:46:38 +00:00
|
|
|
|
2024-03-12 22:39:16 -04:00
|
|
|
namespace App\Models;
|
2015-12-06 13:58:49 -05:00
|
|
|
|
2025-01-30 16:39:00 -05:00
|
|
|
use App\Contracts\Validatable;
|
2025-12-11 14:34:27 +01:00
|
|
|
use App\Enums\SubuserPermission;
|
2025-01-30 16:39:00 -05:00
|
|
|
use App\Traits\HasValidation;
|
2025-09-24 13:34:19 +02:00
|
|
|
use Carbon\Carbon;
|
2025-01-30 16:39:00 -05:00
|
|
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
|
|
|
|
use Illuminate\Database\Eloquent\Model;
|
2022-10-14 10:59:20 -06:00
|
|
|
use Illuminate\Database\Eloquent\Relations\BelongsTo;
|
2025-09-24 13:34:19 +02:00
|
|
|
use Illuminate\Notifications\Notifiable;
|
2015-12-06 13:58:49 -05:00
|
|
|
|
2019-11-03 12:20:11 -08:00
|
|
|
/**
|
2021-01-27 20:52:11 -08:00
|
|
|
* @property int $id
|
|
|
|
|
* @property int $user_id
|
|
|
|
|
* @property int $server_id
|
2025-03-03 14:41:19 -05:00
|
|
|
* @property string[] $permissions
|
2025-09-08 13:12:33 -04:00
|
|
|
* @property Carbon $created_at
|
|
|
|
|
* @property Carbon $updated_at
|
|
|
|
|
* @property User $user
|
|
|
|
|
* @property Server $server
|
2019-11-03 12:20:11 -08:00
|
|
|
*/
|
2025-01-30 16:39:00 -05:00
|
|
|
class Subuser extends Model implements Validatable
|
2015-12-06 13:58:49 -05:00
|
|
|
{
|
2025-01-30 16:39:00 -05:00
|
|
|
use HasFactory;
|
|
|
|
|
use HasValidation;
|
2019-09-04 21:00:34 -07:00
|
|
|
use Notifiable;
|
2017-02-17 19:23:27 -05:00
|
|
|
|
2018-01-25 21:26:06 -06:00
|
|
|
/**
|
|
|
|
|
* The resource name for this model when it is transformed into an
|
|
|
|
|
* API representation using fractal.
|
|
|
|
|
*/
|
2021-01-23 12:33:34 -08:00
|
|
|
public const RESOURCE_NAME = 'server_subuser';
|
2018-01-25 21:26:06 -06:00
|
|
|
|
2025-12-11 14:34:27 +01:00
|
|
|
/** @var array<string, array{name: string, hidden: ?bool, icon: ?string, permissions: string[]}> */
|
|
|
|
|
protected static array $customPermissions = [];
|
|
|
|
|
|
|
|
|
|
/** @param string[] $permissions */
|
|
|
|
|
public static function registerCustomPermissions(string $name, array $permissions, ?string $icon = null, ?bool $hidden = null): void
|
|
|
|
|
{
|
|
|
|
|
$customPermission = static::$customPermissions[$name] ?? [];
|
|
|
|
|
|
|
|
|
|
$customPermission['name'] = $name;
|
|
|
|
|
$customPermission['permissions'] = array_merge($customPermission['permissions'] ?? [], $permissions);
|
|
|
|
|
|
|
|
|
|
if (!is_null($icon)) {
|
|
|
|
|
$customPermission['icon'] = $icon;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!is_null($hidden)) {
|
|
|
|
|
$customPermission['hidden'] = $hidden;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static::$customPermissions[$name] = $customPermission;
|
|
|
|
|
}
|
|
|
|
|
|
2016-01-18 19:57:10 -05:00
|
|
|
/**
|
|
|
|
|
* Fields that are not mass assignable.
|
|
|
|
|
*/
|
|
|
|
|
protected $guarded = ['id', 'created_at', 'updated_at'];
|
|
|
|
|
|
2025-03-08 19:56:06 -05:00
|
|
|
/** @var array<array-key, string[]> */
|
2022-10-14 10:59:20 -06:00
|
|
|
public static array $validationRules = [
|
2025-03-08 19:56:06 -05:00
|
|
|
'user_id' => ['required', 'numeric', 'exists:users,id'],
|
|
|
|
|
'server_id' => ['required', 'numeric', 'exists:servers,id'],
|
|
|
|
|
'permissions' => ['nullable', 'array'],
|
|
|
|
|
'permissions.*' => ['string'],
|
2017-08-23 21:34:11 -05:00
|
|
|
];
|
|
|
|
|
|
2024-03-19 21:08:49 -04:00
|
|
|
protected function casts(): array
|
|
|
|
|
{
|
|
|
|
|
return [
|
|
|
|
|
'user_id' => 'int',
|
|
|
|
|
'server_id' => 'int',
|
|
|
|
|
'permissions' => 'array',
|
|
|
|
|
];
|
|
|
|
|
}
|
|
|
|
|
|
2017-02-09 17:43:54 -05:00
|
|
|
/**
|
|
|
|
|
* Gets the server associated with a subuser.
|
|
|
|
|
*/
|
2022-10-14 10:59:20 -06:00
|
|
|
public function server(): BelongsTo
|
2017-02-09 17:43:54 -05:00
|
|
|
{
|
|
|
|
|
return $this->belongsTo(Server::class);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Gets the user associated with a subuser.
|
|
|
|
|
*/
|
2022-10-14 10:59:20 -06:00
|
|
|
public function user(): BelongsTo
|
2017-02-09 17:43:54 -05:00
|
|
|
{
|
|
|
|
|
return $this->belongsTo(User::class);
|
|
|
|
|
}
|
2017-02-09 18:44:07 -05:00
|
|
|
|
2025-12-11 14:34:27 +01:00
|
|
|
/** @return array<array{name: string, hidden: bool, icon: string, permissions: string[]}> */
|
|
|
|
|
public static function allPermissionData(): array
|
|
|
|
|
{
|
|
|
|
|
$allPermissions = [];
|
|
|
|
|
|
|
|
|
|
foreach (SubuserPermission::cases() as $subuserPermission) {
|
|
|
|
|
[$group, $permission] = $subuserPermission->split();
|
|
|
|
|
|
|
|
|
|
$allPermissions[$group] = [
|
|
|
|
|
'name' => $group,
|
|
|
|
|
'hidden' => $subuserPermission->isHidden(),
|
|
|
|
|
'icon' => $subuserPermission->getIcon(),
|
|
|
|
|
'permissions' => array_merge($allPermissions[$group]['permissions'] ?? [], [$permission]),
|
|
|
|
|
];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
foreach (static::$customPermissions as $customPermission) {
|
|
|
|
|
$name = $customPermission['name'];
|
|
|
|
|
|
|
|
|
|
$groupData = $allPermissions[$name] ?? [];
|
|
|
|
|
|
|
|
|
|
$groupData = [
|
|
|
|
|
'name' => $name,
|
|
|
|
|
'hidden' => $customPermission['hidden'] ?? $groupData['hidden'] ?? false,
|
|
|
|
|
'icon' => $customPermission['icon'] ?? $groupData['icon'],
|
|
|
|
|
'permissions' => array_unique(array_merge($groupData['permissions'] ?? [], $customPermission['permissions'])),
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
$allPermissions[$name] = $groupData;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return array_values($allPermissions);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/** @return string[] */
|
|
|
|
|
public static function allPermissionKeys(): array
|
|
|
|
|
{
|
|
|
|
|
return collect(static::allPermissionData())
|
|
|
|
|
->map(fn ($data) => array_map(fn ($permission) => $data['name'] . '.' . $permission, $data['permissions']))
|
|
|
|
|
->flatten()
|
|
|
|
|
->unique()
|
|
|
|
|
->toArray();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static function doesPermissionExist(string|SubuserPermission $permission): bool
|
2017-02-09 18:44:07 -05:00
|
|
|
{
|
2025-12-11 14:34:27 +01:00
|
|
|
if ($permission instanceof SubuserPermission) {
|
|
|
|
|
$permission = $permission->value;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return str_contains($permission, '.') && in_array($permission, static::allPermissionKeys());
|
2017-02-09 18:44:07 -05:00
|
|
|
}
|
2015-12-06 13:58:49 -05:00
|
|
|
}
|