summaryrefslogtreecommitdiffstats
path: root/wp-includes/sitemaps/class-wp-sitemaps-index.php
diff options
context:
space:
mode:
Diffstat (limited to 'wp-includes/sitemaps/class-wp-sitemaps-index.php')
-rw-r--r--wp-includes/sitemaps/class-wp-sitemaps-index.php96
1 files changed, 96 insertions, 0 deletions
diff --git a/wp-includes/sitemaps/class-wp-sitemaps-index.php b/wp-includes/sitemaps/class-wp-sitemaps-index.php
new file mode 100644
index 0000000..9403588
--- /dev/null
+++ b/wp-includes/sitemaps/class-wp-sitemaps-index.php
@@ -0,0 +1,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 __construct( WP_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( $sitemaps, 0, $this->max_sitemaps, true );
+ }
+
+ /**
+ * 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' );
+ }
+}