Download the PHP package zenaton/zenaton-laravel without Composer
On this page you can find all versions of the php package zenaton/zenaton-laravel. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download zenaton/zenaton-laravel
More information about zenaton/zenaton-laravel
Files in zenaton/zenaton-laravel
Package zenaton-laravel
Short Description Easily use Zenaton for background jobs in your Laravel application
License Apache-2.0
Informations about the package zenaton-laravel
⚠️ This repository is abandoned.
Easy Asynchronous Jobs Manager for Developers
Explore the docs »
Website
·
Examples in PHP
·
Tutorial in PHP
Zenaton for Laravel
Zenaton helps developers to easily run, monitor and orchestrate background jobs on your workers without managing a queuing system. In addition to this, a monitoring dashboard shows you in real-time tasks executions and helps you to handle errors.
The Zenaton Laravel package lets you code and launch tasks in your Laravel project, using Zenaton platform, as well as write workflows as code. You can sign up for an account on Zenaton and go through the tutorial in PHP.
PHP Documentation
You can find all details on Zenaton's website.
Table of contents
- [Getting started](#getting-started) - [Installation](#installation) - [Install the Zenaton Agent](#install-the-zenaton-agent) - [Install the Laravel package](#install-the-laravel-package) - [Quick start](#quick-start) - [Executing a background job](#executing-a-background-job) - [Orchestrating background jobs](#orchestrating-background-jobs) - [Using workflows](#using-workflows) - [Getting help](#getting-help)Getting started
Installation
Install the Zenaton Agent
To install the Zenaton agent, run the following command:
Then, you need your agent to listen to your application. To do this, you need your Application ID and API Token. You can find both on your Zenaton account.
Put them in your .env
file:
Now, to make the agent listen, run the following command:
Install the Laravel package
To add the latest version of the package to your project, run the following command:
Then, publish the default configuration file using the following command:
Quick start
Executing a background job
A background job in Zenaton is a class implementing the Zenaton\Interfaces\TaskInterface
interface.
Let's start by implementing a first task printing something, and returning a value.
You can generate tasks using the zenaton:make:task
artisan command:
Open the app/Zenaton/Tasks/HelloWorldTask.php
file that was generated for you and
implement the ::handle()
method as the following:
Now, when you want to run this task as a background job, you need to do the following:
That's all you need to get started. With this, you can run many background jobs. However, the real power of Zenaton is to be able to orchestrate these jobs. The next section will introduce you to job orchestration.
Orchestrating background jobs
Job orchestration is what allows you to write complex business workflows in a simple way. You can execute jobs sequentially, in parallel, conditionally based on the result of a previous job, and you can even use loops to repeat some tasks.
We wrote about some use-cases of job orchestration, you can take a look at these articles to see how people use job orchestration.
Using workflows
A workflow in Zenaton is a class implementing the Zenaton\Interfaces\WorkflowInterface
interface.
We will implement a very simple workflow:
First, it will execute the HelloWorld
task.
The result of the first task will be used to make a condition using an if
statement.
When the returned value will be greater than 0
, we will execute a second task named FinalTask
.
Otherwise, we won't do anything else.
One important thing to remember is that your workflow implementation must be idempotent. You can read more about that in our documentation.
Let's generate the workflow class to be able to work on it using the corresponding artisan command:
Open the app/Zenaton/Workflows/MyFirstWorkflow.php
file that was generated for you
and implement the ::handle()
method as the following:
Now that your workflow is implemented, you can execute it by calling the dispatch
method:
If you really want to run this example, you will need to implement the FinalTask
task.
There are many more features usable in workflows in order to get the orchestration done right. You can learn more in our documentation.
Getting help
Need help? Feel free to contact us by chat on Zenaton.
Found a bug? You can open a GitHub issue.