schema([ TextInput::make('database')->columnSpanFull(), TextInput::make('username'), TextInput::make('password') ->hintAction( Action::make('rotate') ->icon('tabler-refresh') ->requiresConfirmation() ->action(fn (DatabasePasswordService $service, Database $database, $set, $get) => $this->rotatePassword($service, $database, $set, $get)) ) ->formatStateUsing(fn (Database $database) => $database->password), TextInput::make('remote')->label('Connections From'), TextInput::make('max_connections'), TextInput::make('JDBC') ->label('JDBC Connection String') ->columnSpanFull() ->formatStateUsing(fn (Get $get, Database $database) => 'jdbc:mysql://' . $get('username') . ':' . urlencode($database->password) . '@' . $database->host->host . ':' . $database->host->port . '/' . $get('database')), ]); } public function table(Table $table): Table { return $table ->recordTitleAttribute('servers') ->columns([ TextColumn::make('database')->icon('tabler-database'), TextColumn::make('username')->icon('tabler-user'), TextColumn::make('remote'), TextColumn::make('server.name') ->icon('tabler-brand-docker') ->url(fn (Database $database) => route('filament.admin.resources.servers.edit', ['record' => $database->server_id])), TextColumn::make('max_connections'), TextColumn::make('created_at')->dateTime(), ]) ->actions([ DeleteAction::make(), ViewAction::make()->color('primary'), ]); } protected function rotatePassword(DatabasePasswordService $service, Database $database, Set $set, Get $get): void { $newPassword = $service->handle($database); $jdbcString = 'jdbc:mysql://' . $get('username') . ':' . urlencode($newPassword) . '@' . $database->host->host . ':' . $database->host->port . '/' . $get('database'); $set('password', $newPassword); $set('JDBC', $jdbcString); } }