johnbillion / wp-hooks-generator
Generates a JSON representation of the WordPress actions and filters in your code
Fund package maintenance!
johnbillion
Installs: 90 893
Dependents: 1
Suggesters: 0
Security: 0
Stars: 78
Watchers: 1
Forks: 6
Open Issues: 6
Requires
- php: >=8.3
- ext-libxml: *
- erusev/parsedown: 1.8.0-beta-7
- nikic/php-parser: 5.3.1
- phpdocumentor/reflection-docblock: 5.5.1
Requires (Dev)
Replaces
README
Generates a JSON representation of the WordPress actions and filters in your code. Can be used with WordPress plugins, themes, and core.
Note: If you just want the hook files without generating them yourself, use the following packages instead:
- wp-hooks/wordpress-core for WordPress core
Requirements
PHP 8.3 or higher.
Installation
composer require wp-hooks/generator
Generating the Hook Files
./bin/wp-hooks-generator --input=src --output=hooks
Usage of the Generated Hook Files in PHP
// Get hooks as JSON: $actions_json = file_get_contents( 'hooks/actions.json' ); $filters_json = file_get_contents( 'hooks/filters.json' ); // Convert hooks to PHP: $actions = json_decode( $actions_json, true )['hooks']; $filters = json_decode( $filters_json, true )['hooks']; // Search for filters matching a string: $search = 'permalink'; $results = array_filter( $filters, function( array $hook ) use ( $search ) { return ( strpos( $hook['name'], $search ) !== false ); } ); var_dump( $results );
Usage of the Generated Hook Files in JavaScript
// Get hooks as array of objects: const actions = require('hooks/actions.json').hooks; const filters = require('hooks/filters.json').hooks; // Search for actions matching a string: const search = 'menu'; const results = actions.filter( hook => ( hook.name.match( search ) !== null ) ); console.log(results);
Ignoring Files or Directories
You can ignore files or directories in two ways:
On the Command Line
./vendor/bin/wp-hooks-generator --input=src --output=hooks --ignore-files="ignore/this,ignore/that"
In composer.json
"extra": { "wp-hooks": { "ignore-files": [ "ignore/this", "ignore/that" ] } }
Ignoring Hooks
You can ignore hooks in two ways:
On the Command Line
./vendor/bin/wp-hooks-generator --input=src --output=hooks --ignore-hooks="this_hook,that_hook"
In composer.json
"extra": { "wp-hooks": { "ignore-hooks": [ "this_hook", "that_hook" ] } }
TypeScript Interfaces for the Hook Files
The TypeScript interfaces for the hook files can be found in interface/index.d.ts
. Usage:
import { Hooks, Hook, Doc, Tags, Tag } from 'hooks/index.d.ts';
JSON Schema for the Hook Files
The JSON schema for the hook files can be found in schema.json
.