chameleon2die4 / wp-router
Routes paths to callback functions in WordPress.
Requires
- php: >=7.2.0
This package is auto-updated.
Last update: 2024-12-14 04:46:47 UTC
README
Provides a simple API for mapping requests to callback functions.
Description
WordPress's rewrite rules and query variables provide a powerful system
for mapping URL strings to collections of posts. Every request is parsed
into query variables and turned into a SQL query via $wp_query->query()
.
Sometimes, though, you don't want to display a list of posts. You just want a URL to map to a callback function, with the output displayed in place of posts in whatever theme you happen to be using.
That's where WP Router comes in. It handles all the messy bits of registering post types, query variables, rewrite rules, etc., and lets you write code to do what you want it to do. One function call is all it takes to map a URL to your designated callback function and display the return value in the page.
Installation
Composer:
Browse into directory and run;
$ composer require chameleon2die4/wp-router
Requirements:
- PHP >= 7.0
Uninstall
After remove package use flush_rewrite_rules()
function.
Usage
Creating Routes
- Your plugin should hook into the
wp_router_generate_routes
action. The callback should take one argument, aWP_Router
object. - Register a route and its callback using
WP_Router::add_route( $id, $args )
$id
is a unique string your plugin should use to identify the route$args
is an associative array, that sets the following properties for your route. Any omitted argument will use the default value.-
path
(required) - A regular expression to match against the request path. This corresponds to the array key you would use when creating rewrite rules for WordPress. -
query_vars
- An associative array, with the keys being query vars, and the values being explicit strings or integers corresponding to match in the path regexp. Any query variables included here will be automatically registered. -
title
- The title of the page. -
title_callback
- A callback to use for dynamically generating the title. Defaults to__()
. IfNULL
, thetitle
argument will be used as-is. ifpage_callback
oraccess_callback
returnsFALSE
,title_callback
will not be called.title_callback
can be either a single callback function or an array specifying callback functions for specific HTTP methods (e.g.,GET
,POST
,PUT
,DELETE
, etc.). If the latter, thedefault
key will be used if no other keys match the current request method. -
title_arguments
- An array of query variables whose values will be passed as arguments totitle_callback
. Defaults to the value oftitle
. If an argument is not a registered query variable, it will be passed as-is. -
page_callback
(required) - A callback to use for dynamically generating the contents of the page. The callback should either echo or return the contents of the page (if both, the returned value will be appended to the echoed value). IfFALSE
is returned, nothing will be output, and control of the page contents will be handed back to WordPress. The callback will be called during theparse_request
phase of WordPress's page load. Ifaccess_callback
returnsFALSE
,page_callback
will not be called.page_callback
can be either a single callback function or an array specifying callback functions for specific HTTP methods (e.g.,GET
,POST
,PUT
,DELETE
, etc.). If the latter, thedefault
key will be used if no other keys match the current request method. -
page_arguments
- An array of query variables whose values will be passed as arguments topage_callback
. If an argument is not a registered query variable, it will be passed as-is. -
access_callback
- A callback to determine if the user has permission to access this page. Ifaccess_arguments
is provided, default iscurrent_user_can
, otherwise default isTRUE
. If the callback returnsFALSE
, anonymous users are redirected to the login page, authenticated users get a 403 error.access_callback
can be either a single callback function or an array specifying callback functions for specific HTTP methods (e.g.,GET
,POST
,PUT
,DELETE
, etc.). If the latter, thedefault
key will be used if no other keys match the current request method. -
access_arguments
- An array of query variables whose values will be passed as arguments toaccess_callback
. If an argument is not a registered query variable, it will be passed as-is. -
template
- An array of templates that can be used to display the page. If a path is absolute, it will be used as-is; relative paths allow for overrides by the theme. The string$id
will be replaced with the ID of the route. If no template is found, fallback templates are (in this order):route-$id.php
,route.php
,page-$id.php
,page.php
,index.php
. If FALSE is given instead of an array, the page contents will be printed before callingexit()
(you can also accomplish this by printing your output and exiting directly from your callback function).
-
Example:
$router->add_route('wp-router-sample', array( 'path' => '^wp_router/(.*?)$', 'query_vars' => array( 'sample_argument' => 1, ), 'page_callback' => array(get_class(), 'sample_callback'), 'page_arguments' => array('sample_argument'), 'access_callback' => TRUE, 'title' => 'WP Router Sample Page', 'template' => array('sample-page.php', dirname(__FILE__).DIRECTORY_SEPARATOR.'sample-page.php') ));
In this example, the path http://example.com/wp_router/my_sample_path/
will call
the function sample_callback
in the calling class. The value of the sample_argument
query variable, in this case "my_sample_path", will be provided as the first and only
argument to the callback function. If the file sample-page.php
is found in the theme,
it will be used as the template, otherwise sample-page.php
in your plugin directory will
be used (if that's not found either, fall back to route-wp-router-sample.php
, etc.).
Editing Routes
You can hook into the wp_router_alter_routes
action to modify routes created by other plugins. The callback should take one argument, a WP_Router
object.
Public API Function
Creating or changing routes should always occur in the context of the wp_router_generate_routes
or wp_router_alter_routes
actions, using the WP_Router
object supplied to your callback function.
WP_Router::edit_route( string $id, array $changes )
- update each property given in$changes
for the route with the given ID. Any properties not given in$changes
will be left unaltered.WP_Router::remove_route( string $id )
- delete the route with the given IDWP_Router::get_route( string $id )
- get theWP_Route
object for the given IDWP_Router::get_url( string $id, array $arguments )
- get the URL to reach the route with the given ID, with the given query variables and their valuesWP_Route::get( string $property )
- get the value of the specified property for theWP_Route
instance