 1900c04b71
			
		
	
	
		1900c04b71
		
			
		
	
	
	
	
		
			
			Co-authored-by: RMartinOscar <40749467+RMartinOscar@users.noreply.github.com> Co-authored-by: Boy132 <Boy132@users.noreply.github.com> Co-authored-by: Lance Pioch <git@lance.sh>
		
			
				
	
	
		
			186 lines
		
	
	
		
			8.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			186 lines
		
	
	
		
			8.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace App\Filament\Admin\Resources\DatabaseHosts\Pages;
 | |
| 
 | |
| use App\Filament\Admin\Resources\DatabaseHosts\DatabaseHostResource;
 | |
| use App\Services\Databases\Hosts\HostCreationService;
 | |
| use App\Traits\Filament\CanCustomizeHeaderActions;
 | |
| use App\Traits\Filament\CanCustomizeHeaderWidgets;
 | |
| use Exception;
 | |
| use Filament\Forms\Components\Hidden;
 | |
| use Filament\Infolists\Components\TextEntry;
 | |
| use Filament\Forms\Components\Select;
 | |
| use Filament\Forms\Components\TextInput;
 | |
| use Filament\Forms\Components\Toggle;
 | |
| use Filament\Schemas\Components\Fieldset;
 | |
| use Filament\Schemas\Components\Utilities\Get;
 | |
| use Filament\Schemas\Components\Utilities\Set;
 | |
| use Filament\Notifications\Notification;
 | |
| use Filament\Resources\Pages\CreateRecord;
 | |
| use Filament\Resources\Pages\CreateRecord\Concerns\HasWizard;
 | |
| use Filament\Schemas\Components\Wizard\Step;
 | |
| use Filament\Support\Exceptions\Halt;
 | |
| use Illuminate\Database\Eloquent\Builder;
 | |
| use Illuminate\Database\Eloquent\Model;
 | |
| use Illuminate\Support\HtmlString;
 | |
| use Illuminate\Support\Str;
 | |
| use PDOException;
 | |
| use Throwable;
 | |
| 
 | |
| class CreateDatabaseHost extends CreateRecord
 | |
| {
 | |
|     use CanCustomizeHeaderActions;
 | |
|     use CanCustomizeHeaderWidgets;
 | |
|     use HasWizard;
 | |
| 
 | |
|     protected static string $resource = DatabaseHostResource::class;
 | |
| 
 | |
|     protected static bool $canCreateAnother = false;
 | |
| 
 | |
|     private HostCreationService $service;
 | |
| 
 | |
|     public function boot(HostCreationService $service): void
 | |
|     {
 | |
|         $this->service = $service;
 | |
|     }
 | |
| 
 | |
|     /** @return Step[]
 | |
|      * @throws Exception
 | |
|      */
 | |
|     public function getSteps(): array
 | |
|     {
 | |
|         return [
 | |
|             Step::make(trans('admin/databasehost.setup.preparations'))
 | |
|                 ->columns()
 | |
|                 ->schema([
 | |
|                     TextEntry::make('setup')
 | |
|                         ->hiddenLabel()
 | |
|                         ->state(trans('admin/databasehost.setup.note')),
 | |
|                     Toggle::make('different_server')
 | |
|                         ->label(new HtmlString(trans('admin/databasehost.setup.different_server')))
 | |
|                         ->dehydrated(false)
 | |
|                         ->live()
 | |
|                         ->columnSpanFull()
 | |
|                         ->afterStateUpdated(fn ($state, Set $set) => $state ? $set('panel_ip', gethostbyname(str(config('app.url'))->replace(['http:', 'https:', '/'], ''))) : '127.0.0.1'),
 | |
|                     Hidden::make('panel_ip')
 | |
|                         ->default('127.0.0.1')
 | |
|                         ->dehydrated(false),
 | |
|                     TextInput::make('username')
 | |
|                         ->label(trans('admin/databasehost.username'))
 | |
|                         ->helperText(trans('admin/databasehost.username_help'))
 | |
|                         ->required()
 | |
|                         ->default('pelicanuser')
 | |
|                         ->maxLength(255),
 | |
|                     TextInput::make('password')
 | |
|                         ->label(trans('admin/databasehost.password'))
 | |
|                         ->helperText(trans('admin/databasehost.password_help'))
 | |
|                         ->required()
 | |
|                         ->default(Str::password(16))
 | |
|                         ->password()
 | |
|                         ->revealable()
 | |
|                         ->maxLength(255),
 | |
|                 ])
 | |
|                 ->afterValidation(function (Get $get, Set $set) {
 | |
|                     $set('create_user', "CREATE USER '{$get('username')}'@'{$get('panel_ip')}' IDENTIFIED BY '{$get('password')}';");
 | |
|                     $set('assign_permissions', "GRANT ALL PRIVILEGES ON *.* TO '{$get('username')}'@'{$get('panel_ip')}' WITH GRANT OPTION;");
 | |
|                 }),
 | |
|             Step::make(trans('admin/databasehost.setup.database_setup'))
 | |
|                 ->schema([
 | |
|                     Fieldset::make(trans('admin/databasehost.setup.database_user'))
 | |
|                         ->schema([
 | |
|                             TextEntry::make('cli_login')
 | |
|                                 ->hiddenLabel()
 | |
|                                 ->state(new HtmlString(trans('admin/databasehost.setup.cli_login')))
 | |
|                                 ->columnSpanFull(),
 | |
|                             TextInput::make('create_user')
 | |
|                                 ->label(trans('admin/databasehost.setup.command_create_user'))
 | |
|                                 ->default(fn (Get $get) => "CREATE USER '{$get('username')}'@'{$get('panel_ip')}' IDENTIFIED BY '{$get('password')}';")
 | |
|                                 ->disabled()
 | |
|                                 ->dehydrated(false)
 | |
|                                 ->copyable(fn () => request()->isSecure())
 | |
|                                 ->columnSpanFull(),
 | |
|                             TextInput::make('assign_permissions')
 | |
|                                 ->label(trans('admin/databasehost.setup.command_assign_permissions'))
 | |
|                                 ->default(fn (Get $get) => "GRANT ALL PRIVILEGES ON *.* TO '{$get('username')}'@'{$get('panel_ip')}' WITH GRANT OPTION;")
 | |
|                                 ->disabled()
 | |
|                                 ->dehydrated(false)
 | |
|                                 ->copyable(fn () => request()->isSecure())
 | |
|                                 ->columnSpanFull(),
 | |
|                             TextEntry::make('cli_exit')
 | |
|                                 ->hiddenLabel()
 | |
|                                 ->state(new HtmlString(trans('admin/databasehost.setup.cli_exit')))
 | |
|                                 ->columnSpanFull(),
 | |
|                         ]),
 | |
|                     Fieldset::make(trans('admin/databasehost.setup.external_access'))
 | |
|                         ->schema([
 | |
|                             TextEntry::make('allow_external_access')
 | |
|                                 ->hiddenLabel()
 | |
|                                 ->state(new HtmlString(trans('admin/databasehost.setup.allow_external_access')))
 | |
|                                 ->columnSpanFull(),
 | |
|                         ]),
 | |
|                 ]),
 | |
|             Step::make(trans('admin/databasehost.setup.panel_setup'))
 | |
|                 ->columns([
 | |
|                     'default' => 2,
 | |
|                     'lg' => 3,
 | |
|                 ])
 | |
|                 ->schema([
 | |
|                     TextInput::make('host')
 | |
|                         ->columnSpan(2)
 | |
|                         ->label(trans('admin/databasehost.host'))
 | |
|                         ->helperText(trans('admin/databasehost.host_help'))
 | |
|                         ->required()
 | |
|                         ->live(onBlur: true)
 | |
|                         ->afterStateUpdated(fn ($state, Set $set) => $set('name', $state))
 | |
|                         ->maxLength(255),
 | |
|                     TextInput::make('port')
 | |
|                         ->label(trans('admin/databasehost.port'))
 | |
|                         ->helperText(trans('admin/databasehost.port_help'))
 | |
|                         ->required()
 | |
|                         ->numeric()
 | |
|                         ->default(3306)
 | |
|                         ->minValue(0)
 | |
|                         ->maxValue(65535),
 | |
|                     TextInput::make('max_databases')
 | |
|                         ->label(trans('admin/databasehost.max_database'))
 | |
|                         ->helpertext(trans('admin/databasehost.max_databases_help'))
 | |
|                         ->placeholder(trans('admin/databasehost.unlimited'))
 | |
|                         ->numeric(),
 | |
|                     TextInput::make('name')
 | |
|                         ->label(trans('admin/databasehost.display_name'))
 | |
|                         ->helperText(trans('admin/databasehost.display_name_help'))
 | |
|                         ->required()
 | |
|                         ->maxLength(60),
 | |
|                     Select::make('node_ids')
 | |
|                         ->multiple()
 | |
|                         ->searchable()
 | |
|                         ->preload()
 | |
|                         ->helperText(trans('admin/databasehost.linked_nodes_help'))
 | |
|                         ->label(trans('admin/databasehost.linked_nodes'))
 | |
|                         ->relationship('nodes', 'name', fn (Builder $query) => $query->whereIn('nodes.id', auth()->user()->accessibleNodes()->pluck('id'))),
 | |
|                 ]),
 | |
|         ];
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @throws Halt
 | |
|      * @throws Throwable
 | |
|      */
 | |
|     protected function handleRecordCreation(array $data): Model
 | |
|     {
 | |
|         try {
 | |
|             return $this->service->handle($data);
 | |
|         } catch (PDOException $exception) {
 | |
|             Notification::make()
 | |
|                 ->title(trans('admin/databasehost.error'))
 | |
|                 ->body($exception->getMessage())
 | |
|                 ->color('danger')
 | |
|                 ->icon('tabler-database')
 | |
|                 ->danger()
 | |
|                 ->send();
 | |
| 
 | |
|             throw new Halt();
 | |
|         }
 | |
|     }
 | |
| }
 |