Download the PHP package jagarsoft/laravel-tactician without Composer
On this page you can find all versions of the php package jagarsoft/laravel-tactician. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download jagarsoft/laravel-tactician
More information about jagarsoft/laravel-tactician
Files in jagarsoft/laravel-tactician
Package laravel-tactician
Short Description Laravel implementation of the Tactician Command Bus
License MIT
Informations about the package laravel-tactician
Laravel Tactician
Laravel Tactician in an implementation of the Command Bus Tactician by Ross Tuck.
Warning
Original package has been abandoned. The author has designated this repository as an official replacement. Current tag deprecated Joselfonseca namespace. Next release will be named to Jagarsoft.
Installation
To install this update your composer.json run composer require jagarsoft/laravel-tactician
>= laravel5.5
ServiceProvider will be attached automatically.
Other
Once the dependencies have been downloaded, add the service provider to your config/app.php file:
You are done with the installation!
Usage
To use the command bus you can resolve the bus from the laravel container like so:
Or you can inject it into a class constructor:
Once you have the bus instance you can add your handler for the command to be dispatched:
Now you can dispatch the command with the middleware:
You can map the input data array of the Command's constructor with a plain list of arguments or the array itself. For example:
Of course, you can use default values!
For more information about the usage of the tactician command bus please visit http://tactician.thephpleague.com/.
Example
Check out this example of the package implemented in a simple create order command https://gist.github.com/joselfonseca/24ee0e96666a06b16f92.
Bindings
You can configure the bindings for the locator, inflector, extractor and default bus by publishing the config file like so:
Then you can modify each class name and they will be resolved from the laravel container:
Generators
You can generate Commands and Handlers automatically using artisan:
This will create FooCommand and FooHandler and place them in the app/Commands
folder, please note that the words Command
and Handler
will be added to the class names respectively, so in the avobe example the clases created will be FooCommand
and FooHandler
.
To run both at once:
Middleware included
Laravel tactician includes some useful middleware you can use in your commands.
- Database Transactions: This Middleware will run the command inside a database transaction, if any exception is thrown the transaction won't be committed and the database will stay intact, you can find this middleware in
Joselfonseca\LaravelTactician\Middleware\DatabaseTransactions
.
Change log
Please see the releases page https://github.com/joselfonseca/laravel-tactician/releases
Tests
To run the tests in this package, navigate to the root folder of the project and run:
Then
Contributing
Please see CONTRIBUTING for details.
Security
If you discover any security related issues, please email jose at ditecnologia dot com instead of using the issue tracker.
Credits
- Jose Luis Fonseca
- All Contributors
License
The MIT License (MIT). Please see License File for more information.