mirror of
https://github.com/pelican-dev/panel.git
synced 2025-06-10 03:58:59 +02:00
240 lines
9.3 KiB
PHP
240 lines
9.3 KiB
PHP
<?php
|
|
|
|
namespace App\Filament\Server\Resources;
|
|
|
|
use App\Filament\Server\Resources\UserResource\Pages;
|
|
use App\Models\Permission;
|
|
use App\Models\Server;
|
|
use App\Models\User;
|
|
use App\Services\Subusers\SubuserDeletionService;
|
|
use App\Services\Subusers\SubuserUpdateService;
|
|
use App\Traits\Filament\CanCustomizePages;
|
|
use App\Traits\Filament\CanCustomizeRelations;
|
|
use Filament\Facades\Filament;
|
|
use Filament\Forms\Components\Actions;
|
|
use Filament\Forms\Components\Actions\Action;
|
|
use Filament\Forms\Components\CheckboxList;
|
|
use Filament\Forms\Components\Grid;
|
|
use Filament\Forms\Components\Section;
|
|
use Filament\Forms\Components\Tabs;
|
|
use Filament\Forms\Components\Tabs\Tab;
|
|
use Filament\Forms\Components\TextInput;
|
|
use Filament\Forms\Set;
|
|
use Filament\Notifications\Notification;
|
|
use Filament\Resources\Resource;
|
|
use Filament\Tables\Actions\DeleteAction;
|
|
use Filament\Tables\Actions\EditAction;
|
|
use Filament\Tables\Columns\ImageColumn;
|
|
use Filament\Tables\Columns\TextColumn;
|
|
use Filament\Tables\Table;
|
|
use Illuminate\Database\Eloquent\Model;
|
|
|
|
class UserResource extends Resource
|
|
{
|
|
use CanCustomizePages;
|
|
use CanCustomizeRelations;
|
|
|
|
protected static ?string $model = User::class;
|
|
|
|
protected static ?int $navigationSort = 5;
|
|
|
|
protected static ?string $navigationIcon = 'tabler-users';
|
|
|
|
protected static ?string $tenantOwnershipRelationshipName = 'subServers';
|
|
|
|
public static function getNavigationBadge(): string
|
|
{
|
|
/** @var Server $server */
|
|
$server = Filament::getTenant();
|
|
|
|
return (string) $server->subusers->count();
|
|
}
|
|
|
|
// TODO: find better way handle server conflict state
|
|
public static function canAccess(): bool
|
|
{
|
|
/** @var Server $server */
|
|
$server = Filament::getTenant();
|
|
|
|
if ($server->isInConflictState()) {
|
|
return false;
|
|
}
|
|
|
|
return parent::canAccess();
|
|
}
|
|
|
|
public static function canViewAny(): bool
|
|
{
|
|
return auth()->user()->can(Permission::ACTION_USER_READ, Filament::getTenant());
|
|
}
|
|
|
|
public static function canCreate(): bool
|
|
{
|
|
return auth()->user()->can(Permission::ACTION_USER_CREATE, Filament::getTenant());
|
|
}
|
|
|
|
public static function canEdit(Model $record): bool
|
|
{
|
|
return auth()->user()->can(Permission::ACTION_USER_UPDATE, Filament::getTenant());
|
|
}
|
|
|
|
public static function canDelete(Model $record): bool
|
|
{
|
|
return auth()->user()->can(Permission::ACTION_USER_DELETE, Filament::getTenant());
|
|
}
|
|
|
|
public static function table(Table $table): Table
|
|
{
|
|
/** @var Server $server */
|
|
$server = Filament::getTenant();
|
|
|
|
$tabs = [];
|
|
$permissionsArray = [];
|
|
|
|
foreach (Permission::permissionData() as $data) {
|
|
$options = [];
|
|
$descriptions = [];
|
|
|
|
foreach ($data['permissions'] as $permission) {
|
|
$options[$permission] = str($permission)->headline();
|
|
$descriptions[$permission] = trans('server/users.permissions.' . $data['name'] . '_' . str($permission)->replace('-', '_'));
|
|
$permissionsArray[$data['name']][] = $permission;
|
|
}
|
|
|
|
$tabs[] = Tab::make(str($data['name'])->headline())
|
|
->schema([
|
|
Section::make()
|
|
->description(trans('server/users.permissions.' . $data['name'] . '_desc'))
|
|
->icon($data['icon'])
|
|
->schema([
|
|
CheckboxList::make($data['name'])
|
|
->label('')
|
|
->bulkToggleable()
|
|
->columns(2)
|
|
->options($options)
|
|
->descriptions($descriptions),
|
|
]),
|
|
]);
|
|
}
|
|
|
|
return $table
|
|
->paginated(false)
|
|
->searchable(false)
|
|
->columns([
|
|
ImageColumn::make('picture')
|
|
->visibleFrom('lg')
|
|
->label('')
|
|
->alignCenter()->circular()
|
|
->defaultImageUrl(fn (User $user) => Filament::getUserAvatarUrl($user)),
|
|
TextColumn::make('username')
|
|
->searchable(),
|
|
TextColumn::make('email')
|
|
->searchable(),
|
|
TextColumn::make('permissions')
|
|
->state(fn (User $user) => count($server->subusers->where('user_id', $user->id)->first()->permissions)),
|
|
])
|
|
->actions([
|
|
DeleteAction::make()
|
|
->label('Remove User')
|
|
->hidden(fn (User $user) => auth()->user()->id === $user->id)
|
|
->action(function (User $user, SubuserDeletionService $subuserDeletionService) use ($server) {
|
|
$subuser = $server->subusers->where('user_id', $user->id)->first();
|
|
$subuserDeletionService->handle($subuser, $server);
|
|
|
|
Notification::make()
|
|
->title('User Deleted!')
|
|
->success()
|
|
->send();
|
|
}),
|
|
EditAction::make()
|
|
->label('Edit User')
|
|
->hidden(fn (User $user) => auth()->user()->id === $user->id)
|
|
->authorize(fn () => auth()->user()->can(Permission::ACTION_USER_UPDATE, $server))
|
|
->modalHeading(fn (User $user) => 'Editing ' . $user->email)
|
|
->action(function (array $data, SubuserUpdateService $subuserUpdateService, User $user) use ($server) {
|
|
$subuser = $server->subusers->where('user_id', $user->id)->first();
|
|
|
|
$permissions = collect($data)
|
|
->forget('email')
|
|
->flatMap(fn ($permissions, $key) => collect($permissions)->map(fn ($permission) => "$key.$permission"))
|
|
->push(Permission::ACTION_WEBSOCKET_CONNECT)
|
|
->unique()
|
|
->all();
|
|
|
|
$subuserUpdateService->handle($subuser, $server, $permissions);
|
|
|
|
Notification::make()
|
|
->title('User Updated!')
|
|
->success()
|
|
->send();
|
|
|
|
return redirect(self::getUrl(tenant: $server));
|
|
})
|
|
->form([
|
|
Grid::make()
|
|
->columnSpanFull()
|
|
->columns([
|
|
'default' => 1,
|
|
'sm' => 1,
|
|
'md' => 5,
|
|
'lg' => 6,
|
|
])
|
|
->schema([
|
|
TextInput::make('email')
|
|
->inlineLabel()
|
|
->disabled()
|
|
->columnSpan([
|
|
'default' => 1,
|
|
'sm' => 1,
|
|
'md' => 4,
|
|
'lg' => 5,
|
|
]),
|
|
Actions::make([
|
|
Action::make('assignAll')
|
|
->label('Assign All')
|
|
->action(function (Set $set) use ($permissionsArray) {
|
|
$permissions = $permissionsArray;
|
|
foreach ($permissions as $key => $value) {
|
|
$allValues = array_unique($value);
|
|
$set($key, $allValues);
|
|
}
|
|
}),
|
|
])
|
|
->columnSpan([
|
|
'default' => 1,
|
|
'sm' => 1,
|
|
'md' => 1,
|
|
'lg' => 1,
|
|
]),
|
|
Tabs::make()
|
|
->columnSpanFull()
|
|
->schema($tabs),
|
|
]),
|
|
])
|
|
->mutateRecordDataUsing(function ($data, User $user) use ($server) {
|
|
$permissionsArray = $server->subusers->where('user_id', $user->id)->first()->permissions;
|
|
|
|
$transformedPermissions = [];
|
|
|
|
foreach ($permissionsArray as $permission) {
|
|
[$group, $action] = explode('.', $permission, 2);
|
|
$transformedPermissions[$group][] = $action;
|
|
}
|
|
|
|
foreach ($transformedPermissions as $key => $value) {
|
|
$data[$key] = $value;
|
|
}
|
|
|
|
return $data;
|
|
}),
|
|
]);
|
|
}
|
|
|
|
public static function getDefaultPages(): array
|
|
{
|
|
return [
|
|
'index' => Pages\ListUsers::route('/'),
|
|
];
|
|
}
|
|
}
|