Home >Backend Development >PHP Tutorial >Interactive Console Commands in Laravel

Interactive Console Commands in Laravel

百草
百草Original
2025-03-06 01:06:11403browse

Interactive Console Commands in Laravel

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 = &#39;db:backup
        {connection? : Database connection to backup}
        {--tables=* : Specific tables to backup}
        {--compress : Compress the backup file}&#39;;
    protected $description = &#39;Create a database backup&#39;;

    protected function promptForMissingArgumentsUsing(): array
    {
        return [
            &#39;connection&#39; => 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!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn