frictionlessdigital/actions is a Laravel package for frictionless solutions | actions.
It currently has 0 GitHub stars and 1.352 downloads on Packagist (latest version 12.0.0).
Install it with composer require frictionlessdigital/actions.
Discover more Laravel packages by frictionlessdigital
or browse all Laravel packages to compare alternatives.
Last updated
Based on phenomenal Loris Leiva Actions for Laravel, this package is just a wrapper with a few methods added to sugar-syntax it.
This is for version 10.x and above, which is NOT directly compatible with 1.x.
composer require frictionlessdigital/actions
Note that root namespace for the package is Fls not Frictionlessditial.
The package does not require configuration.
Read base documentation here: Laravel Actions
The protected method is similar to tap(): will return the $value after passing it to the $closure.
return $this->tap(User::first(), fn(User $user) => $user->delete());
is the equivalent of
$user = User::first();
$user->delete();
return $user;
// $user;
Similar to pipe(), this protected method will return the result $value after running the $closure; closure is free to modify the $value.
return $this->pipe(User::first(), fn($user) => $user->delete());
is the equivalent of
$user = User::first();
return $user->delete();
// true;
This is an alias for validateAttributes() - returns an array of attributes validated through rules().
use Fls\Actions\Action;
class UserAction extends Action
{
public function rules()
{
return [
'name' => ['required', 'string'],
'email' => ['required', 'email'],
'notes' => ['nullable', 'string'],
];
}
...
public function handle($attributes) {
return $this->fill($attributes)->validated();
}
}
UserAction::run([
'name' => 'John',
'email' => '[email protected]',
]);
// ['name' => 'John', 'email' => '[email protected]']
This method will validate the attribute, throw an exception is data is not valid, but the return value is the class itself; good for chaining.
use Fls\Actions\Action;
class UserAction extends Action
{
...
public function handle(User $user, $attributes) {
return $this->fill($attributes)
->validate()
->tap($user, fn(User $user) => $user->update($this->validated()));
}
}
Could be useful if you need to make sure validation is complete before chaining-in another action.
This method will wrap the action in a DB transaction.
use Fls\Actions\Action;
use App\User;
class CreateUserAction extends Action
{
public function handle(User $user, $attributes)
{
return $user->create($attributes);
}
}
and can be executed using run and runInTransaction alike. In the latter case, the action will be executed inside a DB::transaction.
Return value would match between the two.
Please see CHANGELOG for more information on what has changed recently.
$ composer test
Please see CONTRIBUTING and CODE_OF_CONDUCT for details.
If you discover any security related issues, please email [email protected] instead of using the issue tracker.
The MIT License (MIT). Please see License File for more information.