When building command-line tools in Laravel, one of the common challenges is handling missing or incorrect user input gracefully. Laravel's PromptsForMissingInput trait addresses this by transforming standard Artisan commands into interactive dialogues.
Rather than failing when arguments are missing, your commands can engage users with helpful prompts, guiding them through the required inputs. This approach is particularly valuable for complex maintenance tasks, deployment scripts, or any situation where you need to ensure accurate command-line input while maintaining a professional and user-friendly interface.
<!-- Syntax highlighted by torchlight.dev -->use Illuminate\Console\Command; use Illuminate\Contracts\Console\PromptsForMissingInput; class PublishContent extends Command implements PromptsForMissingInput { protected $signature = 'content:publish {type} {status}'; protected function promptForMissingArgumentsUsing(): array { return [ 'type' => 'What type of content are you publishing?', 'status' => 'Should this be published as draft or live?' ]; } }
Let's explore a practical example of a database backup command with interactive prompts:
<!-- Syntax highlighted by torchlight.dev --><?php namespace App\Console\Commands; use Illuminate\Console\Command; use Illuminate\Contracts\Console\PromptsForMissingInput; class BackupDatabase extends Command implements PromptsForMissingInput { protected $signature = 'db:backup {connection? : Database connection to backup} {--tables=* : Specific tables to backup} {--compress : Compress the backup file}'; protected $description = 'Create a database backup'; protected function promptForMissingArgumentsUsing(): array { return [ 'connection' => fn () => choice( 'Which database connection should be backed up?', [ 'mysql' => 'MySQL Primary Database', 'sqlite' => 'SQLite Testing Database', 'pgsql' => 'PostgreSQL Analytics Database' ], 'mysql' ), '--tables' => fn () => multiChoice( 'Select tables to backup (leave empty for all):', $this->getAvailableTables() ), '--compress' => fn () => confirm( 'Would you like to compress the backup?', true ) ]; } private function getAvailableTables(): array { // Fetch tables from database return ['users', 'posts', 'comments', 'orders']; } public function handle() { $connection = $this->argument('connection'); $tables = $this->option('tables'); $compress = $this->option('compress'); $this->info("Starting backup of {$connection} database..."); // Backup logic here... } }
The PromptsForMissingInput interface transforms command-line interactions into user-friendly dialogues, making your Artisan commands more intuitive and easier to use.
The above is the detailed content of Interactive Console Commands in Laravel. For more information, please follow other related articles on the PHP Chinese website!