/laravel-schedule-list

Laravel package to add command to list all scheduled artisan commands

Primary LanguagePHPMIT LicenseMIT

Laravel 5 Schedule List

Build Status Scrutinizer Code Quality Code Coverage

Latest Stable Version Latest Unstable Version Total Downloads License

Laravel 5.5+ package to add a artisan command to list all scheduled artisan commands. With schedule time (cron expression), the command to execute and the command description.

Install

Require this package with composer using the following command:

composer require hmazter/laravel-schedule-list

Note! For Laravel version below 5.5 use 0.2.0 tag.

Usage

Usage from the command line to show all your scheduled artisan commands:

php artisan schedule:list

Outputs:

 +--------------+---------------------+--------------+-------------------------------+
 | expression   | next run at         | command      | description                   |
 +--------------+---------------------+--------------+-------------------------------+
 | 0 14 * * 3 * | 2017-08-16 14:00:00 | email:export | Export users to email service |
 +--------------+---------------------+--------------+-------------------------------+

Crontab style output

Use --cron to show the output in the same style as it would go in a crontab file.

Outputs:

0 14 * * 3 * '/usr/local/bin/php' 'artisan' email:export > '/dev/null' 2>&1`

Verbose output

Use -vv to show the full command, including php binary path and output path.

Outputs:

+--------------+---------------------+----------------------------------------------------------------+-------------------------------+
| expression   | next run at         | command                                                        | description                   |
+--------------+---------------------+----------------------------------------------------------------+-------------------------------+
| 0 14 * * 3 * | 2017-08-16 14:00:00 | '/usr/local/bin/php' 'artisan' email:export > '/dev/null' 2>&1 | Export users to email service |
+--------------+---------------------+----------------------------------------------------------------+-------------------------------+

Using -vv together with --cron does not change to output from normal --cron output.

Programmatic use

For occasions when you need to access the list of scheduled events programmatically \Hmazter\LaravelScheduleList\ScheduleList::all exists that will return all the scheduled events as an array of ScheduleEvent.

Inject the ScheduleList or resolve it from the Container and then call all() to get all scheduled events. Usage of it can be seen in ListScheduler::handle

Known limitations

Laravel ships with some special scheduling functions ex between, unlessBetween, when and skip these are not handled right now in the schedule listing output. They are evaluated at each execution of the schedule and does not define any expression that can be included in the table.