/var/www/html/wp-includes/sitemaps/class-wp-sitemaps-index.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
87
88
89
90
91
92
93
94
95
96
<?php
/**
 * Sitemaps: WP_Sitemaps_Index class.
 *
 * Generates the sitemap index.
 *
 * @package WordPress
 * @subpackage Sitemaps
 * @since 5.5.0
 */

/**
 * Class WP_Sitemaps_Index.
 * Builds the sitemap index page that lists the links to all of the sitemaps.
 *
 * @since 5.5.0
 */
#[AllowDynamicProperties]
class 
WP_Sitemaps_Index {
    
/**
     * The main registry of supported sitemaps.
     *
     * @since 5.5.0
     * @var WP_Sitemaps_Registry
     */
    
protected $registry;

    
/**
     * Maximum number of sitemaps to include in an index.
     *
     * @since 5.5.0
     *
     * @var int Maximum number of sitemaps.
     */
    
private $max_sitemaps 50000;

    
/**
     * WP_Sitemaps_Index constructor.
     *
     * @since 5.5.0
     *
     * @param WP_Sitemaps_Registry $registry Sitemap provider registry.
     */
    
public function __constructWP_Sitemaps_Registry $registry ) {
        
$this->registry $registry;
    }

    
/**
     * Gets a sitemap list for the index.
     *
     * @since 5.5.0
     *
     * @return array[] Array of all sitemaps.
     */
    
public function get_sitemap_list() {
        
$sitemaps = array();

        
$providers $this->registry->get_providers();
        
/* @var WP_Sitemaps_Provider $provider */
        
foreach ( $providers as $name => $provider ) {
            
$sitemap_entries $provider->get_sitemap_entries();

            
// Prevent issues with array_push and empty arrays on PHP < 7.3.
            
if ( ! $sitemap_entries ) {
                continue;
            }

            
// Using array_push is more efficient than array_merge in a loop.
            
array_push$sitemaps, ...$sitemap_entries );
            if ( 
count$sitemaps ) >= $this->max_sitemaps ) {
                break;
            }
        }

        return 
array_slice$sitemaps0$this->max_sitemapstrue );
    }

    
/**
     * Builds the URL for the sitemap index.
     *
     * @since 5.5.0
     *
     * @global WP_Rewrite $wp_rewrite WordPress rewrite component.
     *
     * @return string The sitemap index URL.
     */
    
public function get_index_url() {
        global 
$wp_rewrite;

        if ( ! 
$wp_rewrite->using_permalinks() ) {
            return 
home_url'/?sitemap=index' );
        }

        return 
home_url'/wp-sitemap.xml' );
    }
}