n5s / wp-hook-kit
A lightweight WordPress hook helper library. Register hooks before WordPress loads, run callbacks only once, and more.
Installs: 12
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
pkg:composer/n5s/wp-hook-kit
Requires
- php: ^8.2
Requires (Dev)
- ergebnis/composer-normalize: ^2.48
- mantle-framework/testkit: ^1.15
- phpstan/extension-installer: ^1.4
- phpunit/phpcov: ^10.0
- syde/phpcs: ^1.0
- szepeviktor/phpstan-wordpress: ^2.0
This package is auto-updated.
Last update: 2025-12-23 15:36:40 UTC
README
A lightweight WordPress hook helper library. Register hooks before WordPress loads, run callbacks only once, and more.
Installation
composer require n5s/wp-hook-kit
Usage
use n5s\WpHookKit\Hook; // Basic usage - works even before WordPress is loaded Hook::addFilter('the_content', fn($content) => $content . '<p>Footer</p>'); Hook::addAction('init', fn() => register_post_type('book', [])); // Run a callback only once (removes itself after first execution) Hook::addFilterOnce('the_title', fn($title) => $title . ' - Launch Sale!'); Hook::addActionOnce('wp_footer', fn() => echo '<!-- First visit -->'); // Side effects - run code without modifying the filtered value Hook::addFilterSideEffect('the_content', function($content) { error_log('Content rendered: ' . strlen($content) . ' chars'); }); // Combine both: side effect that runs once Hook::addFilterSideEffectOnce('template_include', function($template) { log_first_template_load($template); }); // Register same callback on multiple hooks Hook::addFilters(['the_title', 'the_content'], 'esc_html'); Hook::addActions(['wp_head', 'wp_footer'], fn() => do_something());
All methods accept the standard WordPress parameters: $hook, $callback, $priority = 10, $accepted_args = 1.
Why?
Early registration: Register hooks before WordPress fully loads. The library writes directly to $wp_filter when add_filter() isn't available yet. Unlocks the power of bringing features without the "plugin" way hassle when it's not needed (library, composer autoloaded files, etc.).
Once variants: Because sometimes, you might not want your callback to be executed every time a hook is called.
Side effects: Runs your callback and returns the original value unchanged. Useful to trigger actions when an actual action isn't available, observe filter behavior, etc.
Acknowledgments
This package is gathering multiple package implementations inside a single library, credits goes to:
- wecodemore/wordpress-early-hook — Early hook registration. The only downside is that it can't safely be used inside a library (because Composer doesn't guarantee autoloaded files order). Plus some minor performance improvements.
- stevegrunwell/one-time-callbacks — Once variants
- alleyinteractive/wp-filter-side-effects — Side effects
License
MIT