A lightweight WordPress hook helper library. Register hooks before WordPress loads, run callbacks only once, and more.
composer require n5s/wp-hook-kituse 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.
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.
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
MIT