Sitemaps: Replace wp_sitemaps_register_providers
filter with more suitable wp_sitemaps_add_provider
filter.
The previous filter failed the goal of allowing developers to filter all providers before they are registered, since it only filtered the built-in ones. The more specific `wp_sitemaps_add_provider` filter enables exactly that, as it filters every sitemap provider right before it is added to the sitemaps registry. Props pbiron, pfefferle, Chouby, swissspidy. Fixes #50660. git-svn-id: https://develop.svn.wordpress.org/trunk@48543 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
bea9ce74a7
commit
7bcdf886c0
@ -25,19 +25,32 @@ class WP_Sitemaps_Registry {
|
|||||||
private $providers = array();
|
private $providers = array();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Adds a sitemap with route to the registry.
|
* Adds a new sitemap provider.
|
||||||
*
|
*
|
||||||
* @since 5.5.0
|
* @since 5.5.0
|
||||||
*
|
*
|
||||||
* @param string $name Name of the sitemap provider.
|
* @param string $name Name of the sitemap provider.
|
||||||
* @param WP_Sitemaps_Provider $provider Instance of a WP_Sitemaps_Provider.
|
* @param WP_Sitemaps_Provider $provider Instance of a WP_Sitemaps_Provider.
|
||||||
* @return bool True if the provider was added, false if it is already registered.
|
* @return bool Whether the provider was added successfully.
|
||||||
*/
|
*/
|
||||||
public function add_provider( $name, WP_Sitemaps_Provider $provider ) {
|
public function add_provider( $name, WP_Sitemaps_Provider $provider ) {
|
||||||
if ( isset( $this->providers[ $name ] ) ) {
|
if ( isset( $this->providers[ $name ] ) ) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filters the sitemap provider before it is added.
|
||||||
|
*
|
||||||
|
* @since 5.5.0
|
||||||
|
*
|
||||||
|
* @param WP_Sitemaps_Provider $provider Instance of a WP_Sitemaps_Provider.
|
||||||
|
* @param string $name Name of the sitemap provider.
|
||||||
|
*/
|
||||||
|
$provider = apply_filters( 'wp_sitemaps_add_provider', $provider, $name );
|
||||||
|
if ( ! $provider instanceof WP_Sitemaps_Provider ) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
$this->providers[ $name ] = $provider;
|
$this->providers[ $name ] = $provider;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
@ -110,29 +110,12 @@ class WP_Sitemaps {
|
|||||||
* @since 5.5.0
|
* @since 5.5.0
|
||||||
*/
|
*/
|
||||||
public function register_sitemaps() {
|
public function register_sitemaps() {
|
||||||
/**
|
$providers = array(
|
||||||
* Filters the list of registered sitemap providers.
|
'posts' => new WP_Sitemaps_Posts(),
|
||||||
*
|
'taxonomies' => new WP_Sitemaps_Taxonomies(),
|
||||||
* @since 5.5.0
|
'users' => new WP_Sitemaps_Users(),
|
||||||
*
|
|
||||||
* @param array $providers {
|
|
||||||
* Array of WP_Sitemaps_Provider objects keyed by their name.
|
|
||||||
*
|
|
||||||
* @type WP_Sitemaps_Posts $posts The WP_Sitemaps_Posts object.
|
|
||||||
* @type WP_Sitemaps_Taxonomies $taxonomies The WP_Sitemaps_Taxonomies object.
|
|
||||||
* @type WP_Sitemaps_Users $users The WP_Sitemaps_Users object.
|
|
||||||
* }
|
|
||||||
*/
|
|
||||||
$providers = apply_filters(
|
|
||||||
'wp_sitemaps_register_providers',
|
|
||||||
array(
|
|
||||||
'posts' => new WP_Sitemaps_Posts(),
|
|
||||||
'taxonomies' => new WP_Sitemaps_Taxonomies(),
|
|
||||||
'users' => new WP_Sitemaps_Users(),
|
|
||||||
)
|
|
||||||
);
|
);
|
||||||
|
|
||||||
// Register each supported provider.
|
|
||||||
/* @var WP_Sitemaps_Provider $provider */
|
/* @var WP_Sitemaps_Provider $provider */
|
||||||
foreach ( $providers as $name => $provider ) {
|
foreach ( $providers as $name => $provider ) {
|
||||||
$this->registry->add_provider( $name, $provider );
|
$this->registry->add_provider( $name, $provider );
|
||||||
|
Loading…
Reference in New Issue
Block a user