/var/www/html/wp-includes/sitemaps/class-wp-sitemaps-registry.php


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
<?php
/**
 * Sitemaps: WP_Sitemaps_Registry class
 *
 * Handles registering sitemap providers.
 *
 * @package WordPress
 * @subpackage Sitemaps
 * @since 5.5.0
 */

/**
 * Class WP_Sitemaps_Registry.
 *
 * @since 5.5.0
 */
#[AllowDynamicProperties]
class 
WP_Sitemaps_Registry {
    
/**
     * Registered sitemap providers.
     *
     * @since 5.5.0
     *
     * @var WP_Sitemaps_Provider[] Array of registered sitemap providers.
     */
    
private $providers = array();

    
/**
     * Adds a new sitemap provider.
     *
     * @since 5.5.0
     *
     * @param string               $name     Name of the sitemap provider.
     * @param WP_Sitemaps_Provider $provider Instance of a WP_Sitemaps_Provider.
     * @return bool Whether the provider was added successfully.
     */
    
public function add_provider$nameWP_Sitemaps_Provider $provider ) {
        if ( isset( 
$this->providers$name ] ) ) {
            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;

        return 
true;
    }

    
/**
     * Returns a single registered sitemap provider.
     *
     * @since 5.5.0
     *
     * @param string $name Sitemap provider name.
     * @return WP_Sitemaps_Provider|null Sitemap provider if it exists, null otherwise.
     */
    
public function get_provider$name ) {
        if ( ! 
is_string$name ) || ! isset( $this->providers$name ] ) ) {
            return 
null;
        }

        return 
$this->providers$name ];
    }

    
/**
     * Returns all registered sitemap providers.
     *
     * @since 5.5.0
     *
     * @return WP_Sitemaps_Provider[] Array of sitemap providers.
     */
    
public function get_providers() {
        return 
$this->providers;
    }
}