alleyinteractive / wp-path-dispatch
Simply and easily add a URL which fires an action, triggers a callback, and/or loads a template.
Installs: 10 533
Dependents: 0
Suggesters: 0
Security: 0
Stars: 7
Watchers: 19
Forks: 1
Open Issues: 2
pkg:composer/alleyinteractive/wp-path-dispatch
Requires
- php: ^8.0
Requires (Dev)
This package is auto-updated.
Last update: 2025-10-23 17:09:32 UTC
README
Simply and easily add a URL which fires an action, triggers a callback, and/or loads a template.
Installation
You can install the package via composer:
composer require alleyinteractive/wp-path-dispatch
Usage
At any point before init,
\WP_Path_Dispatch\Path_Dispatch()->add_path( [ 'path' => 'some-path', 'callback' => 'some_function' ] );
This will cause http://domain.com/some-path/ to call some_function().
IMPORTANT! You must flush your rewrites after adding a path.
You can add multiple paths at once with add_paths():
\WP_Path_Dispatch\Path_Dispatch()->add_paths( [ [ 'path' => 'some-path', 'callback' => 'some_function', ], [ 'path' => 'custom-feed.json', 'callback' => 'custom_feed', ], [ 'path' => 'custom-feed.xml', 'callback' => 'custom_feed', ], ] );
The dispatch happens on parse_query, so you can then modify the query via
pre_get_posts or do whatever
you have to do. You can even just load a static file and exit if you simply need to render static content.
When the path is loaded, the action dispatch_path_{$path} is fired. You can
hook onto this instead of or
in addition to passing a callback to add_path(s). The callback is optional.
Lastly, you can set custom rewrites if your paths are more complex. In these cases, the 'path' argument essentially becomes a slug. See add_rewrite_rule() for details about 'rule', 'redirect' (rewrite), and 'position'.
Full breakdown of all the path options
\WP_Path_Dispatch\Path_Dispatch()->add_path( [ 'path' => 'some-path', // required 'callback' => 'some_function', // optional 'action' => '', // fire this action instead of dispatch_path_{$path} 'template' => '', // optional 'rewrite' => [ // optional 'query_vars' => [], // optional 'rule' => '', // required (assuming 'rewrite' is set) 'redirect' => 'index.php?dispatch=$matches[1]', // optional 'position' => 'top' // optional ], ] );
Examples
Simplest possible usages: fires the action 'dispatch_path_my-path' at http://domain.com/my-path/
\WP_Path_Dispatch\Path_Dispatch()->add_path( [ 'path' => 'my-path', ] );
This can even be simplified further as:
\WP_Path_Dispatch\Path_Dispatch()->add_path( 'my-path' );
Call the function 'my_function' at http://domain.com/my-path/
\WP_Path_Dispatch\Path_Dispatch()->add_path( [ 'path' => 'my-path', 'callback' => 'my_function', ] );
Load the template file 'dispatch-custom-page.php' at http://domain.com/my-path/
\WP_Path_Dispatch\Path_Dispatch()->add_path( [ 'path' => 'my-path', 'template' => 'custom-page' ] );
Add a custom rewrite rule. Fires the action 'dispatch_path_my-path' at e.g. http://domain.com/my-path/foo/ and sets the query var 'my_path' to 'foo'. This assumes you already registered that query var.
\WP_Path_Dispatch\Path_Dispatch()->add_path( [ 'path' => 'my-rewrite', 'rewrite' => [ 'rule' => 'my-path/(.*)/?', 'redirect' => 'index.php?dispatch=my-rewrite&my_path=$matches[1]' ], ] );
Same as above, but registers the query var automatically, and loads the template 'dispatch-my-page.php'.
\WP_Path_Dispatch\Path_Dispatch()->add_path( [ 'path' => 'my-rewrite', 'rewrite' => [ 'rule' => 'my-path/(.+)/?', 'redirect' => 'index.php?dispatch=my-rewrite&my_path=$matches[1]', 'query_vars' => 'my_path', ], 'template' => 'my-page', ] );
Same as above, but with multiple query vars, and with a callback instead of a template.
\WP_Path_Dispatch\Path_Dispatch()->add_path( [ 'path' => 'my-rewrite', 'rewrite' => [ 'rule' => 'my-path/([^/]+)/(.+)/?', 'redirect' => 'index.php?dispatch=my-rewrite&my_path=$matches[1]&my_section=$matches[2]', 'query_vars' => [ 'my_path', 'my_section' ], ], 'callback' => [ My_Singleton(), 'my_method' ], ] );
Changelog
Please see CHANGELOG for more information on what has changed recently.
Credits
This project is actively maintained by Alley Interactive. Like what you see? Come work with us.
License
The GNU General Public License (GPL) license. Please see License File for more information.