The quix-labs/laravel-hook-system
package provides a hook system for Laravel.
This system allows intercepting and manipulating specific actions in your application.
- PHP >= 8.1
- Laravel 10.x|11.x
You can install this package via Composer:
composer require quix-labs/laravel-hook-system
A hook is a class that extends QuixLabs\LaravelHookSystem\Hook
:
class GetString extends \QuixLabs\LaravelHookSystem\Hook
{
public function __construct(public string &$string)
{
}
}
Fully cacheable hooks execute interceptors during cache generation and prevent their execution at runtime. An interceptor can bypass this behavior.
class GetString extends \QuixLabs\LaravelHookSystem\Hook implements \QuixLabs\LaravelHookSystem\Interfaces\FullyCacheable
{
public function __construct(public string &$string)
{
}
public static function initialInstance(): static
{
$string = 'initial-state';
return new static($string);
}
}
In the register
method of your ServiceProvider:
use Workbench\App\Hooks\GetString;
class YourProvider{
public function register()
{
\QuixLabs\LaravelHookSystem\HookRegistry::registerHook(GetString::class);
}
}
To execute a hook, QuixLabs\LaravelHookSystem\Hook
implements the static send
method:
class YourController
{
public function index()
{
$string = "";
\Workbench\App\Hooks\GetString::send($string);
return $string;
}
}
An interceptor is a class with a static method intercepted via an #[Intercept]
attribute:
use Illuminate\Support\Str;
use QuixLabs\LaravelHookSystem\Enums\ActionWhenMissing;
use QuixLabs\LaravelHookSystem\Utils\Intercept;
class AppendRandomString
{
#[Intercept(\Workbench\App\Hooks\GetString::class)]
public static function appendRandomString(GetString $hook): void
{
$hook->string .= Str::random(16);
}
# You can specify action when hook not found (THROW_ERROR, SKIP or REGISTER_HOOK)
#[Intercept(\Workbench\App\Hooks\GetString::class, ActionWhenMissing::THROW_ERROR)]
public static function appendStringRequired(GetString $hook): void
{
$hook->string .= Str::random(16);
}
# You can also specify execution priority using third argument
#[Intercept(\Workbench\App\Hooks\GetString::class, ActionWhenMissing::SKIP, 100)]
public static function appendRandomStringAtTheEnd(GetString $hook): void
{
$hook->string .= Str::random(16);
}
# You can prevent full cache generation (useful if the interceptor depends on context request)
#[Intercept(\Workbench\App\Hooks\GetString::class, ActionWhenMissing::SKIP, 100, false)]
public static function appendRandomStringAtTheEnd(GetString $hook): void
{
$hook->string .= Str::random(16);
}
}
In the boot
method of your ServiceProvider:
class YourProvider{
public function boot()
{
\QuixLabs\LaravelHookSystem\HookRegistry::registerInterceptor(\App\Interceptors\AppendRandomString::class);
}
}
The package adds three Artisan commands to manage the hooks:
hooks:status
: Displays the status of hooks and interceptors.hooks:cache
: Caches the hooks and interceptors.hooks:clear
: Clears the hooks and interceptors cache.
The following features are planned for future implementation:
- Instantiate interceptor class using
app()
(add support for dependency container injection).
Please see CHANGELOG for more information on what has changed recently.
The MIT License (MIT). Please see License File for more information.