Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/oliverde8/phpetlbundle
This bundle allows the execution of PHP etl chains in symfony with an interface to see execution history
https://github.com/oliverde8/phpetlbundle
bundle php symfony symfony-bundle
Last synced: 3 months ago
JSON representation
This bundle allows the execution of PHP etl chains in symfony with an interface to see execution history
- Host: GitHub
- URL: https://github.com/oliverde8/phpetlbundle
- Owner: oliverde8
- License: mit
- Created: 2021-05-04T20:46:04.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-10-11T12:55:24.000Z (3 months ago)
- Last Synced: 2024-10-11T13:50:37.391Z (3 months ago)
- Topics: bundle, php, symfony, symfony-bundle
- Language: PHP
- Homepage:
- Size: 202 KB
- Stars: 5
- Watchers: 2
- Forks: 2
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
- Security: Security/EtlExecutionVoter.php
Awesome Lists containing this project
README
# PHP Etl Bundle
[![Scrutinizer Code Quality](https://scrutinizer-ci.com/g/oliverde8/phpEtlBundle/badges/quality-score.png?b=main)](https://scrutinizer-ci.com/g/oliverde8/phpEtlBundle/?branch=main)
[![Build Status](https://scrutinizer-ci.com/g/oliverde8/phpEtlBundle/badges/build.png?b=main)](https://scrutinizer-ci.com/g/oliverde8/phpEtlBundle/build-status/main)
[![Code Coverage](https://scrutinizer-ci.com/g/oliverde8/phpEtlBundle/badges/coverage.png?b=main)](https://scrutinizer-ci.com/g/oliverde8/phpEtlBundle/?branch=main)
[![Latest Stable Version](https://poser.pugx.org/oliverde8/php-etl-bundle/v)](//packagist.org/packages/oliverde8/php-etl-bundle)
[![Total Downloads](https://poser.pugx.org/oliverde8/php-etl-bundle/downloads)](//packagist.org/packages/oliverde8/php-etl-bundle)
[![Latest Unstable Version](https://poser.pugx.org/oliverde8/php-etl-bundle/v/unstable)](//packagist.org/packages/oliverde8/php-etl-bundle)
[![License](https://poser.pugx.org/oliverde8/php-etl-bundle/license)](//packagist.org/packages/oliverde8/php-etl-bundle)The Php etl bundle allows the usage of [Oliver's PHP Etl](https://github.com/oliverde8/php-etl) library in symfony.
You should also check the [PHP ETL's Easy Admin Bundle](https://github.com/oliverde8/phpEtlEasyadminBundle) to have interfaces.
## Installation
1. Install using composer
2. in `/config/` create a directory `etl`
3. Enable bundle:
```php
\Oliverde8\PhpEtlBundle\Oliverde8PhpEtlBundle::class => ['all' => true],
```4. Optional: Enable queue if you wish to allow users from the easy admin panel to do executions.
```yaml
framework:
messenger:
routing:
"Oliverde8\PhpEtlBundle\Message\EtlExecutionMessage": async
```5. Optional: Enable creation of individual files for each log by editing the monolog.yaml
```yaml
etl:
type: service
id: Oliverde8\PhpEtlBundle\Services\ChainExecutionLogger
level: debug
channels: ["!event"]
```## Usage
### Creating an ETL chain
First read the documentation of the [PHP ETL](https://github.com/oliverde8/php-etl)
Each chain is declare in a single file. The name of the chain is the name of the file created in `/config/etl/`.
**Example:**
```yaml
chain:
"Dummy Step":
operation: rule-engine-transformer
options:
add: true
columns:
test:
rules:
- get : {field: [0, 'uid']}
```### Executing a chain
```sh
./bin/console etl:execute demo '[["test1"],["test2"]]' '{"opt1": "val1"}'
```The first argument is the input, depending on your chain it can be empty. The second are parameters that
will be available in the context of each link in the chain.### Additional commands
#### Get a definition
```sh
./bin/console etl:get-definition demo
```### Adding your own chain operation
To add your own chain operation you need 2 classes. The operation itself that we will call
`MyVendor\Etl\Operation\OurTestOperation`, and a `MyVendor\Etl\OperationFactory\OurTestOperationFactory` factory
to create it. The factory allows us to configure the operation and inject service to our operation.All operations needs to implement `DataChainOperationInterface`; they can extend `AbstractChainOperation`.
All factories needs to extend `Oliverde8\Component\PhpEtl\Builder\Factories\AbstractFactory`.
The operation is a Model and not a service, you therefore need to add the path to the exclusions so that it's not
made a service by symfony:
```yaml
App\:
resource: '../src/'
exclude:
- '../src/Etl/Operation'
```Factories needs to be tagged `etl.operation-factory\ . To remove the need to tag all your factories you can add
the following line your your services.yaml file
```yaml
MyVendor\Etl\OperationFactory\:
resource: '../src/Etl/OperationFactory/'
tags: ['etl.operation-factory']
```For more information on how the etl works and how to create operations check the [Php Etl Documentation](https://github.com/oliverde8/php-etl#creating-you-own-operations)