quix-labs / laravel-hook-system
Add hooks system to Laravel
                                    Fund package maintenance!
                                                                            
                                                                                                                                        alancolant
                                                                                    
                                                                
Installs: 29
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 4
pkg:composer/quix-labs/laravel-hook-system
Requires
- php: ^8.1
- illuminate/console: ^10.0 || ^11.0 || ^12.0
- illuminate/contracts: ^10.0 || ^11.0 || ^12.0
- illuminate/support: ^10.0 || ^11.0 || ^12.0
Requires (Dev)
- larastan/larastan: ^2.0.1 || ^3.0
- laravel/pint: ^1.14
- nunomaduro/collision: ^8.1.1||^7.10.0
- orchestra/testbench: ^8.8 || ^9.0 || ^10.0
- pestphp/pest: ^2.20 || ^3.0
- pestphp/pest-plugin-arch: ^2.0 || ^3.0
- pestphp/pest-plugin-laravel: ^2.0 || ^3.0
- phpstan/extension-installer: ^1.3
- phpstan/phpstan-deprecation-rules: ^1.1 || ^2.0
- phpstan/phpstan-phpunit: ^1.3 || ^2.0
- dev-main
- 1.2.0
- 1.1.2
- 1.1.0
- 1.0.0
- dev-dependabot/github_actions/actions/download-artifact-6
- dev-dependabot/github_actions/actions/upload-artifact-5
- dev-dependabot/github_actions/stefanzweifel/git-auto-commit-action-7
- dev-dependabot/github_actions/actions/checkout-5
- dev-dependabot/github_actions/actions/download-artifact-5
- dev-dev
This package is auto-updated.
Last update: 2025-10-27 08:26:46 UTC
README
The quix-labs/laravel-hook-system package provides a hook system for Laravel.
This system allows intercepting and manipulating specific actions in your application.
Requirements
- PHP >= 8.1
- Laravel 10.x|11.x|12.x
Installation
You can install this package via Composer:
composer require quix-labs/laravel-hook-system
Hook usage
Creating a Hook
A hook is a class that extends QuixLabs\LaravelHookSystem\Hook:
class GetString extends \QuixLabs\LaravelHookSystem\Hook { public function __construct(public string &$string) { } }
Creating a Fully Cacheable Hook
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); } }
Registering Hooks
In the register method of your ServiceProvider:
use Workbench\App\Hooks\GetString; class YourProvider{ public function register() { \QuixLabs\LaravelHookSystem\HookRegistry::registerHook(GetString::class); } }
Executing a Hook
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; } }
Interceptor usage
Creating an Interceptor
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); } }
Registering Interceptors
In the boot method of your ServiceProvider:
class YourProvider{ public function boot() { \QuixLabs\LaravelHookSystem\HookRegistry::registerInterceptor(\App\Interceptors\AppendRandomString::class); } }
Artisan Commands
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.
Planned Features
The following features are planned for future implementation:
- Instantiate interceptor class using app()(add support for dependency container injection).
Changelog
Please see CHANGELOG for more information on what has changed recently.
Credits
License
The MIT License (MIT). Please see License File for more information.