An open API service indexing awesome lists of open source software.

https://github.com/flowpack/task

Task Scheduler for Neos
https://github.com/flowpack/task

hacktoberfest scheduler task-runner

Last synced: 11 months ago
JSON representation

Task Scheduler for Neos

Awesome Lists containing this project

README

          

# Flow Framework Task Scheduler

[![Latest Stable Version](https://poser.pugx.org/flowpack/task/v/stable)](https://packagist.org/packages/flowpack/task) [![Total Downloads](https://poser.pugx.org/flowpack/task/downloads)](https://packagist.org/packages/flowpack/task) [![License](https://poser.pugx.org/flowpack/task/license)](https://packagist.org/packages/flowpack/task)

This package provides a simple to use task scheduler for Neos Flow. Tasks are configured via settings, recurring tasks can be configured using cron syntax. Detailed options configure the first and last executions as well as options for the class handling the task.

Scheduling and running tasks are decoupled: The `Scheduler` schedules tasks whcih the are executed by the `TaskRunner`. This architecture allows receiving and displaying metrics of already executed tasks.

Most of the architectural ideas behind the package are taken from [php-task](https://github.com/php-task/php-task), and reimplemented for Neos Flow.

## Installation

```bash
composer require 'flowpack/task'
```

## Configuration

### Defining A Task

```yaml
Flowpack:
Task:
tasks:
'a-unique-identifier':
label: The label of this task
description: Some detailed description of this task
# A class, implementing the TaskHandlerInterface
handlerClass: 'Vendor\Package\TaskHandler\TaskHandlerClass'
cronExpression: '*/5 * * * *'
# A workload, eg. some configuration, given to the taskHandler
workload:
interval: PT5M
```

### General Options

* `lockStorage`: Configuration string for the lock storage used for taskHandler implementing `LockingTaskHandlerInterface`. See https://symfony.com/doc/current/components/lock.html#available-stores for more options

* `keepTaskExecutionHistory`: Number of task executions to keep in the database. (default: 3)

## Implementing A Task Handler

A task handler contains the code executed for a specific task. Your command handler has to implement one of the following interfaces:

`Flowpack\Task\TaskHandler\TaskHandlerInterface`

A basic task. The interface requires the method `handle(WorkloadInterface $workload): string` to be implemented. The return value serves as information for successfully executed tasks.

`Flowpack\Task\TaskHandler\RetryTaskHandlerInterface`

Also requires `getMaximumAttempts(): int` to be implemented. Allowing the tasks to be retried on failure.

`Flowpack\Task\TaskHandler\LockingTaskHandlerInterface`

Also requires `getLockIdentifier(WorkloadInterface $workload): string` to be implemented. The return value specifies a lock to be acquired. When such a task is running, other tasks requiring the same lock will be skipped.

## Available Commands

Schedule and run due tasks

```bash
./flow task:run
```
Schedule and run a single task

```bash
./flow task:runSingle
```

Show a list of all defined and scheduled tasks:

```bash
./flow task:list
```

Show details about a specific task:

```bash
./flow task:show
```