schema([ TextInput::make('database') ->columnSpanFull() ->suffixAction(CopyAction::make()), TextInput::make('username') ->suffixAction(CopyAction::make()), TextInput::make('password') ->password()->revealable() ->hidden(fn () => !auth()->user()->can(Permission::ACTION_DATABASE_VIEW_PASSWORD, $server)) ->hintAction( RotateDatabasePasswordAction::make() ->authorize(fn () => auth()->user()->can(Permission::ACTION_DATABASE_UPDATE, $server)) ) ->suffixAction(CopyAction::make()) ->formatStateUsing(fn (Database $database) => $database->password), TextInput::make('remote') ->label('Connections From'), TextInput::make('max_connections') ->formatStateUsing(fn (Database $database) => $database->max_connections === 0 ? $database->max_connections : 'Unlimited'), TextInput::make('jdbc') ->label('JDBC Connection String') ->password()->revealable() ->hidden(!auth()->user()->can(Permission::ACTION_DATABASE_VIEW_PASSWORD, $server)) ->suffixAction(CopyAction::make()) ->columnSpanFull() ->formatStateUsing(fn (Database $database) => $database->jdbc), ]); } public function table(Table $table): Table { return $table ->columns([ TextColumn::make('database'), TextColumn::make('username'), TextColumn::make('remote'), DateTimeColumn::make('created_at') ->sortable(), ]) ->actions([ ViewAction::make() ->modalHeading(fn (Database $database) => 'Viewing ' . $database->database), DeleteAction::make(), ]); } protected function getHeaderActions(): array { /** @var Server $server */ $server = Filament::getTenant(); return [ CreateAction::make('new') ->label(fn () => $server->databases()->count() >= $server->database_limit ? 'Database limit reached' : 'Create Database') ->disabled(fn () => $server->databases()->count() >= $server->database_limit) ->color(fn () => $server->databases()->count() >= $server->database_limit ? 'danger' : 'primary') ->createAnother(false) ->form([ Grid::make() ->columns(2) ->schema([ Select::make('database_host_id') ->label('Database Host') ->columnSpan(2) ->required() ->placeholder('Select Database Host') ->options(fn () => $server->node->databaseHosts->mapWithKeys(fn ($databaseHost) => [$databaseHost->id => $databaseHost->name])), TextInput::make('database') ->columnSpan(1) ->label('Database Name') ->prefix('s'. $server->id . '_') ->hintIcon('tabler-question-mark') ->hintIconTooltip('Leaving this blank will auto generate a random name'), TextInput::make('remote') ->columnSpan(1) ->label('Connections From') ->default('%'), ]), ]) ->action(function ($data, DatabaseManagementService $service) use ($server) { if (empty($data['database'])) { $data['database'] = str_random(12); } $data['database'] = 's'. $server->id . '_' . $data['database']; $service->create($server, $data); }), ]; } public function getBreadcrumbs(): array { return []; } }