There will be times when you need to create your own artisan command, and it is totally possible with laravel, you can create your own artisan command, in this tutorial i will show you how to create artisan command on laravel 4.2.
On laravel 4.2, the artisan command is stored under app/commands folder, the artisan command is just a regular php file. You don't need to create the php file manually, there is a dedicated artisan command for generating the php file under app/commands folder.
For this tutorial, let's create a simple artisan command for displaying text, the class name for this artisan command is called 'hello', and the command will be 'php artisan say:hello', with parameter input --name.
Creating the php file
To generate php file under app/commands, you can use 'php artisan command:make', so here's what we do:
php artisan command:make hello
If you check app/commands folder, you can see there is a new file called hello.php
Editing the php file
Next we need to edit the php file, in this case hello.php (app/commands/hello.php), make sure exactly like this (copy-paste the code if you have to):
<?php
use Illuminate\Console\Command;
use Symfony\Component\Console\Input\InputOption;
use Symfony\Component\Console\Input\InputArgument;
class hello extends Command {
/**
* The console command name.
*
* @var string
*/
protected $name = 'say:hello';
/**
* The console command description.
*
* @var string
*/
protected $description = 'This command is just learning purpose.';
/**
* Create a new command instance.
*
* @return void
*/
public function __construct()
{
parent::__construct();
}
/**
* Execute the console command.
*
* @return mixed
*/
public function fire()
{
$name = $this->option('name');
$greeting = 'Hello';
$question = ' how are you today?';
if (!empty($name)) {
$name = ' ' . $name . ',';
}
$display = $greeting . $name . $question;
$this->info($display);
}
/**
* Get the console command arguments.
*
* @return array
*/
protected function getArguments()
{
return array(
array('example', InputArgument::OPTIONAL, 'An example argument.'),
);
}
/**
* Get the console command options.
*
* @return array
*/
protected function getOptions()
{
return array(
array('name', null, InputOption::VALUE_OPTIONAL, 'Enter your name here.', null),
);
}
}
Registering the artisan command
We are not done yet, we still need to register the artisan command that we just created, open app/start/artisan.php file and add the following code:
Okay, now we can test the artisan command, see if it's working or not, the command would be:
<?php
/*
|--------------------------------------------------------------------------
| Register The Artisan Commands
|--------------------------------------------------------------------------
|
| Each available Artisan command must be registered with the console so
| that it is available to be called. We'll register every command so
| the console gets access to each of the command object instances.
|
*/
// Artisan command for saying hello
Artisan::add(new hello);
Okay, now we can test the artisan command, see if it's working or not, the command would be:
php artisan say:hello
php artisan say:hello --name=jessica