dukecity/command-scheduler-bundle

This Symfony bundle will allow you to schedule all your commands just like UNIX crontab

Installs: 322 417

Dependents: 3

Suggesters: 0

Security: 0

Stars: 24

Watchers: 1

Forks: 125

Open Issues: 14

Type:symfony-bundle

pkg:composer/dukecity/command-scheduler-bundle

v6.0.14 2025-12-09 11:39 UTC

README

Code_Checks codecov CodeRabbit Pull Request Reviews

This bundle will allow you to easily manage scheduling for Symfony's console commands (native or not) with cron expression. See Wiki for Details

Versions & Dependencies

Please read Upgrade-News for Version 6

Version 6.x has the goal to use modern Php and Symfony features and low maintenance. So only PHP >= 8.2 and Symfony ^7.0 (Latest: ^7.4|^8.0) are supported at the moment.

The following table shows the compatibilities of different versions of the bundle :

Version Symfony PHP
6.x (main) ^7.0 + ^8.0 >=8.2
5.x ^5.4 + ^6.0 >=8.0
4.x ^4.4.20 + ^5.3 >=8.0
3.x ^4.4.20 + ^5.3 >=7.3
2.2.x ^3.4 + ^4.3 ^7.1

Install

When using Symfony Flex there is an installation recipe.
To use it, you have to enable contrib recipes on your project :

composer config extra.symfony.allow-contrib true
composer req dukecity/command-scheduler-bundle

Update Database

If you're using DoctrineMigrationsBundle (recommended way):

php bin/console make:migration
php bin/console doctrine:migrations:migrate

Without DoctrineMigrationsBundle:

php bin/console doctrine:schema:update --force

Install Assets

php bin/console assets:install --symlink --relative public

Secure your route

Add this line to your security config.

- { path: ^/command-scheduler, role: ROLE_ADMIN } 

Check new URL /command-scheduler/list

Features and Changelog

Please read Changelog

Screenshots

list

new

new2

Extending the ScheduledCommand Entity

You can extend the default ScheduledCommand entity to add custom fields or behavior. The bundle uses a MappedSuperclass pattern with an interface for maximum flexibility.

Creating a Custom Entity

  1. Create your custom entity extending BaseScheduledCommand:
<?php

namespace App\Entity;

use Doctrine\ORM\Mapping as ORM;
use Dukecity\CommandSchedulerBundle\Entity\BaseScheduledCommand;

#[ORM\Entity]
#[ORM\Table(name: 'scheduled_command')]
class MyScheduledCommand extends BaseScheduledCommand
{
    #[ORM\Column(type: 'string', nullable: true)]
    private ?string $customField = null;

    public function getCustomField(): ?string
    {
        return $this->customField;
    }

    public function setCustomField(?string $customField): static
    {
        $this->customField = $customField;
        return $this;
    }
}
  1. Configure the bundle to use your custom entity:
# config/packages/dukecity_command_scheduler.yaml
dukecity_command_scheduler:
    scheduled_command_class: App\Entity\MyScheduledCommand
  1. Update your database schema:
php bin/console make:migration
php bin/console doctrine:migrations:migrate

Available Extension Points

  • ScheduledCommandInterface - Contract for all scheduled command entities
  • BaseScheduledCommand - MappedSuperclass with all base properties and methods
  • ScheduledCommand - Default concrete entity (used if no custom class configured)
  • ScheduledCommandFactory - Service for creating entity instances

Documentation

See the documentation here.

License

This bundle is under the MIT license. See the complete license for info.