glooby / task-bundle
Scheduling of tasks for symfony made simple
Installs: 15 452
Dependents: 0
Suggesters: 0
Security: 0
Stars: 32
Watchers: 4
Forks: 13
Type:symfony-bundle
Requires
- php: >=7.1
- doctrine/orm: ~2.6
- dragonmantank/cron-expression: ~2.0
- symfony/framework-bundle: ~4.3
Requires (Dev)
- php-coveralls/php-coveralls: ~2.1
- phpspec/prophecy: ~1.8
- phpunit/phpunit: ^7
- symfony/phpunit-bridge: ^4.3
README
Provides a simple framework to manage scheduling and execution of tasks Symfony application.
Prerequisite
This bundle requires cron to be installed on the server to be able to execute scheduled tasks
Installation
Add the glooby/task-bundle
package to your require
section in the composer.json
file.
$ composer require glooby/task-bundle ~3.0
Add the GloobyTaskBundle to your application's kernel:
<?php public function registerBundles() { $bundles = [ // ... new Glooby\TaskBundle\GloobyTaskBundle(), // ... ]; ... }
Create this file /etc/cron.d/glooby_scheduler_run
* * * * * nginx cd /path/to/project && php bin/console scheduler:run --env=prod &> /dev/null 2>&1
Documentation
Create a executable Task
To setup a new runnable task you should follow these steps
Implement the TaskInterface
example: src/Glooby/Api/TaskBundle/Task/PingTask.php
class PingTask implements TaskInterface { /** * @inheritdoc */ public function run(array $params = []) { return 'pong'; } }
Add a service for your task
services: glooby_task.ping: class: Glooby\TaskBundle\Task\PingTask
Try and run the task trough cli
$ bin/console task:run glooby_task.ping
"pong"
Setup Scheduled task
To setup a new schedule you should follow the steps below
Make your service runnable
Follow the steps in [Create a executable Task](#Create a executable Task)
Tag your service
By tagging your service with the glooby.scheduled_task tag it will be treated as a scheduled task
example:
src/Glooby/Api/TaskBundle/Resources/config/services.yml
services: glooby_task.ping: class: Glooby\TaskBundle\Task\PingTask tags: - { name: glooby.scheduled_task }
Annotate your class
Annotate your class with this annotation: Glooby\TaskBundle\Annotation\Schedule
Parameters
interval
The first parameter to the annotation is defaulted to the interval parameter. In this parameter you configure the interval that the service should be executed.
The interval is a string of five or optional six subexpressions that describe details of the schedule. The syntax is based on the Linux cron daemon definition.
* * * * * *
- - - - - -
| | | | | |
| | | | | + year [optional]
| | | | +----- day of week (0 - 7) (Sunday=0 or 7)
| | | +---------- month (1 - 12)
| | +--------------- day of month (1 - 31)
| +-------------------- hour (0 - 23)
+------------------------- min (0 - 59)
This is the only required parameter
use Glooby\TaskBundle\Annotation\Schedule; /** * @Schedule("* * * * *") */ class PingTask implements TaskInterface {
Here you have several shortcuts that you can use instead for most common use cases
use Glooby\TaskBundle\Annotation\Schedule; /** * @Schedule("@hourly") */ class PingTask implements TaskInterface {
params
The params that should be used when calling
use Glooby\TaskBundle\Annotation\Schedule; /** * @Schedule("@weekly", params={"wash": true, "flush": 500}) */ class CityImporter implements TaskInterface {
active
Phe active parameter tells if the schedule should be active or not, default=true
use Glooby\TaskBundle\Annotation\Schedule; /** * @Schedule("*/6", active=false) */ class PingTask implements TaskInterface {
Sync schedules to the database, this has to be run after each update
bin/console scheduler:run
Running the Tests
Install the dependencies:
$ script/bootstrap
Then, run the test suite:
$ script/test
Contributing
See CONTRIBUTING file.
License
This bundle is released under the MIT license. See the complete license in the bundle: LICENSE.md