Vinci Console is an auxiliary component to help create files faster, such as login structures, password recovery structures, database configuration and more.
To access Vinci, open the terminal in your project folder and type php vinci [command]. To access information about Solital and its dependencies, open your terminal inside your project folder and type php vinci version
To run the Vinci console on Windows, remember to add the PHP directory to the Windows PATH. Also check if your version of Windows or your editor supports ANSI characters.
The Vinci Console is a very simple to use helper. When you run the php vinci list command, you will get a description of all the commands present in the Solital Framework.
Example
php vinci [command] [argument] [--option1] [--option2]
| Command | Description | Arguments | Options | 
|---|---|---|---|
| auth:skeleton | Create Login and 'Forgot Password' structures | - | --login / --forgot / --remove | 
| clear-history | Clear a command history | - | - | 
| create:cmd | Create a command | name | --remove | 
| create:controller | Create a Controller class | name | --remove | 
| create:middleware | Create a Middleware class | name | --remove | 
| create:migration | Create a migration | name (optional) | - | 
| create:model | Create a Model class | name | --remove | 
| create:queue | Create a Queue class | name | --remove | 
| create:seeder | Create a Seeder class | name | - | 
| create:router | Create a new router | name | --comment | 
| db:dump | Dump the connected database | name | - | 
| db:list | List data from a database table | - | --limit=10 | 
| generate:files | Imports Solital Framework's default configuration files | - | - | 
| history | Get all command history | - | - | 
| migrate | Run a migration | - | --rollback (=value) / --status | 
| queue | Run a queue | - | --class (=name) | 
| router:list | Show all routes | - | - | 
| scanner | Find infected files | - | - | 
| schedule | Create a schedule class | name | - | 
| seeder | Run a user-created Seeder | - | --class (=name) | 
| server | Start built-in PHP server | - | - | 
| status | Check app status | - | |
| storage:clear | Clear the Solital cache | - | --cache / --session / --schedules / --log | 
| version | Describes a command | cmd_name | - | 
| help | Displays details about some command | - | - | 
| about | Displays the Vinci Console version | - | |
| list | Displays a list of all Solital commands | - | - | 
To create a custom command, you need to run the command php vinci create:cmd [command_name_class]. This command will create a class in the app/Console/Command folder.
Below is an example of the command and the created class:
Command
php vinci create:cmd UserCommand
Generated class
<?php
namespace Solital\Console\Command;
use Solital\Core\Console\Command;
use Solital\Core\Console\Interface\CommandInterface;
class UserCommand extends Command implements CommandInterface
{
    /**
     * @var string
     */
    protected string $command = "";
    /**
     * @var array
     */
    protected array $arguments = [];
    /**
     * @var array
     */
    protected array $options = [];
    /**
     * @var string
     */
    protected string $description = "";
    /**
     * @param object $arguments
     * @param object $options
     * 
     * @return mixed
     */
    #[\Override]
    public function handle(object $arguments, object $options): mixed
    {
        return $this;
    }
}
In the $command variable, you will define the custom command that will be executed. The $arguments variable will have an array of values containing all arguments (if your custom command has no arguments, leave this variable empty). The variable $options must contain mandatory options for your command, otherwise use the options dynamically. Lastly, the $description variable will have a short description of what the custom command does.
The handle method will contain all the code that will be executed when executing the custom command and should always return a $this or, if necessary, another value.
Using Arguments
Arguments can be retrieved using the $arguments variable:
php vinci user:cmd myArgument
In the class:
protected array $arguments = ['name'];
If you pass more arguments than are specified in your command's class, a warning will be displayed.
Using Options
Options can be returned dynamically, but you must check in the handle method whether an option exists.
php vinci user:cmd name --myOption
#[\Override]
public function handle(object $arguments, object $options): mixed
{
    if (isset($options->myOption)) {
        # ...
    }
    return $this;
}
If you have any mandatory options that must be entered when executing the command, you can define these options using the variable $options.
protected array $options = ['--myoption', '--withArg='];
In the example above, the command must contain one of the options. If an option requires entering a value, use = next to the option (see the example above: --withArg=).
This will mean that when using this option, the user will enter a value (for example: --withArg=accept).
It is very common to enter an input value on the command line when needed. Using the InputOutput class, you can perform this action.
use Solital\Core\Console\InputOutput;
$input_output = new InputOutput();
$input_output->dialog('Enter a string: ')->action(function ($message) {
    echo $message . PHP_EOL;
});
The dialog() method will display a message to the user to inform a input value, while the action() method retrieves the value entered on the command line.
The action() method performs an action using the previously entered value. This method uses an anonymous function with the variable $message as a parameter.
You can also use a "yes/no" confirmation, or any other value.
use Solital\Core\Console\InputOutput;
$input_output = new InputOutput();
$input_output->confirmDialog('What you want?', 'Y', 'N', false);
$input_output->confirm(function () {
    echo "accepted" . PHP_EOL;
})->refuse(function () {
    echo "denied" . PHP_EOL;
});
In the first parameter of the confirmDialog method, you will define the question. The second parameter will be the value of the answer if it is positive, if not, the third parameter will receive the value of the answer if it is negative. The fourth parameter will define if the answer is know sensitive, if not, set it to false.
This method must be used together with two other methods: confirm() and refuse().
To customize the colors of the message that is displayed from the CLI, you must use the color() method. To use the available colors, you must use the ColorsEnum enum.
use Solital\Core\Console\Output\ColorsEnum;
$input_output = new InputOutput();
$inout_output->color(ColorsEnum::GREEN);
By default, the previous methods display input to the user. However, in the case of passwords, you must use the password() method.
You can take the entered password and use it in another part of your code.
$input_output = new InputOutput();
$password = $input_output->password("Enter the password");
echo $password;
To display data in the console, use the ConsoleOutput class. Below are some of the main methods you can use to display messages in a personalized way.
use Solital\Core\Console\Output\ConsoleOutput;
ConsoleOutput::success($message, $space);    // Display a success message
ConsoleOutput::info($message, $space);       // Display an information message
ConsoleOutput::warning($message, $space);    // Displays a warning message
ConsoleOutput::error($message, $space);      // Displays an error message
ConsoleOutput::line($message, $space);       // Display a standard message
true, adds a margin to the left of the message.After that, to display the message on the command line, use the print() method:
ConsoleOutput::success("My message")->print();
If you need to skip some lines in the console, you can use the break() method. This method accepts the value true and also int values.
// Skip a line
ConsoleOutput::success("My message")->print()->break();
// Skip two lines
ConsoleOutput::success("My message")->print()->break(true);
// Skip three lines. Use an INT value
ConsoleOutput::success("My message")->print()->break(3);
To stop script execution when displaying a message on the console, use the exit() method.
ConsoleOutput::success("My message")->print()->exit();
This method uses the native PHP function exit(). You can also add a message to this function.
ConsoleOutput::success("My message")->print()->exit("My exit message");
If you want to add a custom color to your message, you must use the message method. You must make use of the Enum ColorsEnum. This enum has forground and background colors.
However, if you want to use any type of color, then you must use the color number instead of the Enum.
use Solital\Core\Console\Output\ColorsEnum;
// With ColorsEnum
ConsoleOutput::message("My message", ColorsEnum::LIGHT_BLUE)->print();
// With custom color
ConsoleOutput::message("My message", 49)->print();
To display all foreground and background colors that do not exist in ColorsEnum, you can use the methods below.
echo ConsoleOutput::getForegroundColors() . PHP_EOL;
echo ConsoleOutput::getBackgroundColors();
Banners are large messages intended to display important information. Use the banner() method.
ConsoleOutput::banner("My message", ColorsEnum::BG_BLUE)->print();
If you need to increase or decrease the banner size, change the third parameter.
ConsoleOutput::banner("My message", ColorsEnum::BG_BLUE, 40)->print();
There is a different type of display message used for debugging using the debugMessage() method.
ConsoleOutput::debugMessage("My message", $title, $color)->print();
ColorsEnum or an integer number.To clear a message from the console, you can use the clear() method, informing, if necessary, the time it will take (in seconds) for the message to be cleared.
ConsoleOutput::success("My message")->print();
// Without time
ConsoleOutput::clear(); 
// With time
ConsoleOutput::clear(2);
If you want to display the execution time of a method or function in the console, you can use the status() method. This method displays whether a method or function was executed correctly or whether there was an error through a Boolean return. If the return is not Boolean, a simple message is displayed.
You must add in the first parameter the name of the task that the method or function is doing. For example, if you are saving a user to the database, you can add creating_user. The second parameter will be the closure.
To display the status, you must use the printStatus() method.
ConsoleOutput::status('creating_user', function () {
    return true;
})->printStatus();
In the previous example, the return is true. Therefore, an OK will be displayed in the console. If the return is false, an ERROR will be displayed.
To customize these messages, you must add values to the parameters of the printStatus() method. You can also disable the script time display.
ConsoleOutput::status('creating_user', function () {
    return true;
})->printStatus('accept', 'not accept', false);
If you have a command, and want to call another command within the same class, you can use the call() method.
For example, you have an InsertCommand class:
<?php
namespace Solital\Console\Command;
use Solital\Core\Console\Command;
use Solital\Core\Console\Interface\CommandInterface;
class InsertCommand extends Command implements CommandInterface
{
    /**
     * @var string
     */
    protected string $command = "cmd:insert";
    /**
     * @var array
     */
    protected array $arguments = [];
    /**
     * @var array
     */
      protected array $options = [];
    /**
     * @var string
     */
    protected string $description = "";
    /**
     * @param object $arguments
     * @param object $options
     * 
     * @return mixed
     */
    #[\Override]
    public function handle(object $arguments, object $options): mixed
    {
        echo "Insert a value";
        return $this;
    }
}
And you also have an UpdateCommand class. You can execute the command from the previous class within this new class.
<?php
namespace Solital\Console\Command;
use Solital\Core\Console\Command;
use Solital\Core\Console\Interface\CommandInterface;
class UpdateCommand extends Command implements CommandInterface
{
    /**
     * @var string
     */
    protected string $command = "cmd:update";
    /**
     * @var array
     */
    protected array $arguments = [];
    /**
     * @var array
     */
    protected array $options = [];
    /**
     * @var string
     */
    protected string $description = "";
    /**
     * @param object $arguments
     * @param object $options
     * 
     * @return mixed
     */
    #[\Override]
    public function handle(object $arguments, object $options): mixed
    {
        Command::call('cmd:insert');
        return $this;
    }
}
Progressbar has customizable names, colors, datatypes, error handling, and more.
Usage
use Solital\Core\Console\ProgressBar\ProgressBar;
use Solital\Core\Console\ProgressBar\ProgressBarStyle;
//Lets create a style object first.
//Style object has 4 parameters {$name, $color, $datatype, $length}.
$progressbar_style = new ProgressBarStyle("Downloading", "white", "Kb", 16);
//Now lets create the progressbar object.
//Progressbar object has 2 parameters {$styleobject, $initialmax}
$progressbar = new ProgressBar($progressbar_style, 1000);
Using the Progressbar
//Loop until the progressbar is complete
for ($i = 0; $i < $progressbar->GetInitialMax(); $i++) {
    $progressbar->step();
    usleep(1000);
}
Methods
//Increases the progressbar value by 1.
$progressbar->step();
//Increases the progressbar value by x.
$progressbar->stepBy(x);
//Changes the progressbar value to x.
$progressbar->stepTo(x);
//Gets the progressbar value.
$progressbar->getValue();
//Gets the max initial value.
$progressbar->getInitialMax();
//Forces a redraw on the progressbar.
$progressbar->update();
//Enables the pause mode, it can be removed by using any of the step methods or forcing a redraw.
$progressbar->pauseProgressbar();
//Resets the progressbar object.
$progressbar->resetProgressbar();
//Terminates the progressbar and resets the object.
$progressbar->terminateProgressbar();
You can create tables in the console. To do this, use the Table class. 
use Solital\Core\Console\Table;
$table = new Table();
$table->row([
    'id'        => 1,
    'name'      => 'Matthew S.',
    'surname'   => 'Kramer',
    'email'     => 'matthew@example.com',
    'status'    => true,
]);
$table->row([
    'id'        => 2,
    'name'      => 'Millie J.',
    'surname'   => 'Koenig',
    'email'     => 'millie@example.com',
    'status'    => false,
]);
$table->row([
    'id'        => 3,
    'name'      => 'Regina G.',
    'surname'   => 'Hart',
    'email'     => 'regina@example.com',
    'status'    => true,
]);
echo $table;
Output :

use Solital\Core\Console\Table;
$table = new Table();
$table->setBorderStyle(Table::COLOR_BLUE);
$table->setCellStyle(Table::COLOR_GREEN);
$table->setHeaderStyle(Table::COLOR_RED, Table::BOLD);
$table->setColumnCellStyle('id', Table::ITALIC, Table::COLOR_LIGHT_YELLOW);
$table->setColumnCellStyle('email', Table::BOLD, Table::ITALIC);
$table->row([
    'id'        => 1,
    'name'      => 'Matthew S.',
    'surname'   => 'Kramer',
    'email'     => 'matthew@example.com',
    'status'    => true,
]);
$table->row([
    'id'        => 2,
    'name'      => 'Millie J.',
    'surname'   => 'Koenig',
    'email'     => 'millie@example.com',
    'status'    => false,
]);
$table->row([
    'id'        => 3,
    'name'      => 'Regina G.',
    'surname'   => 'Hart',
    'email'     => 'regina@example.com',
    'status'    => true,
]);
echo $table;
Output :

Credits - Muhammet ŞAFAK
If you need a standard header and just add the values, use the dynamicRows method.
use Solital\Core\Console\Table;
$header = ['name', 'email', 'age'];
$values = [
  ['Foo', 'foo@email.com', 20],
  ['Bar', 'bar@email.com', 30]
];
$table = new Table();
$table->setHeaderStyle(Table::COLOR_LIGHT_GREEN);
$table->dynamicRows($header, $values);
Formatted lines are a way of organizing data that contains some additional information. You can see an example of this method in use by running the php vinci list command.
use Solital\Core\Console\Table;
$values = [
  'user' => 'Admin',
  'email' => 'admin@gmail.com'
];
Table::formattedRowData($values);
The second parameter you can define the spacing between the information. In the third parameter you can create a margin on the left side.
use Solital\Core\Console\Table;
$values = [
  'user' => 'Admin',
  'email' => 'admin@gmail.com'
];
Table::formattedRowData($values, 50, true);